实验8-2-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
//2020/8/23
#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;
}
/* 你的代码将被嵌在这里 */
void f( long int x, char *p ){
//*p=p[],
//这一点明白了指针题做起来就省力了
int i,j,k;
int a[99];
k=x;
int u=x;
if (k < 0) k*=-1;
//对x的特殊情况,负数,进行处理
if (x == 0) i=1;
//对0进行预处理 ,
//再进行记录位数
else {
for (i = 0;k != 0;){
k/=16;
i++;
}
}
int t;
if (x >= 0){
for (j = i-1;j >= 0;j--){
//开始对x进行处转化
t=x%16;
x/=16;
//这里要注意,数的个位是数组下标最大的一位
//即要从末尾开始赋值
if (t >= 10) p[j]='A'+t-10;
else p[j]='0'+t;
}
p[i]='\0';
//字符串\0结尾
}
//对于负数要分开处理
//因为多了一个负号
else {
i++;
x*=-1;
for (j = i-1;j >= 1;j--){
t=x%16;
x/=16;
if (t >= 10) p[j]='A'+t-10;
else p[j]='0'+t;
}
p[0]='-';
//负数组的第一位是负号,与正数不同
p[i]='\0';
//同样\0结尾
}
}