两天的努力终于把天梯赛lv1的题做完了,虽然很水,但是还是花了我不少时间啊。。。。

L1-001. Hello World

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

这道超级简单的题目没有任何输入。

你只需要在一行中输出著名短句“Hello World!”就可以了。

5分的题,当然简单。

#include<cstdio>
int main()
{printf("Hello World!\n");return 0;
}

L1-002. 打印沙漏

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印

************
*****

所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。

给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。

输入格式:

输入在一行给出1个正整数N(<=1000)和一个符号,中间以空格分隔。

输出格式:

首先打印出由给定符号组成的最大的沙漏形状,最后在一行中输出剩下没用掉的符号数。

输入样例:

19 *

输出样例:

************
*****
2

这题首先要求出第一行的符号数,然后按输出样例格式输出符号即可。只是我最不会的就是看两端值,,,,所以这题还是写的蛮久的,也看了一部分别人的代码,感觉自己好low啊。。。。

#include<cstdio>
int main()
{int n;char a;scanf("%d %c",&n,&a);int d,i=1,j,max,sum=1;while(1){i+=2;if(sum+i*2>n){max=i-2;d=n-sum;break;}sum+=i*2;}for(i=max;i>=1;i-=2){for(j=0;j<=max;j++){if(j<(max-i)/2)printf(" ");else if(j>=(max+i)/2){printf("\n");break;}elseprintf("%c",a);}}for(i=3;i<=max;i+=2){for(j=0;j<=max;j++){if(j<(max-i)/2)printf(" ");else if(j>=(max+i)/2){printf("\n");break;}elseprintf("%c",a);}}printf("%d\n",d);return 0;
}

L1-003. 个位数统计

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

给定一个k位整数N = dk-1*10k-1 + ... + d1*101 + d0 (0<=di<=9, i=0,...,k-1, dk-1>0),请编写程序统计每种不同的个位数字出现的次数。例如:给定N = 100311,则有2个0,3个1,和1个3。

输入格式:

每个输入包含1个测试用例,即一个不超过1000位的正整数N。

输出格式:

对N中每一种不同的个位数字,以D:M的格式在一行中输出该位数字D及其在N中出现的次数M。要求按D的升序输出。

输入样例:

100311

输出样例:

0:2
1:3
3:1

这一题一看第一句就不想做了,后来才发现,超级简单,就是统计字符串中每个数的个数,并输出就行。。

#include<cstdio>
#include<cstring>
char s[1005];
int a[10];
int main()
{memset(a,0,sizeof(a));scanf("%s",s);int len=strlen(s);for(int i=0;i<len;i++){int k=s[i]-'0';a[k]++;}for(int i=0;i<=9;i++){if(a[i]!=0)printf("%d:%d\n",i,a[i]);}return 0;
}

L1-004. 计算摄氏温度

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈建海

给定一个华氏温度F,本题要求编写程序,计算对应的摄氏温度C。计算公式:C = 5*(F-32)/9。题目保证输入与输出均在整型范围内。

输入格式:

输入在一行中给出一个华氏温度。

输出格式:

在一行中按照格式“Celsius = C”输出对应的摄氏温度C的整数值。

输入样例:

150

输出样例:

Celsius = 65

最开始学的时候的一个程序,,,

#include<cstdio>
int main()
{int f,c;scanf("%d",&f);c=5*(f-32)/9;printf("Celsius = %d\n",c);return 0;
}

L1-005. 考试座位号

时间限制
200 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

每个PAT考生在参加考试时都会被分配两个座位号,一个是试机座位,一个是考试座位。正常情况下,考生在入场时先得到试机座位号码,入座进入试机状态后,系统会显示该考生的考试座位号码,考试时考生需要换到考试座位就座。但有些考生迟到了,试机已经结束,他们只能拿着领到的试机座位号码求助于你,从后台查出他们的考试座位号码。

输入格式:

输入第一行给出一个正整数N(<=1000),随后N行,每行给出一个考生的信息:“准考证号 试机座位号 考试座位号”。其中准考证号由14位数字组成,座位从1到N编号。输入保证每个人的准考证号都不同,并且任何时候都不会把两个人分配到同一个座位上。

考生信息之后,给出一个正整数M(<=N),随后一行中给出M个待查询的试机座位号码,以空格分隔。

输出格式:

对应每个需要查询的试机座位号码,在一行中输出对应考生的准考证号和考试座位号码,中间用1个空格分隔。

输入样例:

4
10120150912233 2 4
10120150912119 4 1
10120150912126 1 3
10120150912002 3 2
2
3 4

输出样例:

10120150912002 2
10120150912119 1

这一题明显的结构体类型的题,虽然很简单,但是我不太熟悉结构体的操作,还是去看了别人的代码,再自己写出来的。

#include<cstdio>
struct Student
{char s[20];int n;int q;
};
int main()
{int n,m,a;scanf("%d",&n);Student stu[n];for(int i=0;i<n;i++){scanf("%s%d%d",stu[i].s,&stu[i].n,&stu[i].q);}scanf("%d",&m);while(m--){scanf("%d",&a);for(int i=0;i<n;i++){if(a==stu[i].n)printf("%s %d\n",stu[i].s,stu[i].q);}}return 0;
}

L1-006. 连续因子

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

一个正整数N的因子中可能存在若干连续的数字。例如630可以分解为3*5*6*7,其中5、6、7就是3个连续的数字。给定任一正整数N,要求编写程序求出最长连续因子的个数,并输出最小的连续因子序列。

