2017团队天梯赛决赛题选做

         头一次去参加大规模的程序比赛现场,果然不出意外的震撼,当时见到很多大牛,心里只有膜拜啊,也为自己没有考好感到很遗憾,在这里做些总结,当然后面的有难度的题就保留下来吧,毕竟还是很菜啊。。。。


L1-041. 寻找250

时间限制
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
陈越

对方不想和你说话,并向你扔了一串数…… 而你必须从这一串数字中找到“250”这个高大上的感人数字。

输入格式:

输入在一行中给出不知道多少个绝对值不超过1000的整数,其中保证至少存在一个“250”。

输出格式:

在一行中输出第一次出现的“250”是对方扔过来的第几个数字(计数从1开始)。题目保证输出的数字在整型范围内。

输入样例:
888 666 123 -233 250 13 250 -222
输出样例:
5
还是比较简单的,手速赛也比不过人家啊。。。。。
#include
#include
#include
#include
#include
#include
using namespace std;
int f[100000];
int main()
{
  int a,k=0;
  while(scanf("%d",&a)!=EOF)
  {
    f[k++]=a;
  }
  for(int i=0;i

L1-042. 日期格式化

时间限制
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
陈越

世界上不同国家有不同的写日期的习惯。比如美国人习惯写成“月-日-年”,而中国人习惯写成“年-月-日”。下面请你写个程序,自动把读入的美国格式的日期改写成中国习惯的日期。

输入格式:

输入在一行中按照“mm-dd-yyyy”的格式给出月、日、年。题目保证给出的日期是1900年元旦至今合法的日期。

输出格式:

在一行中按照“yyyy-mm-dd”的格式给出年、月、日。

输入样例:
03-15-2017
输出样例:
2017-03-15
#include
#include
#include
#include
#include
#include
using namespace std;
int main()
{
  int m,d,y;
  scanf("%d-%d-%d",&m,&d,&y);
  printf("%d-%02d-%02d\n",y,m,d);
  return 0;
}

L1-043. 阅览室

时间限制
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
陈越

天梯图书阅览室请你编写一个简单的图书借阅统计程序。当读者借书时,管理员输入书号并按下S键,程序开始计时;当读者还书时,管理员输入书号并按下E键,程序结束计时。书号为不超过1000的正整数。当管理员将0作为书号输入时,表示一天工作结束,你的程序应输出当天的读者借书次数和平均阅读时间。

注意:由于线路偶尔会有故障,可能出现不完整的纪录,即只有S没有E,或者只有E没有S的纪录,系统应能自动忽略这种无效纪录。另外,题目保证书号是书的唯一标识,同一本书在任何时间区间内只可能被一位读者借阅。

输入格式:

输入在第一行给出一个正整数N(<= 10),随后给出N天的纪录。每天的纪录由若干次借阅操作组成,每次操作占一行,格式为:

书号([1, 1000]内的整数) 键值(“S”或“E”) 发生时间(hh:mm,其中hh是[0,23]内的整数,mm是[0, 59]内整数)

每一天的纪录保证按时间递增的顺序给出。

输出格式:

对每天的纪录,在一行中输出当天的读者借书次数和平均阅读时间(以分钟为单位的精确到个位的整数时间)。

输入样例:
3
1 S 08:10
2 S 08:35
1 E 10:00
2 E 13:16
0 S 17:00
0 S 17:00
3 E 08:10
1 S 08:20
2 S 09:00
1 E 09:20
0 E 17:00
输出样例:
2 196
0 0
1 60
应该要写这个题的,哎呀,可惜当时不会啊。。。。
好像坑点还很多。。



L1-044. 稳赢

时间限制
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
陈越

大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示:

现要求你编写一个稳赢不输的程序,根据对方的出招,给出对应的赢招。但是!为了不让对方输得太惨,你需要每隔K次就让一个平局。

输入格式:

输入首先在第一行给出正整数K(<=10),即平局间隔的次数。随后每行给出对方的一次出招:“ChuiZi”代表“锤子”、“JianDao”代表“剪刀”、“Bu”代表“布”。“End”代表输入结束,这一行不要作为出招处理。

输出格式:

对每一个输入的出招,按要求输出稳赢或平局的招式。每招占一行。

输入样例:
2
ChuiZi
JianDao
Bu
JianDao
Bu
ChuiZi
ChuiZi
End
输出样例:
Bu
ChuiZi
Bu
ChuiZi
JianDao
ChuiZi
Bu
这个也比较简单。。
#include
#include
#include
#include
#include
#include
using namespace std;
char s[5][10]={"ChuiZi","JianDao","Bu"};
char ss[10];
int main()
{
  int n;
  scanf("%d",&n);
  getchar();
  int k=1;
  while(scanf("%s",ss)!=EOF)
  {
    if(ss[0]=='E')
       break;
    if(k%(n+1)==0)
    {
      if(ss[0]=='C')
         printf("%s\n",s[0]);
      if(ss[0]=='J')
         printf("%s\n",s[1]);
      if(ss[0]=='B')
         printf("%s\n",s[2]);
      k=1;
    }
    else
    {
      if(ss[0]=='C')
         printf("%s\n",s[2]);
      if(ss[0]=='J')
         printf("%s\n",s[0]);
      if(ss[0]=='B')
         printf("%s\n",s[1]);
      k++;
    }
  }
  return 0;
}

L1-045. 宇宙无敌大招呼

时间限制
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
陈越

据说所有程序员学习的第一个程序都是在屏幕上输出一句“Hello World”,跟这个世界打个招呼。作为天梯赛中的程序员,你写的程序得高级一点,要能跟任意指定的星球打招呼。

输入格式:

输入在第一行给出一个星球的名字S,是一个由不超过7个英文字母组成的单词,以回车结束。

输出格式:

在一行中输出“Hello S”,跟输入的S星球打个招呼。

输入样例:
Mars
输出样例:
Hello Mars
总有一些神人能10秒不到写完一个Hello World!的小程序,我这算二级伤残吗。。。
#include
#include
#include
#include
#include
#include
using namespace std;

int main()
{
  char s[10];
  scanf("%s",s);
  printf("Hello %s",s);
  return 0;
}

L1-046. 整除光棍

时间限制
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
翁恺

这里所谓的“光棍”,并不是指单身汪啦~ 说的是全部由1组成的数字,比如1、11、111、1111等。传说任何一个光棍都能被一个不以5结尾的奇数整除。比如,111111就可以被13整除。 现在,你的程序要读入一个整数x,这个整数一定是奇数并且不以5结尾。然后,经过计算,输出两个数字:第一个数字s,表示x乘以s是一个光棍,第二个数字n是这个光棍的位数。这样的解当然不是唯一的,题目要求你输出最小的解。

提示:一个显然的办法是逐渐增加光棍的位数,直到可以整除x为止。但难点在于,s可能是个非常大的数 —— 比如,程序输入31,那么就输出3584229390681和15,因为31乘以3584229390681的结果是111111111111111,一共15个1。

输入格式:

输入在一行中给出一个不以5结尾的正奇数x(< 1000)。

输出格式:

在一行中输出相应的最小的s和n,其间以1个空格分隔。

输入样例:
31
输出样例:
3584229390681 15
看到这题,被吓到了,就没咋看,,,,
我要给这题做个完整的总结。。
首先,我按照题目给的提示暴力做了一遍,发现两个测试点超时,细想一下,确实会啊。。。
后来,经别人指点,每次对余数进行处理,直到余数能被那个奇数整除结束,把每次求得的除数输出即可,但是还有一个坑点,中间的除数可能为0,这个就比较尴尬了,还要特判一下是不是中间的值,11111=8*13000+5*1300+4*130+7*13,这个式子更好的解释了上述我说的内容,虽然说的不太明白,但是大概就是如此。。
#include
#include
#include
#include
#include
#include
using namespace std;

int main()
{
	int x;
	scanf("%d",&x);
	int t=1,s=1;
	int m;
	int flag=0;
    while(1)
    {
    	if(t%x==0)
    	{
    		m=t/x;
    		printf("%d %d",m,s);
    		break;
		}
		else
		{	
		    m=t/x;
		    if(m>0||(m==0&&flag))
               printf("%d",m);			
			s++;
			t=t%x;
		}
		t=t*10+1;
		if(t>x)
	        flag=1;
	}
	return 0;
}

L1-047. 装睡

时间限制
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
陈越

你永远叫不醒一个装睡的人 —— 但是通过分析一个人的呼吸频率和脉搏,你可以发现谁在装睡!医生告诉我们,正常人睡眠时的呼吸频率是每分钟15-20次,脉搏是每分钟50-70次。下面给定一系列人的呼吸频率与脉搏,请你找出他们中间有可能在装睡的人,即至少一项指标不在正常范围内的人。

输入格式:

输入在第一行给出一个正整数N(<= 10)。随后N行,每行给出一个人的名字(仅由英文字母组成的、长度不超过3个字符的串)、其呼吸频率和脉搏(均为不超过100的正整数)。

输出格式:

按照输入顺序检查每个人,如果其至少一项指标不在正常范围内,则输出其名字,每个名字占一行。

输入样例:
4
Amy 15 70
Tom 14 60
Joe 18 50
Zoe 21 71
输出样例:
Tom
Zoe
#include
#include
#include
#include
#include
#include
using namespace std;
struct P
{
  char s[10];
  int m;
  int q;
};
P mm[20];
int main()
{
  int n;
  scanf("%d",&n);
  getchar();
  for(int i=0;i20||mm[i].q<50||mm[i].q>70)
    {
      printf("%s\n",mm[i].s);
    }
  }
  return 0;
}

L1-048. 矩阵A乘以B

时间限制
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
陈越

给定两个矩阵A和B,要求你计算它们的乘积矩阵AB。需要注意的是,只有规模匹配的矩阵才可以相乘。即若A有Ra行、Ca列,B有Rb行、Cb列,则只有Ca与Rb相等时,两个矩阵才能相乘。

输入格式:

输入先后给出两个矩阵A和B。对于每个矩阵,首先在一行中给出其行数R和列数C,随后R行,每行给出C个整数,以1个空格分隔,且行首尾没有多余的空格。输入保证两个矩阵的R和C都是正数,并且所有整数的绝对值不超过100。

输出格式:

若输入的两个矩阵的规模是匹配的,则按照输入的格式输出乘积矩阵AB,否则输出“Error: Ca != Rb”,其中Ca是A的列数,Rb是B的行数。

输入样例1:
2 3
1 2 3
4 5 6
3 4
7 8 9 0
-1 -2 -3 -4
5 6 7 8
输出样例1:
2 4
20 22 24 16
53 58 63 28
输入样例2:
3 2
38 26
43 -5
0 17
3 2
-11 57
99 68
81 72
输出样例2:
Error: 2 != 3
其实这题也不难,,
#include
#include
#include
#include
#include
#include
using namespace std;
int a[1000][1000],b[1000][1000],c[1000][1000];
int main()
{
  int r1,c1;
  scanf("%d%d",&r1,&c1);
  for(int i=0;i

果真还是水题练得不够,,,稍微难一点的水题就不会了,,,









你可能感兴趣的:(cccc)