C语言问题:给定一个十进制正整数,将其转化成26进制数输出,其中用A表示0, B表示1, ... , Z表示25。
输入十进制正整数N(0<=N<=1,000,000,000),并以-1为结束符。输出转换得到的26进制数。...
输入十进制正整数N( 0 <= N <= 1,000,000,000 ),并以-1为结束符。
输出转换得到的26进制数。 展开
输出转换得到的26进制数。 展开
2个回答
展开全部
一楼做得不错可惜美中不足,稍微修改了下
#include "stdio.h"
int change(long int n,int a[])
{
int i = 0;
while(n!=0)
{
a[i] = n%26;
n/=26;
i++;
}
return i;
}
void main()
{
long int n;
int i,l;
int a[10];
printf("请输入一个在0与一亿之间的整数:\n");
scanf("%ld",&n);
l=change(n,a);
for(i=l-1;i>=0;i--)
printf("%c",a[i]+'A');
printf("\n");
}
展开全部
#include "stdio.h"
int change(long int n,int a[]);
void main(){
long int n;
int i,l;
int a[10];
printf("请输入一个在0与一亿之间的整数:\n");
scanf("%ld",&n);
l=change(n,a);
for(i=l-1;i>=0;i--)
{ switch(a[i]){
case 0:a[i]='A';break;
case 1:a[i]='B';break;
case 2:a[i]='C';break;
case 3:a[i]='D';break;
case 4:a[i]='E';break;
case 5:a[i]='F';break;
case 6:a[i]='G';break;
case 7:a[i]='H';break;
case 8:a[i]='I';break;
case 9:a[i]='J';break;
case 10:a[i]='K';break;
case 11:a[i]='L';break;
case 12:a[i]='M';break;
case 13:a[i]='N';break;
case 14:a[i]='O';break;
case 15:a[i]='P';break;
case 16:a[i]='Q';break;
case 17:a[i]='R';break;
case 18:a[i]='S';break;
case 19:a[i]='T';break;
case 20:a[i]='U';break;
case 21:a[i]='V';break;
case 22:a[i]='W';break;
case 23:a[i]='X';break;
case 24:a[i]='Y';break;
case 25:a[i]='Z';break;
default:break;
}
printf("%c",a[i]);
}
printf("\n");
}
int change(long int n,int a[]){
int i = 0;
while(n!=0){
a[i] = n%26;
n/=26;
i++;
}
return i;
}
int change(long int n,int a[]);
void main(){
long int n;
int i,l;
int a[10];
printf("请输入一个在0与一亿之间的整数:\n");
scanf("%ld",&n);
l=change(n,a);
for(i=l-1;i>=0;i--)
{ switch(a[i]){
case 0:a[i]='A';break;
case 1:a[i]='B';break;
case 2:a[i]='C';break;
case 3:a[i]='D';break;
case 4:a[i]='E';break;
case 5:a[i]='F';break;
case 6:a[i]='G';break;
case 7:a[i]='H';break;
case 8:a[i]='I';break;
case 9:a[i]='J';break;
case 10:a[i]='K';break;
case 11:a[i]='L';break;
case 12:a[i]='M';break;
case 13:a[i]='N';break;
case 14:a[i]='O';break;
case 15:a[i]='P';break;
case 16:a[i]='Q';break;
case 17:a[i]='R';break;
case 18:a[i]='S';break;
case 19:a[i]='T';break;
case 20:a[i]='U';break;
case 21:a[i]='V';break;
case 22:a[i]='W';break;
case 23:a[i]='X';break;
case 24:a[i]='Y';break;
case 25:a[i]='Z';break;
default:break;
}
printf("%c",a[i]);
}
printf("\n");
}
int change(long int n,int a[]){
int i = 0;
while(n!=0){
a[i] = n%26;
n/=26;
i++;
}
return i;
}
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询