输入格式:

输入在一行中给出一个正整数N(1<N<231)。

输出格式:

首先在第1行输出最长连续因子的个数;然后在第2行中按“因子1*因子2*……*因子k”的格式输出最小的连续因子序列,其中因子按递增顺序输出,1不算在内。

输入样例:

630

输出样例:

3
5*6*7

最近一直再看关于质因子分解的东西,好多种做法,让我感觉无从下手啊,,,所以又看了别人的代码,果然简练,不过从2开始遍历,虽然我一直担心会超,但是结果不会,一直不会算复杂度的我表示很忧伤,,,,,

#include<cstdio>
#include<cmath>
int main()
{int n;scanf("%d",&n);int i,j,m=sqrt(n)+1;int t=n,num=0,s;for(i=2;i<=m;i++){if(n%i==0){t=n/i;for(j=i+1;j<=m;j++){if(t%j==0) t/=j;elsebreak;}if(j-i>num){num=j-i;s=i;}}}if(num==0){printf("1\n%d\n",n);}else{printf("%d\n%d",num,s);for(int i=s+1;i<=s+num-1;i++)printf("*%d",i);printf("\n");}return 0;
}

L1-007. 念数字

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
翁恺

输入一个整数,输出每个数字对应的拼音。当整数为负数时,先输出“fu”字。十个数字对应的拼音如下:

0: ling
1: yi
2: er
3: san
4: si
5: wu
6: liu
7: qi
8: ba
9: jiu

输入格式:

输入在一行中给出一个整数,如: 1234 。

提示:整数包括负数、零和正数。

输出格式:

在一行中输出这个整数对应的拼音,每个数字的拼音之间用空格分开,行末没有最后的空格。如 yi er san si

输入样例:

-600

输出样例:

fu liu ling ling

超级简单,上代码。。

#include<cstdio>
#include<cstring>
char s[10][10]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
char a[1000];
int main()
{scanf("%s",a);int i=0,len=strlen(a);if(a[i]=='-'){printf("fu ");i++;}    for(;i<len-1;i++)printf("%s ",s[a[i]-'0']);printf("%s\n",s[a[i]-'0']);return 0;
}

L1-008. 求整数段和

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
杨起帆

给定两个整数A和B,输出从A到B的所有整数以及这些数的和。

输入格式:

输入在一行中给出2个整数A和B,其中-100<=A<=B<=100,其间以空格分隔。

输出格式:

首先顺序输出从A到B的所有整数,每5个数字占一行,每个数字占5个字符宽度,向右对齐。最后在一行中输出全部数字的和。

输入样例:

-3 8

输出样例:

   -3   -2   -1    0    12    3    4    5    67    8
Sum = 30
#include<cstdio>
int main()
{int A,B,i,sum=0,f=0;scanf("%d%d",&A,&B);for(i=A;i<=B;i++){printf("%5d",i);sum+=i;f++;if(f%5==0)printf("\n");}if(f%5!=0)printf("\n"); printf("Sum = %d\n",sum);return 0;
}

L1-009. N个数求和

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

本题的要求很简单,就是求N个数字的和。麻烦的是,这些数字是以有理数“分子/分母”的形式给出的,你输出的和也必须是有理数的形式。

输入格式:

输入第一行给出一个正整数N(<=100)。随后一行按格式“a1/b1 a2/b2 ...”给出N个有理数。题目保证所有分子和分母都在长整型范围内。另外,负数的符号一定出现在分子前面。

输出格式:

输出上述数字和的最简形式 —— 即将结果写成“整数部分 分数部分”,其中分数部分写成“分子/分母”,要求分子小于分母,且它们没有公因子。如果结果的整数部分为0,则只输出分数部分。

输入样例1:

5
2/5 4/15 1/30 -2/60 8/3

输出样例1:

3 1/3

输入样例2:

2
4/3 2/3

输出样例2:

2

输入样例3:

3
1/3 -1/6 1/8

输出样例3:

7/24
#include<cstdio>
long long gcd(long long a,long long b)
{if(b==0)return a;return gcd(b,a%b);
}
int main()
{int n;scanf("%d",&n);long long a,b,t0,c,d,lcp;scanf("%lld/%lld",&a,&b);t0=gcd(a,b);if(a!=0){a/=t0;b/=t0;}int i=1;while(i<n){scanf("%lld/%lld",&c,&d);lcp=b*d/gcd(b,d);a=a*lcp/b+c*lcp/d;b=lcp;t0=gcd(a,b);if(a!=0){a/=t0;b/=t0;  }i++;}if(a%b==0)printf("%lld\n",a/b);elseif(a/b==0)printf("%lld/%lld\n",a%b,b);elseprintf("%lld %lld/%lld\n",a/b,a%b,b);return 0;
}

L1-010. 比较大小

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
杨起帆(浙江大学城市学院)

本题要求将输入的任意3个整数从小到大输出。

输入格式:

输入在一行中给出3个整数,其间以空格分隔。

输出格式:

在一行中将3个整数从小到大输出,其间以“->”相连。

输入样例:

4 2 8

输出样例:

2->4->8
#include<cstdio>
#include<algorithm>
using namespace std;
int main()
{int s[3];for(int i=0;i<3;i++)scanf("%d",&s[i]);sort(s,s+3);printf("%d->%d->%d\n",s[0],s[1],s[2]);   return 0;
}

L1-011. A-B

时间限制
100 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

