1144: 多种进制
时间限制: 1 Sec 内存限制: 128 MB
题目描述
输入一个十进制整数n,转换成2、3、7、8进制输出
要求程序定义一个dToK()函数,功能是将十进制数转化为k进制整数,其余功能在main()函数中实现。
void dToK(int n, int k, char str[])
{
//将n转化为k进制数,存入str
}
输入
输入一个int范围内的正整数n
输出
输出为4行,分别是n对应的2、3、7、8进制数
样例输入
13
样例输出
1101
111
16
15
这题我犯的一个错误,转进制的时候直接 str[i]=n%k 了,导致输出乱码,而实际应该是 str[i]=n%k+'0' 。
//1144: 多种进制
#include<stdlib.h>
#include<string.h>
#include<stdio.h>
#define maxn 100
void dToK(int n, int k, char *str);
char *revstr(char *str, size_t len);
char str2[maxn],str3[maxn],str7[maxn],str8[maxn];
int main(){
int n,i;
scanf("%d",&n);
dToK(n,2,str2);
dToK(n,3,str3);
dToK(n,7,str7);
dToK(n,8,str8);
return 0;
}
char *revstr(char *str, size_t len)
{
char *start = str;
char *end = str + len - 1;
char ch;
if (str != NULL)
{
while (start < end)
{
ch = *start;
*start++ = *end;
*end-- = ch;
}
}
return str;
}
void dToK(int n, int k, char *str1)
{
//将n转化为k进制数,存入str
char str[maxn];
if(n==0) {
str[0]='0';
}
int i=0;
while(n>0&&str!=NULL){
str[i]=n%k+'0';
n=n/k;
i++;
}
str[i]='\0';
for(i--;i>=0;i--){
printf("%c",str[i]);
}
printf("\n");
}