一、题目要求如下
二、解题思路
2019是十进制数,也就是到10就进一位。
而依照题意转换成字母就是变成了类似26进制。(26位进一位,1~26分别就是A~Z)
但是因为字母的特殊性,他没有0,开始即是1(A),所以这是一个从1~26的26进制,逢27才进1位。例如27表示的就是AA,第一个A代表26个,第二个A是1个
例如:24(10)== X(26)括号内是进制的意思,即24十进制转换成26进制是x,这就能表示成第24位字母是x的意思。
那相应的3(10)== C(26)、1(10)== A(26)、27(10)==AA(26)....
AB这个字母串中,A代表的是26的1次方*1,B代表的是26的0次方*2。
所以要求2019的26进制,就是不断取26的模并进位。
把2019每次取26的模都存储下来,每次取模就是最后一位,保存到数组里,那么这个数组存储的就是逆序的26进制数(或者说是逆序的字母串)
所以最后输出要逆序输出,成为正序。
三、代码实现
#include <stdio.h>
int main()
{
int i,j,num;
char s[10];
//num是开始的数字,后面的运算代表着原本的数字。不断对2019取26的模,然后让num等于2019/26
//而j是num取26的模
num=2019;
j=num%26;
//这个功能是取2019的26进制数的逆序。
while(j!=0){
s[i]=64+j;//j是一个大于0的数字,例如j为1,代表着A。所以要64+j(ACSII码65是A)
i++;
num=num/26;
j=num%26;
}
//倒序输出26进制的2019
for(j=i;j>0;j--){
printf("%c",s[j-1]);
}
return 0;
}