本题要求你计算A-B。不过麻烦的是,A和B都是字符串 —— 即从字符串A中把字符串B所包含的字符全删掉,剩下的字符组成的就是字符串A-B。

输入格式:

输入在2行中先后给出字符串A和B。两字符串的长度都不超过104,并且保证每个字符串都是由可见的ASCII码和空白字符组成,最后以换行符结束。

输出格式:

在一行中打印出A-B的结果字符串。

输入样例:

I love GPLT!  It's a fun game!
aeiou

输出样例:

I lv GPLT!  It's  fn gm!
#include<cstdio>
#include<cstring>
char s1[10005],s2[10005],s3[10005];
int main()
{gets(s1);gets(s2);int len1=strlen(s1),len2=strlen(s2);int i,j,k=0;for(i=0;i<len1;i++){bool f=true;for(j=0;j<len2;j++){if(s1[i]==s2[j]){f=false;break;}}if(f) s3[k++]=s1[i];}s3[k]='\0';for(int i=0;i<k;i++)printf("%c",s3[i]);return 0;
}

L1-012. 计算指数

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

真的没骗你,这道才是简单题 —— 对任意给定的不超过10的正整数n,要求你输出2n。不难吧?

输入格式:

输入在一行中给出一个不超过10的正整数n。

输出格式:

在一行中按照格式“2^n = 计算结果”输出2n的值。

输入样例:

5

输出样例:

2^5 = 32
#include<cstdio>
int main()
{int n,sum=1;scanf("%d",&n);for(int i=1;i<=n;i++)sum*=2;printf("%d^%d = %d\n",2,n,sum);return 0;
}

L1-013. 计算阶乘和

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

对于给定的正整数N,需要你计算 S = 1! + 2! + 3! + ... + N!。

输入格式:

输入在一行中给出一个不超过10的正整数N。

输出格式:

在一行中输出S的值。

输入样例:

3

输出样例:

9
#include<cstdio>
int main()
{int n,sum,f;scanf("%d",&n);for(int i=1;i<=n;i++){f=1;for(int j=1;j<=i;j++)f*=j;sum+=f;}printf("%d",sum);return 0;
}

L1-014. 简单题

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

这次真的没骗你 —— 这道超级简单的题目没有任何输入。

你只需要在一行中输出事实:“This is a simple problem.”就可以了。

#include<cstdio>
int main()
{printf("This is a simple problem.");return 0;
}

L1-015. 跟奥巴马一起画方块

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

美国总统奥巴马不仅呼吁所有人都学习编程,甚至以身作则编写代码,成为美国历史上首位编写计算机代码的总统。2014年底,为庆祝“计算机科学教育周”正式启动,奥巴马编写了很简单的计算机代码:在屏幕上画一个正方形。现在你也跟他一起画吧!

输入格式:

输入在一行中给出正方形边长N(3<=N<=21)和组成正方形边的某种字符C,间隔一个空格。

输出格式:

输出由给定字符C画出的正方形。但是注意到行间距比列间距大,所以为了让结果看上去更像正方形,我们输出的行数实际上是列数的50%(四舍五入取整)。

输入样例:

10 a

输出样例:

aaaaaaaaaa
aaaaaaaaaa
aaaaaaaaaa
aaaaaaaaaa
aaaaaaaaaa
#include<cstdio>
#include<cmath>
int main()
{int n,m;char a;scanf("%d %c",&n,&a);m=floor(1.0*n/2+0.5);for(int i=0;i<m;i++){for(int j=0;j<n;j++)printf("%c",a);printf("\n");}return 0;
}

L1-016. 查验身份证

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

一个合法的身份证号码由17位地区、日期编号和顺序编号加1位校验码组成。校验码的计算规则如下:

首先对前17位数字加权求和,权重分配为:{7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};然后将计算的和对11取模得到值Z;最后按照以下关系对应Z值与校验码M的值:

Z:0 1 2 3 4 5 6 7 8 9 10
M:1 0 X 9 8 7 6 5 4 3 2

现在给定一些身份证号码,请你验证校验码的有效性,并输出有问题的号码。

输入格式:

输入第一行给出正整数N(<= 100)是输入的身份证号码的个数。随后N行,每行给出1个18位身份证号码。

输出格式:

按照输入的顺序每行输出1个有问题的身份证号码。这里并不检验前17位是否合理,只检查前17位是否全为数字且最后1位校验码计算准确。如果所有号码都正常,则输出“All passed”。

输入样例1:

4
320124198808240056
12010X198901011234
110108196711301866
37070419881216001X

输出样例1:

12010X198901011234
110108196711301866
37070419881216001X

输入样例2:

2
320124198808240056
110108196711301862

输出样例2:

All passed

这一题最大的坑点是要有两个flag控制,最初做这题的时候错误检查不出来,找了别人看代码,其实最主要的学习方法是自己摸索,尽量不要看人家的代码,或者让别人给你查错,虽然刚开始学习的我一直就这样干,,,

#include<cstdio>
char M[20]="10X98765432";
int a[18]={7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};
char s[20];
int main()
{int n,sum,f,ff;scanf("%d",&n);getchar();ff=1;while(n--){f=1;sum=0;scanf("%s",s);for(int i=0;i<17;i++){if(s[i]>='0'&&s[i]<='9'){sum+=(s[i]-'0')*a[i];sum%=11;}else{f=0;ff=0;printf("%s\n",s);break;  }}if(f&&s[17]!=M[sum]){ff=0;printf("%s\n",s);continue;}}if(ff) printf("All passed\n");return 0;
}

