本题要求实现一个将长整数转化成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;
}
}