【牛客网】 J-闯关的lulu

链接:https://www.nowcoder.com/acm/contest/67/J 
来源:牛客网

时间限制:C/C++ 1秒,其他语言2秒 
空间限制:C/C++ 32768K,其他语言65536K 
64bit IO Format: %lld 
题目描述 
勇者lulu某天进入了一个高度10,000,000层的闯关塔,在塔里每到一层楼,他都会获得对应数量的0 1(看情况获得),然后塔里有一个法则,当你身上某个数字达到一个特定的数量时,它们会合成为下一个数字,现在问题来了,当lulu从1层到达第n层的时候,他身上的数字是多少。 
第1层 0 
第2层 11 
第3层 110 
第4层 21 
第5层 210 
第6层 22 
第7层 220 
第8层 2211 
第9层 22110 
第10层 2221 
第11层 22210 
第12层 3 
输入描述:

第一行是样例数T(T<100) 
第2到2+T-1行每行有一个整数n(0 < n < =10^7)。 
输出描述: 
从大到小输出lulu到达第n层时身上的数字

示例1 
输入





20 
输出


11 
110 
32211 
备注: 
对于100%的数据, 
0 < T <= 100 

0 < n <= 10^7

题解:

 

①当lulu到达奇数层时可以获得1个数字'0';当lulu到达偶数层时可以获得1个数字'0'和1个数字'1'

②当lulu获得k+2个数字k时,这个k+2个数字k会全部消失并变成1个k+1

先计算出0,1的个数,再寻找规律,发现a[i]=a[i]+a[i-1]/i的规律。

 

 

 

#include<stdio.h>
#include<string.h>
int main()
{
	int t;
	scanf("%d",&t);
	while(t--)
	{
		long long int m,n,i,j;
		scanf("%lld",&n);
		int a[1000];
		memset(a,0,sizeof(a));
		a[0]=n;
		a[1]=n/2;
		
		for(i=2;;i++)
		{
			a[i-1]=a[i-1]+a[i-2]/(i);
			a[i-2]=a[i-2]%(i);
			if(a[i-1]==0)
			break;
		}
		for(i=i-2;i>=0;i--)
		{
			if(a[i]==0)
			continue;
			for(j=a[i];j>0;j--)
			printf("%lld",i);
		}
		printf("\n");
	}
	
	return 0;
}

 

 

 

全部评论

相关推荐

03-10 11:23
门头沟学院 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
正在热议
更多
# 一张图晒出你司的标语 #
4453次浏览 78人参与
# 找AI工作可以去哪些公司? #
10086次浏览 314人参与
# 米连集团26产品管培生项目 #
13481次浏览 285人参与
# 你的实习产出是真实的还是包装的? #
20825次浏览 346人参与
# 从事AI岗需要掌握哪些技术栈? #
9809次浏览 390人参与
# 春招至今,你的战绩如何? #
67740次浏览 599人参与
# 开放七大实习专项,百度暑期实习值得冲吗 #
15702次浏览 229人参与
# AI面会问哪些问题? #
29127次浏览 632人参与
# 你做过最难的笔试是哪家公司 #
35940次浏览 313人参与
# 中国电信笔试 #
32390次浏览 301人参与
# 金三银四,你的春招进行到哪个阶段了? #
22563次浏览 284人参与
# 投递几十家公司,到现在0offer,大家都一样吗 #
341221次浏览 2176人参与
# 同bg的你秋招战况如何? #
212267次浏览 1121人参与
# 哪些公司真双非友好? #
69817次浏览 289人参与
# 如何准备秋招 #
78324次浏览 868人参与
# 阿里笔试 #
179436次浏览 1324人参与
# 应届生被毁约被毁意向了怎么办 #
63349次浏览 305人参与
# 机械人避雷的岗位/公司 #
62727次浏览 393人参与
# 小马智行求职进展汇总 #
25151次浏览 80人参与
# 第一份工作一定要去大厂吗 #
15204次浏览 123人参与
# 担心入职之后被发现很菜怎么办 #
291429次浏览 1210人参与
# 为了减少AI幻觉,你注入过哪些设定? #
26323次浏览 310人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务