L1-017. 到底有多二

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

一个整数“犯二的程度”定义为该数字中包含2的个数与其位数的比值。如果这个数是负数,则程度增加0.5倍;如果还是个偶数,则再增加1倍。例如数字“-13142223336”是个11位数,其中有3个2,并且是负数,也是偶数,则它的犯二程度计算为:3/11*1.5*2*100%,约为81.82%。本题就请你计算一个给定整数到底有多二。

输入格式:

输入第一行给出一个不超过50位的整数N。

输出格式:

在一行中输出N犯二的程度,保留小数点后两位。

输入样例:

-13142223336

输出样例:

81.82%
#include<cstdio>
#include<cstring>
char s[55];
int main()
{scanf("%s",s);int len=strlen(s),m=len;double f=1,sum=0;if(s[0]=='-'){f=1.5;m=len-1;} for(int i=0;i<len;i++){if(s[i]=='2')sum++;}if(s[len-1]%2==0)f*=2;sum=100.00*sum/m*f;printf("%.2lf%%\n",sum);return 0;
}

这一题的%要用%%来输出。。

L1-018. 大笨钟

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

微博上有个自称“大笨钟V”的家伙,每天敲钟催促码农们爱惜身体早点睡觉。不过由于笨钟自己作息也不是很规律,所以敲钟并不定时。一般敲钟的点数是根据敲钟时间而定的,如果正好在某个整点敲,那么“当”数就等于那个整点数;如果过了整点,就敲下一个整点数。另外,虽然一天有24小时,钟却是只在后半天敲1~12下。例如在23:00敲钟,就是“当当当当当当当当当当当”,而到了23:01就会是“当当当当当当当当当当当当”。在午夜00:00到中午12:00期间(端点时间包括在内),笨钟是不敲的。

下面就请你写个程序,根据当前时间替大笨钟敲钟。

输入格式:

输入第一行按照“hh:mm”的格式给出当前时间。其中hh是小时,在00到23之间;mm是分钟,在00到59之间。

输出格式:

根据当前时间替大笨钟敲钟,即在一行中输出相应数量个“Dang”。如果不是敲钟期,则输出:

Only hh:mm.  Too early to Dang.

其中“hh:mm”是输入的时间。

输入样例1:

19:05

输出样例1:

DangDangDangDangDangDangDangDang

输入样例2:

07:05

输出样例2:

Only 07:05.  Too early to Dang.

这一题我要好好吐槽一番,一开始以为00:00要用字符串输入输出,后来一想完全没必要啊,就当一般的数字范围处理,if完全就能解决的题啊,完全没出意外,写对了!!!

#include<cstdio>
int main()
{int h,m,sum=0;scanf("%d:%d",&h,&m);if(h>=0&&h<12||(h==12&&m==0))printf("Only %02d:%02d.  Too early to Dang.",h,m);elseif(h>12&&h<=23&&m==0)sum=h-12;elseif(h==12&&m!=0||(h>12&&h<=23&&m!=0))sum=h-11;for(int i=0;i<sum;i++)printf("Dang");printf("\n");return 0;
}

L1-019. 谁先倒

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

划拳是古老中国酒文化的一个有趣的组成部分。酒桌上两人划拳的方法为:每人口中喊出一个数字,同时用手比划出一个数字。如果谁比划出的数字正好等于两人喊出的数字之和,谁就输了,输家罚一杯酒。两人同赢或两人同输则继续下一轮,直到唯一的赢家出现。

下面给出甲、乙两人的酒量(最多能喝多少杯不倒)和划拳记录,请你判断两个人谁先倒。

输入格式:

输入第一行先后给出甲、乙两人的酒量(不超过100的非负整数),以空格分隔。下一行给出一个正整数N(<=100),随后N行,每行给出一轮划拳的记录,格式为:

甲喊 甲划 乙喊 乙划

其中“喊”是喊出的数字,“划”是划出的数字,均为不超过100的正整数(两只手一起划)。

输出格式:

在第一行中输出先倒下的那个人:A代表甲,B代表乙。第二行中输出没倒的那个人喝了多少杯。题目保证有一个人倒下。注意程序处理到有人倒下就终止,后面的数据不必处理。

输入样例:

1 1
6
8 10 9 12
5 10 5 10
3 8 5 12
12 18 1 13
4 16 12 15
15 1 1 16

输出样例:

A
1

一定要注意读题!

#include<cstdio>
int ss[105][5];
int main()
{int a,b,n;int sum1=0,sum2=0;scanf("%d%d%d",&a,&b,&n);for(int i=0;i<n;i++)for(int j=0;j<4;j++)scanf("%d",&ss[i][j]);for(int i=0;i<n;i++){if(ss[i][0]+ss[i][2]==ss[i][1]){if(ss[i][0]+ss[i][2]!=ss[i][3])sum1++;if(sum1>a)break;}  if(ss[i][0]+ss[i][2]==ss[i][3]){if(ss[i][0]+ss[i][2]!=ss[i][1])sum2++;if(sum2>b)break;}  }if(sum1>a) printf("A\n%d\n",sum2);if(sum2>b) printf("B\n%d\n",sum1);return 0;
}

L1-020. 帅到没朋友

时间限制
200 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

当芸芸众生忙着在朋友圈中发照片的时候,总有一些人因为太帅而没有朋友。本题就要求你找出那些帅到没有朋友的人。

输入格式:

