#include <stdio.h>
void convertHex(char* s,int data)
{
static int index = 0;
if(data != 0)
{
convertHex(s,data/16);
*(s + index++) = "0123456789ABCDEF"[data%16];
}
*(s + index) = '\0';//末尾加'\0'
}
int main()
{
char str[129] = "hello world";//若是定义为static,则无需关心末尾加0
int data;
if(scanf("%d", &data))
{
convertHex(str,data);
puts(str);
}
else
fprintf(stderr,"input error");
for(int i = 0;i<10;i++)
printf("%d ",str[i]);
return 0;
}
#include <stdio.h>
void convertHex(char* s,int data)
{
static int count = 0;
static int index = 0;
if(data != 0)
{
count++;
if(count > 128) {fprintf(stderr,"error data is too big !");exit(1);}
convertHex(s+1,data/16);
count--;
*(s-count + index++) = "0123456789ABCDEF"[data%16];
}
else
*s = '\0';//末尾加'\0'
}
int main()
{
char str[129]="hello world";
int data;
if(scanf("%d", &data))
{
convertHex(str,data);
puts(str);
}
else
fprintf(stderr,"input error");
for(int i = 0;i<10;i++)
printf("%d ",str[i]);
return 0;
}
不用递归
#include<stdio.h>
int main()
{
int i,j,k=0,num,sum=0,n,m,d;
char str[2000],str1[2000];
printf("输入要转换的数: \n");
scanf("%s",str);//输入要转换的数,并存储在字符串数组中
printf("输入这个数本身的进制数: \n");
scanf("%d",&n);
printf("要求转换成的进制数: \n");
scanf("%d",&m);
for(i=0;str[i]!='\0';i++)
{
if(str[i]>='0'&&str[i]<='9')//将每一个数找出
num=str[i]-'0';
else
num=str[i]-'a'+10;
sum=sum*n+num;
}
while(sum)
{
d=sum%m;
str1[k++]="0123456789abcdef"[d];/*这里其实还有一种方法就是判断余数与10的大小关系,如果余数大于等于十将这个数字加上87(若字母为大写就加55)转化为对应的字母,若为数字就按此方发存入数组。*/
sum/=m;
}
for(i=k-1;i>=0;i--)
{
if(str1[i]>='0'&&str1[i]<='9')
printf("%d",str1[i]-'0');
else
printf("%d",str1[i]-'a'+10);
}
return 0;
}
C++写法
#include <iostream>
using namespace std;
void convertHex(string& s,string::size_type data)
{
if(data != 0)
{
convertHex(s,data/16);
s = s + "0123456789ABCDEF"[data%16];
}
}
int main()
{
string result;
string::size_type data;
while(cin >> data)
{
convertHex(result,data);
}
cout << result << endl;
return 0;
}