外星日历

外星日历(2017蓝桥杯真题)

题目描述
本题为填空题,只需要算出结果后,在代码中使用输出语句将所填结果输出即可。

某星系深处发现了文明遗迹。

他们的计数也是用十进制。 他们的文明也有日历。日历只有天数,没有年、月的概念。 有趣的是,他们也使用了类似“星期”的概念, 只不过他们的一个星期包含了 9 天, 为了方便,这里分别记为:A,B,C…H,I。

从一些资料上看到, 他们的 23 日是星期 E, 他们的 190 日是星期 A, 他们的 343251 日是星期 I。

令人兴奋的是,他们居然也预见了“世界末日”的那天, 当然是一个很大很大的数字 651764141421415346185。

请你计算一下,这遥远的一天是该文明的星期几?

运行限制
最大运行时间:1s
最大运行内存: 128M

思路分析:
①将大数放到string中,A-I放到num数组中;
②将string中每个数字字符转化为数字存在sum数组中;
③循环得到num数组中每个元素对9取余的余数的和再对9取余得到最终的ans;
取余公式分析
④num[ans-1]即为答案。

易错分析:
①数字庞大不可用int或者long long;
②double可以装下,但是明显不可以进行取余操作;

上代码:

#include<bits/stdc++.h>
using namespace std;
int main()
{
	char num[9]={'A','B','C','D','E','F','G','H','I'};
	string str="651764141421415346185";
	int sum[25]={0};
	for(int i=0 ; i<str.length() ; i++)
	{
		sum[i]=str[i]-'0';
	}
	int ans=0;
	for(int i=0 ; i<str.length() ; i++)
	{
		ans=ans+sum[i]%9;//大数取余 
	}
	ans=ans%9;//最后还要再取余一次 
	if(ans!=0) cout<<num[ans-1];//要考虑余数为0数组下标越界的问题 
	else cout<<num[8];	
	return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值