输入第一行给出一个正整数N(<=100),是已知朋友圈的个数;随后N行,每行首先给出一个正整数K(<=1000),为朋友圈中的人数,然后列出一个朋友圈内的所有人——为方便起见,每人对应一个ID号,为5位数字(从00000到99999),ID间以空格分隔;之后给出一个正整数M(<=10000),为待查询的人数;随后一行中列出M个待查询的ID,以空格分隔。

注意:没有朋友的人可以是根本没安装“朋友圈”,也可以是只有自己一个人在朋友圈的人。虽然有个别自恋狂会自己把自己反复加进朋友圈,但题目保证所有K超过1的朋友圈里都至少有2个不同的人。

输出格式:

按输入的顺序输出那些帅到没朋友的人。ID间用1个空格分隔,行的首尾不得有多余空格。如果没有人太帅,则输出“No one is handsome”。

注意:同一个人可以被查询多次,但只输出一次。

输入样例1:

3
3 11111 22222 55555
2 33333 44444
4 55555 66666 99999 77777
8
55555 44444 10000 88888 22222 11111 23333 88888

输出样例1:

10000 88888 23333

输入样例2:

3
3 11111 22222 55555
2 33333 44444
4 55555 66666 99999 77777
4
55555 44444 22222 11111

输出样例2:

No one is handsome

关于这一题,我其实是考虑太多了,而且我有个最大的毛病就是先写,然后再看,写到一半是发现如果全部遍历一遍的话,肯定会时间受限啊,没有注意到题目人的编号是00000到99999,这样完全可以用一个数组存储一下,然后没有存1的就是没朋友,果然还是想的太少,思路太狭隘,注意读题,只有一个人的算没朋友,还有一点就是出来的数要用%05d来输出编号,,,,

#include<cstdio>
#include<cstring>
int s[100005];
int main()
{int n;memset(s,0,sizeof(s));scanf("%d",&n);while(n--){int k;scanf("%d",&k);for(int i=0;i<k;i++){int p;scanf("%d",&p);if(k!=1)s[p]=1;}   }int m,a;scanf("%d",&m);int f=1;while(m--){scanf("%d",&a);if(s[a]!=1){s[a]=1;if(f)printf("%05d",a);elseprintf(" %05d",a);f=0;}}if(f) printf("No one is handsome");printf("\n");return 0;
}

L1-021. 重要的话说三遍

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

这道超级简单的题目没有任何输入。

你只需要把这句很重要的话 —— “I'm gonna WIN!”——连续输出三遍就可以了。

注意每遍占一行,除了每行的回车不能有任何多余字符。

#include<cstdio>
int main()
{printf("I'm gonna WIN!\n");printf("I'm gonna WIN!\n");printf("I'm gonna WIN!\n");return 0;
}

L1-022. 奇偶分家

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

给定N个正整数,请统计奇数和偶数各有多少个?

输入格式:

输入第一行给出一个正整N(<= 1000);第2行给出N个正整数,以空格分隔。

输出格式:

在一行中先后输出奇数的个数、偶数的个数。中间以1个空格分隔。

输入样例:

9
88 74 101 26 15 0 34 22 77

输出样例:

3 6
#include<cstdio>
int s[1005];
int main()
{int n,sum1=0,sum2=0;scanf("%d",&n);for(int i=0;i<n;i++)scanf("%d",&s[i]);for(int i=0;i<n;i++){if(s[i]%2==0)sum2++;elsesum1++;}printf("%d %d",sum1,sum2);return 0;
}

L1-023. 输出GPLT

时间限制
150 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

给定一个长度不超过10000的、仅由英文字母构成的字符串。请将字符重新调整顺序,按“GPLTGPLT....”这样的顺序输出,并忽略其它字符。当然,四种字符(不区分大小写)的个数不一定是一样多的,若某种字符已经输出完,则余下的字符仍按GPLT的顺序打印,直到所有字符都被输出。

输入格式:

输入在一行中给出一个长度不超过10000的、仅由英文字母构成的非空字符串。

输出格式:

在一行中按题目要求输出排序后的字符串。题目保证输出非空。

输入样例:

pcTclnGloRgLrtLhgljkLhGFauPewSKgt

输出样例:

GPLTGPLTGLTGLGLL
#include<cstdio>
#include<cstring>
char s[10005];
int a[5]={0};
int main()
{scanf("%s",&s);int len=strlen(s);for(int i=0;i<len;i++){if(s[i]=='G'||s[i]=='g')a[0]++;if(s[i]=='P'||s[i]=='p')a[1]++; if(s[i]=='L'||s[i]=='l')a[2]++;if(s[i]=='T'||s[i]=='t')a[3]++;      }while(a[0]!=0||a[1]!=0||a[2]!=0||a[3]!=0){for(int i=0;i<4;i++)if(a[i]!=0){a[i]--;if(i==0)printf("G");if(i==1)printf("P");if(i==2)printf("L");if(i==3)printf("T");}}printf("\n");return 0;
}

L1-024. 后天

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

如果今天是星期三,后天就是星期五;如果今天是星期六,后天就是星期一。我们用数字1到7对应星期一到星期日。给定某一天,请你输出那天的“后天”是星期几。

输入格式:

输入第一行给出一个正整数D(1 <= D <=7),代表星期里的某一天。

输出格式:

在一行中输出D天的后天是星期几。

输入样例:

3

输出样例:

5
#include<cstdio>
int main()
{int n,sum;while(scanf("%d",&n)!=EOF){if(n==5){printf("7");continue;}sum=(n+2)%7;printf("%d",sum);}return 0;
}

