题目:
本题要求实现一个将长整数转化成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 i=0,m,count=0,j=0;
char a[MAXN];
if(x<0){//处理特殊情况
p[0]='-';
i++;
x=-x;
}
if(x==0){//处理特殊情况
p[0]='0';
return;
}
while(x!=0){
m=x%16;
x=x/16;
if(m<10){
a[j++]=m+'0';//转换为数字 并填入数组a
}
else{
a[j++]=m-10+'A';//转换为字母 并填入数组a
}
count++; //count表示填了多少个
}
for(;i<=count;i++){//将数组a中的数字倒序复制到p中
p[i]=a[--j];//注意这里是先减了才赋值给j
}
p[i]='\0';
}