6-9 长整数转化成16进制字符串 (15 分)
本题要求实现一个将长整数转化成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
作者: 张泳
单位: 浙江大学城市学院
时间限制: 400 ms
内存限制: 64 MB
void f( long int x, char *p ){
int sign=1,N,i;
char t[MAXN];//取余是从低位到高位,在来一个保存,最后转化给题目的p
if(x<0)//负数对他绝对值部分取值
{
sign*=-1;
x*=-1;
}
for(i=0;;i++)
{
if(x%16>9)//对16取余,大于9的换成A-F
{
t[i]=x%16+'A'-10;
}
else
{
t[i]=x%16+'0';换成0-9字符
}
x/=16;
if(!x)
break;
}
N=i+1;//位数,因为在循环没有正常结束时就退出,在计算位数要+1
if(sign>0)//正数
{
for(i=0;i<N;i++)
{
*(p+i)=*(t+N-i-1);//尾对头
}
*(p+i)='\0';//字符串结束标志
}
else//负数
{
*p='-';//第一位给负号
for(i=0;i<N;i++)
{
*(p+1+i)=*(t+N-i-1);//从p【1】开始从t[ ] 得到字符
}
*(p+1+i)='\0';
}
}