L1-025. 正整数A+B

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

本题的目标很简单,就是求两个正整数A和B的和,其中A和B都在区间[1,1000]。稍微有点麻烦的是,输入并不保证是两个正整数。

输入格式:

输入在一行给出A和B,其间以空格分开。问题是A和B不一定是满足要求的正整数,有时候可能是超出范围的数字、负数、带小数点的实数、甚至是一堆乱码。

注意:我们把输入中出现的第1个空格认为是A和B的分隔。题目保证至少存在一个空格,并且B不是一个空字符串。

输出格式:

如果输入的确是两个正整数,则按格式“A + B = 和”输出。如果某个输入不合要求,则在相应位置输出“?”,显然此时和也是“?”。

输入样例1:

123 456

输出样例1:

123 + 456 = 579

输入样例2:

22. 18

输出样例2:

? + 18 = ?

输入样例3:

-100 blabla bla...33

输出样例3:

? + ? = ?
#include<cstdio>
#include<cstring>
char s1[1000],s2[1000];
int main()
{scanf("%s ",s1);gets(s2);int len1=strlen(s1),len2=strlen(s2);int sum1=0,sum2=0;for(int i=0;i<len1;i++){if(s1[i]>='0'&&s1[i]<='9')sum1=sum1*10+s1[i]-'0';else{s1[0]='?';break;}}if(sum1<1||sum1>1000) s1[0]='?';for(int i=0;i<len2;i++){if(s2[i]>='0'&&s2[i]<='9')sum2=sum2*10+s2[i]-'0';else{s2[0]='?';break;}}if(sum2<1||sum2>1000) s2[0]='?';if(s1[0]!='?'&&s2[0]!='?')printf("%d + %d = %d\n",sum1,sum2,sum1+sum2);if(s1[0]!='?'&&s2[0]=='?')printf("%d + ? = ?\n",sum1);if(s1[0]=='?'&&s2[0]!='?')printf("? + %d = ?\n",sum2);if(s1[0]=='?'&&s2[0]=='?')printf("? + ? = ?\n");return 0;
}

L1-026. I Love GPLT

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

这道超级简单的题目没有任何输入。

你只需要把这句很重要的话 —— “I Love GPLT”——竖着输出就可以了。

所谓“竖着输出”,是指每个字符占一行(包括空格),即每行只能有1个字符和回车。

#include<cstdio>
int main()
{printf("I\n \nL\no\nv\ne\n \nG\nP\nL\nT\n");  return 0;
}

L1-027. 出租

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

下面是新浪微博上曾经很火的一张图:

一时间网上一片求救声,急问这个怎么破。其实这段代码很简单,index数组就是arr数组的下标,index[0]=2 对应 arr[2]=1,index[1]=0 对应 arr[0]=8,index[2]=3 对应 arr[3]=0,以此类推…… 很容易得到电话号码是18013820100。

本题要求你编写一个程序,为任何一个电话号码生成这段代码 —— 事实上,只要生成最前面两行就可以了,后面内容是不变的。

输入格式:

输入在一行中给出一个由11位数字组成的手机号码。

输出格式:

为输入的号码生成代码的前两行,其中arr中的数字必须按递减顺序给出。

输入样例:

18013820100

输出样例:

int[] arr = new int[]{8,3,2,1,0};
int[] index = new int[]{3,0,4,3,1,0,2,4,3,4,4};
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
char s[20],s1[20],f[20],ss[20],aa[20];
int main()
{scanf("%s",s);for(int i=0;i<11;i++)s1[i]=s[i];sort(s1,s1+11);int i,k=1;f[0]=s1[0];for(i=1;i<11;i++){if(s1[i]!=s1[i-1])f[k++]=s1[i]; }int j=0;for(i=k-1;i>=0;i--)ss[j++]=f[i];for(i=0;i<11;i++){for(k=0;k<j;k++){if(s[i]==ss[k]){aa[i]=k+'0';break;}}}printf("int[] arr = new int[]{");for(i=0;i<j-1;i++)printf("%c,",ss[i]);printf("%c};\n",ss[i]);printf("int[] index = new int[]{");for(i=0;i<10;i++)printf("%c,",aa[i]);printf("%c};\n",aa[i]);  return 0;
}

L1-028. 判断素数

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

本题的目标很简单,就是判断一个给定的正整数是否素数。

输入格式:

输入在第一行给出一个正整数N(<=10),随后N行,每行给出一个小于231的需要判断的正整数。

输出格式:

对每个需要判断的正整数,如果它是素数,则在一行中输出“Yes”,否则输出“No”。

输入样例:

2
11
111

输出样例:

Yes
No

这题 不需要打表,最重要的是打表的时候数组要开到2^31这么大,显然不可能开那么的数组,,用一般的条件判断就行了,,

#include<cstdio>
#include<cmath>
int main()
{int n,a; scanf("%d",&n);while(n--){scanf("%d",&a);int m=sqrt(a);if(a==1){printf("No\n");continue;}bool f=true;for(int i=2;i<=m;i++){if(a%i==0){f=false;break;}}if(f)printf("Yes\n");elseprintf("No\n");}  return 0;
}

L1-029. 是不是太胖了

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

据说一个人的标准体重应该是其身高(单位:厘米)减去100、再乘以0.9所得到的公斤数。已知市斤是公斤的两倍。现给定某人身高,请你计算其标准体重应该是多少?(顺便也悄悄给自己算一下吧……)

