本題要求實現一個將長整數轉化成16進制字符串的簡單函數。
函數接口定義:
void f( long int x, char *p );
其中x是待轉化的十進制長整數,p指向某個字符數組的首元素。函數f的功能是把轉換所得的16進制字符串寫入p所指向的數組。16進制的A~F爲大寫字母。
裁判測試程序樣例:
#include <stdio.h>
#define MAXN 10
void f( long int x, char *p );
int main()
{
long int x;
char s[MAXN] = “”;
scanf("%ld", &x);
f(x, s);
printf("%s\n", s);
return 0;
}
/* 你的代碼將被嵌在這裏 */
輸入樣例1:
123456789
輸出樣例1:
75BCD15
輸入樣例2:
-125
輸出樣例2:
-7D
函數代碼:
void f( long int x, char *p )
{
int len=0; //標記p的長度
long int i,item;
//如果x爲負數,則把“-”賦值給頭結點
if(x<0)
{
x=-x; //x取正數
*p='-';
len++; //len自增一位
}
//若爲0,則直接賦值爲‘0’
if(x==0)
*p='0';
//求出十六進制的位數
for(item=x;item>0;item/=16)
len++;
//題目限制在10位數內
for(i=0;i<MAXN;i++)
{
item=x%16;
x=x/16;
//如果小於10 倒敘 輸出字符 0 - 9 大於等於10輸出 A - F
if(item<10)
//p+len-1-i指向數組結尾
*(p+len-1-i)=item+'0';
else
*(p+len-1-i)=item-10+'A';
if(x==0)
break;
}
}