蓝桥杯C语言练习题目(十三)----年号字串

一、题目要求如下

二、解题思路

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;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值