输入格式:

输入第一行给出一个正整数H(100 < H <= 300),为某人身高。

输出格式:

在一行中输出对应的标准体重,单位为市斤,保留小数点后1位。

输入样例:

169

输出样例:

124.2
#include<cstdio>
int main()
{int h;double w;scanf("%d",&h);w=(h-100)*1.8;printf("%.1lf\n",w);return 0;
}

L1-030. 一帮一

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

“一帮一学习小组”是中小学中常见的学习组织方式,老师把学习成绩靠前的学生跟学习成绩靠后的学生排在一组。本题就请你编写程序帮助老师自动完成这个分配工作,即在得到全班学生的排名后,在当前尚未分组的学生中,将名次最靠前的学生与名次最靠后的异性学生分为一组。

输入格式:

输入第一行给出正偶数N(<=50),即全班学生的人数。此后N行,按照名次从高到低的顺序给出每个学生的性别(0代表女生,1代表男生)和姓名(不超过8个英文字母的非空字符串),其间以1个空格分隔。这里保证本班男女比例是1:1,并且没有并列名次。

输出格式:

每行输出一组两个学生的姓名,其间以1个空格分隔。名次高的学生在前,名次低的学生在后。小组的输出顺序按照前面学生的名次从高到低排列。

输入样例:

8
0 Amy
1 Tom
1 Bill
0 Cindy
0 Maya
1 John
1 Jack
0 Linda

输出样例:

Amy Jack
Tom Linda
Bill Maya
Cindy John
#include<cstdio>
int vis[55]={0};
struct Student
{int sex;char name[10];
};
int main()
{int n;scanf("%d",&n);Student stu[n];for(int i=0;i<n;i++)scanf("%d %s",&stu[i].sex,stu[i].name);for(int i=0;i<n/2;i++){printf("%s ",stu[i].name);for(int j=n-1;j>=n/2;j--){if(stu[i].sex!=stu[j].sex&&vis[j]==0){vis[j]=1;printf("%s\n",stu[j].name);break;}}}return 0;
}

L1-031. 到底是不是太胖了

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

据说一个人的标准体重应该是其身高(单位:厘米)减去100、再乘以0.9所得到的公斤数。真实体重与标准体重误差在10%以内都是完美身材(即 |真实体重-标准体重| < 标准体重x10%)。已知市斤是公斤的两倍。现给定一群人的身高和实际体重,请你告诉他们是否太胖或太瘦了。

输入格式:

输入第一行给出一个正整数N(<= 20)。随后N行,每行给出两个整数,分别是一个人的身高H(120 < H < 200;单位:厘米)和真实体重W(50 < W <= 300;单位:市斤),其间以空格分隔。

输出格式:

为每个人输出一行结论:如果是完美身材,输出“You are wan mei!”;如果太胖了,输出“You are tai pang le!”;否则输出“You are tai shou le!”。

输入样例:

3
169 136
150 81
178 155

输出样例:

You are wan mei!
You are tai shou le!
You are tai pang le!

有时候我真的想拍死出题人,当然不敢,但是这题真的坑点太多了吧,上边一道题种标准体重是double型,这题用double型是完全不可行的,然后看了题解说标准体重要是一个int型,虽然我一直知道浮点型的精度问题会导致结果的误差,但是这题要不要考虑广大读者,给个说明呢,还有一个就是我不明白using namespace std;的用意在哪,不加就是编译错误,实在不解啊啊啊,,,,

#include<cstdio>
#include<cmath>
using namespace std;
int n,h,w,pw;
int main()
{scanf("%d",&n);while(n--){scanf("%d%d",&h,&w);pw=(h-100)*1.8;if(abs(w-pw)<(pw*0.1))printf("You are wan mei!\n");if(abs(w-pw)>=(pw*0.1)&&w<pw)printf("You are tai shou le!\n");if(abs(w-pw)>=(pw*0.1)&&w>pw)printf("You are tai pang le!\n");}return 0;
}

L1-032. Left-pad

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
陈越

根据新浪微博上的消息,有一位开发者不满NPM(Node Package Manager)的做法,收回了自己的开源代码,其中包括一个叫left-pad的模块,就是这个模块把javascript里面的React/Babel干瘫痪了。这是个什么样的模块?就是在字符串前填充一些东西到一定的长度。例如用“*”去填充字符串“GPLT”,使之长度为10,调用left-pad的结果就应该是“******GPLT”。Node社区曾经对left-pad紧急发布了一个替代,被严重吐槽。下面就请你来实现一下这个模块。

输入格式:

输入在第一行给出一个正整数N(<=104)和一个字符,分别是填充结果字符串的长度和用于填充的字符,中间以1个空格分开。第二行给出原始的非空字符串,以回车结束。

输出格式:

在一行中输出结果字符串。

输入样例1:

15 _
I love GPLT

输出样例1:

____I love GPLT

输入样例2:

4 *
this is a sample for cut

输出样例2:

 cut
#include<cstdio>
#include<cstring>
char s[40000];
int main()
{int n,i;char c;while(scanf("%d %c",&n,&c)!=EOF){getchar();gets(s);int len=strlen(s),ca;if(len<=n){ca=n-len;for(i=0;i<ca;i++)printf("%c",c);for(i=0;i<len;i++)printf("%c",s[i]);printf("\n");}if(len>n){ca=len-n;for(i=ca;i<len;i++)printf("%c",s[i]); printf("\n");}}return 0;
}

团体程序设计天梯赛-练习集相关推荐

  1. 【CCCC】PAT : 团体程序设计天梯赛-练习集 L3 答案(01-23)

    [CCCC]PAT : 团体程序设计天梯赛-练习集 L3 答案 顶着满课,整整一星期,终于咕完了.(:´д`)ゞ 知识点分类(23): 1.搜索模拟(5):BFS,DFS,最短路,路径打印 2.计算几 ...

  2. 【CCCC】PAT : 团体程序设计天梯赛-练习集 L2 答案,题解,附代码

    [CCCC]PAT : 团体程序设计天梯赛-练习集 L2 答案 鉴定完毕,全部水题 ヾ(•ω•`)o 知识点分类(32): 1.树锯结构(9):二叉树的存储,编号,遍历顺序转换,求深度,底层节点,从底 ...

  3. PTA团体程序设计天梯赛-练习集(3)

    PTA团体程序设计天梯赛-练习集 L1-001 Hello World (5 分) 这道超级简单的题目没有任何输入. 你只需要在一行中输出著名短句"Hello World!"就可以 ...

  4. PTA团体程序设计天梯赛-练习集

    PTA团体程序设计天梯赛-练习集 L1-024 后天 L1-025 正整数A+B L1-026 I Love GPLT L1-027 出租 L1-029 是不是太胖了 L1-030 一帮一 L1-03 ...

  5. 【CCCC】PAT : 团体程序设计天梯赛-练习集 L1 答案

    [CCCC]PAT : 团体程序设计天梯赛-练习集 L1 答案 鉴定完毕,全部水题 ヾ(•ω•`)o 标号 标题 分数 通过数 提交数 通过率 L1-001 Hello World 5 46779 1 ...

  6. PTA团体程序设计天梯赛-练习集Level-1(参考代码C语言/Python版)

    本题目集截止到2022年天梯赛 受个人水平限制,<PTA团体程序设计天梯赛-练习集>中暂时只能把Level-1的题目做出来(也许有些Level-2的题可以写出来?)-我不是专门搞竞赛的,参 ...

  7. 团体程序设计天梯赛练习集题解整合

    网上介绍 团体程序设计天梯赛练习集 的文章已经很多了, 我的这篇文章是对练习集题解的整合,方便每一位备战 团体程序设计天梯赛 的同学使用. 一年一度的 团体程序设计天梯赛 即将开始,PTA的练习集是必 ...

  8. 团体程序设计天梯赛-练习集 L1-033——L1-048

    团体程序设计天梯赛-练习集 /** @Description: 出生年* @version: * @Author: * @Date: 2021-03-25 08:13:57* @LastEditors ...

  9. 团体程序设计天梯赛-练习集——L3-020 至多删三个字符

    给定一个全部由小写英文字母组成的字符串,允许你至多删掉其中 3 个字符,结果可能有多少种不同的字符串? 输入格式: 输入在一行中给出全部由小写英文字母组成的.长度在区间 [4, 106] 内的字符串. ...

  10. PAT : 团体程序设计天梯赛-练习集 L3 答案即比赛技巧

    知识点分类(23): 1.搜索模拟(5):BFS,DFS,最短路,路径打印 2.计算几何(5):找规律,斜率计算,极角排序,三角形面积,三点共线,凸包 3.数据结构(5):栈,并查集,二叉树,堆,线段 ...

最新文章

  1. GOF23设计模式(创建型模式) 原型模式
  2. 原码一位乘法器设计_对原码、反码和补码的加深理解
  3. html5 文件转byte[],JS 文件base64、File、Blob、ArrayBuffer互转
  4. mysqldump命令
  5. sqlserver2008r2安装
  6. uva10891Game of sum
  7. Java之多线程里面的锁理解以及synchronized与Lock的区别
  8. Android 使用SeekBar调节系统音量
  9. java二维数组两个框代表什么_在java语言中,二维数组的两个中括号[][]分别表示()和()。...
  10. Laravel框架性能优化
  11. 为什么不断做迁移,那是在还技术债
  12. 上新了! 热门开源 AutoML 工具 NNI 2.0 来袭!
  13. 60佳优秀的国外电子商务网站设计案例(上篇)
  14. access 分表存储_数据库分区、分表、分库、分片
  15. Oracle官网下载JDK
  16. 遭遇 kapjazy.dll,yhpri.dll,WinSys64.Sys,nwiztlbu.exe,myplayer.com 等1
  17. 功率因数校正的离线式开关电源设计
  18. 微信小程序开发之——婚礼邀请函-项目展示(4.1)
  19. Excel之VBA编程常用语句300句
  20. 忆享聚焦|全球云计算市场份额、数字虚拟人、“元宇宙”实体店……近期行业热点速览

热门文章

  1. NAO机器人——总结
  2. java计算机毕业设计合同管理MyBatis+系统+LW文档+源码+调试部署
  3. 入门C语言排序n个数
  4. LeetCode第319周赛题解
  5. 腾讯Java后端开发实习生(一面)
  6. html css学习笔记~ 基础知识和页面显示的四个区域内容及display:flex 等常用的一些命令(手画)
  7. 计算机应用技术专业的大学生职业生涯规划书,计算机应用专业大学生职业生涯规划书范文...
  8. 计算机的清屏,计算机清屏键是什么
  9. python爬取拉勾网给定关键词职位信息存入数据库_Python 爬取拉勾网python职位信息...
  10. 街都VR:景区使用360全景制作的八个优势