PTA|团体程序设计天梯赛-练习题目题解锦集(C/C++)(持续更新中……)
PTA|团体程序设计天梯赛-练习题目题解锦集(持续更新中)实现语言:C/C++; 欢迎各位看官交流讨论、指导题解错误;或者分享更快的方法!!题目链接:https://pintia.cn/problem-sets/994805046380707840/problems目录(点击对应题目即可进入相应题解……小声BB……)L1-001 Hello World (5 分)...
PTA|团体程序设计天梯赛-练习题目题解锦集(持续更新中)
实现语言:C/C++; 欢迎各位看官交流讨论、指导题解错误;或者分享更快的方法!!
题目链接:https://pintia.cn/problem-sets/994805046380707840/problems
目录
(点击对应题目即可进入相应题解……小声BB……)
L1-001 Hello World (5 分)
这道超级简单的题目没有任何输入。
你只需要在一行中输出著名短句“Hello World!”就可以了。
输入样例:
无
输出样例:
Hello World!
题目代码:
#include<stdio.h>
int main()
{
printf("Hello World!\n");
return 0;
}
L1-002 打印沙漏 (20 分)
本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印
*****
***
*
***
*****
所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。
给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。
输入格式:
输入在一行给出1个正整数N(≤1000)和一个符号,中间以空格分隔。
输出格式:
首先打印出由给定符号组成的最大的沙漏形状,最后在一行中输出剩下没用掉的符号数。
输入样例:
19 *
输出样例:
*****
***
*
***
*****
2
题目代码:
#include <stdio.h>
int main()
{
int n;
char c;
scanf("%d %c",&n,&c);
int sum=1;//沙漏需要的字符个数
int i=1;//层数
while(sum<=n)
{
sum+=2*(2*(i+1)-1);//2n-1是一层的个数,乘以2代表两层一共需要的
if(sum<=n)
i++;
}
int j,k;
for(j=0;j<i;j++)//打印上半部分
{
for(k=0;k<j;k++)
printf(" ");
for(k=0;k<2*(i-j)-1;k++)
{
printf("%c",c);
}//输出*
printf("\n");
}
for(j=2;j<=i;j++)
{
for(k=0;k<i-j;k++)
printf(" ");
for(k=0;k<2*j-1;k++)
{
printf("%c",c);
}
printf("\n");
}
printf("%d",n-(sum-2*(2*(i+1)-1)));
}
L1-003 个位数统计 (15 分)
给定一个 k 位整数 N=dk−110k−1+⋯+d1101+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<iostream>
#include<cstring>
#define MAXN 1001
using namespace std;
int main()
{
char s[MAXN];
int book[10]={0};
scanf("%s",s);
for(int i=0;i<strlen(s);i++)
book[s[i]-48]++;
for(int i=0;i<10;i++)
{
if(book[i]!=0)
cout << i << ":" << book[i] << endl;
}
return 0;
}
L1-004 计算摄氏温度 (5 分)
给定一个华氏温度F,本题要求编写程序,计算对应的摄氏温度C。计算公式:C=5×(F−32)/9。题目保证输入与输出均在整型范围内。
输入格式:
输入在一行中给出一个华氏温度。
输出格式:
在一行中按照格式“Celsius = C”输出对应的摄氏温度C的整数值。
输入样例:
150
输出样例:
Celsius = 65
题目代码:
#include<iostream>
using namespace std;
int main()
{
int n,c;
scanf("%d",&n);
c=5*(n-32)/9;
printf("Celsius = %d\n",c);
return 0;
}
L1-005 考试座位号 (15 分)
每个 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
题目代码:
//L1-005 考试座位号
#include<iostream>
#define MAXN 1001
using namespace std;
struct STU{
char s[15];
int shiji;
int kaoshi;
};
int main()
{
struct STU stu[MAXN]={0};
int N,M;
// int a[MAXN][MAXN]={0};
cin >> N;
for(int i=0;i<N;i++)
scanf("%s %d %d",stu[i].s,&stu[i].shiji,&stu[i].kaoshi);
int k;
scanf("%d",&M);
for(int i=0;i<M;i++)
{
scanf("%d",&k);
for(int j=0;j<N;j++)
if(k==stu[j].shiji)
{
cout << stu[j].s << " " << stu[j].kaoshi << endl;
break;
}
}
return 0;
}
L1-006 连续因子 (20 分)
一个正整数 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
题目代码 :
#include<iostream>
#include<cmath>
using namespace std;
typedef long long ll;
int main()
{
ll n;
cin>>n;
ll prd=0;//定义乘积
int start=0,len=0;//定义最终得到序列开始的因子,序列的长度
for(int i=2;i<=sqrt(n);i++)//i从2到根号n
{
prd=1;
for(int j=i;prd*j<=n;j++)//从j开始一直乘到N为止,每次乘积判定是否小于等于N,若超过N,则结束循环
{
prd*=j;//乘积迭代
if(n%prd==0&&j-i+1>len)//如果当前乘积为N的乘积因子且长度大于上一次
{//更新序列起始因子和长度
start=i;
len=j-i+1;
}
}
}
if(start==0)//若起始因子为0,说明N为质数,因为质数=1*本身,而循环最多能表示1*本身的根号
{
start=n;
len=1;
}
cout<<len<<'\n'<<start;
for(int i=start+1;i<start+len;i++)//输出,如果因子只有一个只输出一个
cout<<'*'<<i;
return 0;
}
L1-007 念数字 (10 分)
输入一个整数,输出每个数字对应的拼音。当整数为负数时,先输出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
题目代码:
//L1-007 念数字
#include<iostream>
#include<cmath>
#include<cstring>
using namespace std;
int main(){
char ch[10][5]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
char s[1001];
cin >> s;
int k=strlen(s);
if(s[0]=='-')
{
cout << "fu ";
for(int i=1;i<k;i++)
{
if(i!=k-1)
cout << ch[s[i]-48] << " ";
}
}
else
{
for(int i=0;i<k;i++)
if(i!=k-1)
cout << ch[s[i]-48] << " ";
}
cout << ch[s[k-1]-48];
// cout << endl;
return 0;
}
L1-008 求整数段和 (10 分)
给定两个整数A和B,输出从A到B的所有整数以及这些数的和。
输入格式:
输入在一行中给出2个整数A和B,其中−100≤A≤B≤100,其间以空格分隔。
输出格式:
首先顺序输出从A到B的所有整数,每5个数字占一行,每个数字占5个字符宽度,向右对齐。最后在一行中按Sum = X
的格式输出全部数字的和X
。
输入样例:
-3 8
输出样例:
-3 -2 -1 0 1
2 3 4 5 6
7 8
Sum = 30
题目代码 :
//L1-008 求整数段和
#include<iostream>
using namespace std;
int main()
{
int a,b,sum=0,count=0;
scanf("%d%d",&a,&b);
for(int i=a;i<=b;i++)
{
printf("%5d",i);
sum+=i;
count++;
if(count%5==0)
printf("\n");
}
if((b-a+1)%5==0)
printf("Sum = %d\n",sum);
else
printf("\nSum = %d\n",sum);
return 0;
}
L1-009 N个数求和 (20 分)
本题的要求很简单,就是求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>
#include<cstring>
#include<cmath>
#include<algorithm>
#define LL long long
using namespace std;
LL gcd(LL a,LL b)///求最大公约数
{
return a%b==0?b:gcd(b,a%b);
}
int main()
{
LL t,a[101],b[101],s1=0,s2=0;
scanf("%lld",&t);
for(int i=0; i<t; i++)
scanf("%lld/%lld",&a[i],&b[i]);
s2=b[0];
for(int i=1; i<t; i++)
s2=s2/gcd(s2,b[i])*b[i];///求出所有分数的公分母
for(int i=0; i<t; i++)
s1+=s2/b[i]*a[i];///求分子总和
LL n=s1/s2,m=abs(s1%s2);
if(m==0) printf("%lld\n",n);
else
{
if(n!=0)printf("%lld ",n);
if(s1<0&&n==0)printf("-");
printf("%lld/%lld\n",m/gcd(s2,m),s2/gcd(s2,m));
}
return 0;
}
L1-010 比较大小 (10 分)
本题要求将输入的任意3个整数从小到大输出。
输入格式:
输入在一行中给出3个整数,其间以空格分隔。
输出格式:
在一行中将3个整数从小到大输出,其间以“->”相连。
输入样例:
4 2 8
输出样例:
2->4->8
题目代码:
//L1-010 比较大小
#include<iostream>
using namespace std;
int main()
{
int a,b,c,t;
cin >> a >> b >> c;
if(a>b)
{
t=a;
a=b;
b=t;
}
if(a>c)
{
t=a;
a=c;
c=t;
}
if(b>c)
{
t=b;
b=c;
c=t;
}
cout << a << "->" << b << "->" << c << endl;
return 0;
}
L1-011 A-B (20 分)
本题要求你计算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 <iostream>
#include<string>
using namespace std;
int book[256];
int main() {
string s, a;
getline(cin, s);
getline(cin, a);
for(int i = 0; i < a.length(); i++) {
book[a[i]] = 1;
}
for(int i = 0; i < s.length(); i++) {
if(book[s[i]] == 1) {
continue;
}
cout << s[i];
}
return 0;
}
L1-012 计算指数 (5 分)
真的没骗你,这道才是简单题 —— 对任意给定的不超过 10 的正整数 n,要求你输出 2n。不难吧?
输入格式:
输入在一行中给出一个不超过 10 的正整数 n。
输出格式:
在一行中按照格式 2^n = 计算结果
输出 2n 的值。
输入样例:
5
输出样例:
2^5 = 32
题目代码:
//L1-012 计算指数
#include<iostream>
#include<cmath>
using namespace std;
typedef long long LL;
int main()
{
LL n;
cin >> n;
cout << "2^" << n << " = " << pow(2,n);
return 0;
}
L1-013 计算阶乘和 (10 分)
对于给定的正整数N,需要你计算 S=1!+2!+3!+...+N!。
输入格式:
输入在一行中给出一个不超过10的正整数N。
输出格式:
在一行中输出S的值。
输入样例:
3
输出样例:
9
题目代码:
//L1-013 计算阶乘和
#include<iostream>
using namespace std;
int main()
{
int n;
cin >> n;
if(n==1) cout << "1\n";
else if(n==2) cout << "3\n";
else if(n==3) cout << "9\n";
else if(n==4) cout << "33\n";
else if(n==5) cout << "153\n";
else if(n==6) cout << "873\n";
else if(n==7) cout << "5913\n";
else if(n==8) cout << "46233\n";
else if(n==9) cout << "409113\n";
else cout << "4037913\n";
return 0;
}
L1-014 简单题 (5 分)
这次真的没骗你 —— 这道超级简单的题目没有任何输入。
你只需要在一行中输出事实:This is a simple problem.
就可以了。
输入样例:
无
输出样例:
This is a simple problem.
题目代码:
#include<iostream>
using namespace std;
int main()
{
cout << "This is a simple problem.\n";
return 0;
}
L1-015 跟奥巴马一起画方块 (15 分)
美国总统奥巴马不仅呼吁所有人都学习编程,甚至以身作则编写代码,成为美国历史上首位编写计算机代码的总统。2014年底,为庆祝“计算机科学教育周”正式启动,奥巴马编写了很简单的计算机代码:在屏幕上画一个正方形。现在你也跟他一起画吧!
输入格式:
输入在一行中给出正方形边长N(3≤N≤21)和组成正方形边的某种字符C
,间隔一个空格。
输出格式:
输出由给定字符C
画出的正方形。但是注意到行间距比列间距大,所以为了让结果看上去更像正方形,我们输出的行数实际上是列数的50%(四舍五入取整)。
输入样例:
10 a
输出样例:
aaaaaaaaaa
aaaaaaaaaa
aaaaaaaaaa
aaaaaaaaaa
aaaaaaaaaa
题目代码:
//L1-015 跟奥巴马一起画方块
#include<iostream>
using namespace std;
int main()
{
int a,b;
char c;
cin >> a;
getchar();
cin >> c;
if(a%2!=0)
b=a/2+1;
else
b=a/2;
for(int i=1;i<=b;i++)
{
for(int j=1;j<=a;j++)
cout << c;
cout <<"\n";
}
return 0;
}
L1-016 查验身份证 (15 分)
一个合法的身份证号码由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
题目代码:
//L1-016 查验身份证
#include<iostream>
using namespace std;
int quan[]={7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};
char jiao[]={'1','0','X','9','8','7','6','5','4','3','2'};
char id[20];
bool jiaoyan()
{
int sum=0,flag=1;
for(int i=0;i<17;i++)
{
if(id[i]>='0'&&id[i]<='9')
{
sum+=(id[i]-48)*quan[i];
// cout << "id[" <<i << "]\t" << id[i] << endl;
// cout << "quan[" << i << "]\t" << quan[i] << endl;
}
else
{
flag=0;
break;
}
}
// cout << sum << endl;
if(flag)
{
sum%=11;
if(id[17]==jiao[sum])
return true;
else
return false;
}
else
return false;
}
int main()
{
int n,ans=0,k;
cin >> n;
k=n;
while(k--)
{
cin >> id;
if(jiaoyan())
ans++;
else
cout << id << endl;
}
if(ans==n)
cout << "All passed\n";
return 0;
}
L1-017 到底有多二 (15 分)
一个整数“犯二的程度”定义为该数字中包含2的个数与其位数的比值。如果这个数是负数,则程度增加0.5倍;如果还是个偶数,则再增加1倍。例如数字-13142223336
是个11位数,其中有3个2,并且是负数,也是偶数,则它的犯二程度计算为:3/11×1.5×2×100%,约为81.82%。本题就请你计算一个给定整数到底有多二。
输入格式:
输入第一行给出一个不超过50位的整数N
。
输出格式:
在一行中输出N
犯二的程度,保留小数点后两位。
输入样例:
-13142223336
输出样例:
81.82%
题目代码:
//L1-017 到底有多二
#include<iostream>
#include<cstring>
#define MAXN 51
using namespace std;
int main()
{
char num[MAXN];
int len,ans=0;
float sum=1.0;
cin >> num;
for(int i=0;i<strlen(num);i++)
{
if(num[i]=='2')
ans++;
}
if(num[0]=='-')
{
sum*=1.5;
len=strlen(num)-1;
if(num[len]%2==0)
sum*=2.0;
}
else
{
len=strlen(num);
if(num[len-1]%2==0)
sum*=2.0;
}
sum=sum*ans/(float)len;
sum*=100000; //五位数
int k=int(sum);
int ge,shi,bai,qian,wan;
ge=k%10;
shi=(k%100-ge)/10;
wan=k/10000;
qian=k/1000-wan*10;
bai=k/100-qian*10-wan*100;
if(ge>4)
shi++;
if(wan!=0)
cout << wan << qian << "." << bai << shi << "%\n";
else
cout << qian << "." << bai << shi << "%\n";
return 0;
}
L1-018 大笨钟 (10 分)
微博上有个自称“大笨钟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.
题目代码:
//L1-018 大笨钟
#include<iostream>
using namespace std;
int main()
{
char c[5];
int dang=0;
cin >> c;
if(c[0]=='0')
cout << "Only "<< c <<". Too early to Dang.";
else if(c[0]=='1'&&(c[0]-48+c[1]-48)<3)
cout << "Only "<< c <<". Too early to Dang.";
else if(c[0]=='1'&&c[1]=='2')
{
if(c[3]>'0'||c[4]>'0')
cout << "Dang";
else
cout << "Only "<< c <<". Too early to Dang.";
}
else if(c[0]=='1'&&(c[0]-48+c[1]-48)>3)
{
if(c[3]>'0'||c[4]>'0')
dang++;
dang+=c[1]-50;
for(int i=0;i<dang;i++)
cout << "Dang";
}
else if(c[0]=='2')
{
if(c[3]>'0'||c[4]>'0')
dang++;
dang+=(c[1]-40);
for(int i=0;i<dang;i++)
cout << "Dang";
}
cout << endl;
return 0;
}
L1-019 谁先倒 (15 分)
划拳是古老中国酒文化的一个有趣的组成部分。酒桌上两人划拳的方法为:每人口中喊出一个数字,同时用手比划出一个数字。如果谁比划出的数字正好等于两人喊出的数字之和,谁就输了,输家罚一杯酒。两人同赢或两人同输则继续下一轮,直到唯一的赢家出现。
下面给出甲、乙两人的酒量(最多能喝多少杯不倒)和划拳记录,请你判断两个人谁先倒。
输入格式:
输入第一行先后给出甲、乙两人的酒量(不超过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
题目代码:
//L1-019 谁先倒
#include<iostream>
using namespace std;
int main()
{
int A,B,asum,bsum,n;
cin >> A >> B;
asum=0;bsum=0;
cin >> n;
while(n--)
{
int anum,ahua,bnum,bhua;
int sum;
cin >> anum >> ahua >> bnum >> bhua;
sum=anum+bnum;
//A win && B lose
if(sum==ahua&&sum!=bhua)
asum++;
//B win && A lose
if(sum==bhua&&sum!=ahua)
bsum++;
//A lose
if(asum>A)
{
cout << "A\n" << bsum << endl;
break;
}
if(bsum>B)
{
cout << "B\n" << asum << endl;
break;
}
}
return 0;
}
L1-020 帅到没朋友 (20 分)
当芸芸众生忙着在朋友圈中发照片的时候,总有一些人因为太帅而没有朋友。本题就要求你找出那些帅到没有朋友的人。
输入格式:
输入第一行给出一个正整数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
题目代码:
//L1-020 帅到没朋友
#include<iostream>
using namespace std;
int main()
{
int n,m,k,flag,data;
int id[100002]={0};
int cool[100002]={0};
int top=1,ctop=1;
cin >> n;
for(int i=0;i<n;i++)
{
cin >> m;
if(m==1)
{
cin >> data;
cool[ctop++]=data;
}
else
{
while(m--)
{
flag=1;
cin >> data;
id[top++]=data;
}
}
}
cin >> k;
while(k--)
{
flag=1;
cin >> data;
for(int i=1;i<=top;i++)
if(id[i]==data)
{
flag=0;
break;
}
for(int i=1;i<=ctop;i++)
if(cool[i]==data)
{
flag=0;
break;
}
if(flag)
cool[ctop++]=data;
}
if(ctop==1)
cout << "No one is handsome\n";
else
{
for(int i=1;i<ctop-1;i++)
printf("%05d ",id[i]);
printf("%05d\n",id[ctop-1]);
}
return 0;
}
L1-021 重要的话说三遍 (5 分)
这道超级简单的题目没有任何输入。
你只需要把这句很重要的话 —— “I'm gonna WIN!”——连续输出三遍就可以了。
注意每遍占一行,除了每行的回车不能有任何多余字符。
输入样例:
无
输出样例:
I'm gonna WIN!
I'm gonna WIN!
I'm gonna WIN!
题目代码:
#include<iostream>
using namespace std;
int main()
{
for(int i=0;i<3;i++)
cout <<"I'm gonna WIN!\n";
return 0;
}
L1-022 奇偶分家 (10 分)
给定N
个正整数,请统计奇数和偶数各有多少个?
输入格式:
输入第一行给出一个正整N
(≤1000);第2行给出N
个正整数,以空格分隔。
输出格式:
在一行中先后输出奇数的个数、偶数的个数。中间以1个空格分隔。
输入样例:
9
88 74 101 26 15 0 34 22 77
输出样例:
3 6
题目代码:
//L1-022 奇偶分家
#include<iostream>
using namespace std;
int main()
{
int n,m;
int ji=0,ou=0;
cin >> n;
while(n--)
{
cin >> m;
if(m%2==0)
ou++;
else
ji++;
}
cout << ji << " " << ou << endl;
return 0;
}
L1-023 输出GPLT (20 分)
给定一个长度不超过10000的、仅由英文字母构成的字符串。请将字符重新调整顺序,按GPLTGPLT....
这样的顺序输出,并忽略其它字符。当然,四种字符(不区分大小写)的个数不一定是一样多的,若某种字符已经输出完,则余下的字符仍按GPLT
的顺序打印,直到所有字符都被输出。
输入格式:
输入在一行中给出一个长度不超过10000的、仅由英文字母构成的非空字符串。
输出格式:
在一行中按题目要求输出排序后的字符串。题目保证输出非空。
输入样例:
pcTclnGloRgLrtLhgljkLhGFauPewSKgt
输出样例:
GPLTGPLTGLTGLGLL
题目代码:
//L1-023 输出GPLT
#include<iostream>
#include<cstring>
#include<algorithm>
#define MAXN 10001
using namespace std;
int main()
{
char str[MAXN];
int book[4]={0};
//G P L T
cin >> str;
for(int i=0;i<strlen(str);i++)
{
if(str[i]=='G'||str[i]=='g')
book[0]++;
else if(str[i]=='P'||str[i]=='p')
book[1]++;
else if(str[i]=='L'||str[i]=='l')
book[2]++;
else if(str[i]=='T'||str[i]=='t')
book[3]++;
}
while(1)
{
if(book[0]>0)
{
cout << "G";
book[0]--;
}
if(book[1]>0)
{
cout << "P";
book[1]--;
}
if(book[2]>0)
{
cout << "L";
book[2]--;
}
if(book[3]>0)
{
cout << "T";
book[3]--;
}
if(book[0]==0&&book[1]==0&&book[2]==0&&book[3]==0)
break;
}
return 0;
}
L1-024 后天 (5 分)
如果今天是星期三,后天就是星期五;如果今天是星期六,后天就是星期一。我们用数字1到7对应星期一到星期日。给定某一天,请你输出那天的“后天”是星期几。
输入格式:
输入第一行给出一个正整数D
(1 ≤ D
≤ 7),代表星期里的某一天。
输出格式:
在一行中输出D
天的后天是星期几。
输入样例:
3
输出样例:
5
题目代码:
//L1-024 后天
#include<iostream>
using namespace std;
int main()
{
int n;
cin >> n;
if(n==1) cout << "3\n";
else if(n==2) cout << "4\n";
else if(n==3) cout << "5\n";
else if(n==4) cout << "6\n";
else if(n==5) cout << "7\n";
else if(n==6) cout << "1\n";
else cout << "2\n";
return 0;
}
L1-025 正整数A+B (15 分)
题的目标很简单,就是求两个正整数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:
? + ? = ?
题目代码:
//L1-025 正整数A+B
#include<iostream>
#include<cstring>
#include<cmath>
#define MAXN 1001
using namespace std;
int main()
{
char A[MAXN],B[MAXN];
int lena,lenb,flaga=1,flagb=1;
cin >> A;
//B字符串 第0个字符是空格 所以从第一个位置开始判断
scanf("%[^\n]",B);
lena=strlen(A);lenb=strlen(B);
// cout << lena <<" " << lenb << endl;
if(lena>=4&&lenb-1<=4)
flaga=0;
if(lena<=4&&lenb-1>=4)
flagb=0;
if(lena>=4&&lenb-1>=4)
{
flaga=0;
flagb=0;
}
if(A[0]=='0')
flaga=0;
if(B[1]=='0')
flagb=0;
// cout << flaga << " " <<flagb <<endl;
for(int i=1;i<lena;i++)
{
if(A[i]<'0'||A[i]>'9')
{
flaga=0;
break;
}
}
for(int i=2;i<lenb;i++)
{
if(B[i]<'0'||B[i]>'9')
{
flagb=0;
break;
}
}
if(lena==4)
if(A[0]=='1'&&A[1]=='0'&&A[2]=='0'&&A[3]=='0')
flaga=1;
if(lenb-1==4)
if(B[1]=='1'&&B[2]=='0'&&B[3]=='0'&&B[4]=='0')
flagb=1;
// cout << flaga << " " <<flagb <<endl;
if(flaga&&flagb)
{
int suma=0,sumb=0;
int j=lena;
for(int i=0;i<lena;i++)
{
j--;
suma+=pow(10,j)*(A[i]-48);
}
j=lenb-1;
for(int i=1;i<lenb;i++)
{
j--;
sumb+=pow(10,j)*(B[i]-48);
}
cout << A << " +" << B << " = " << suma+sumb << endl;
}
if(!flaga&&!flagb)
cout << "? + ? = ?\n";
if(flaga&&!flagb)
cout << A << " + ? = ?\n";
if(!flaga&&flagb)
cout << "? +" << B << " = ?\n";
return 0;
}
L1-026 I Love GPLT (5 分)
这道超级简单的题目没有任何输入。
你只需要把这句很重要的话 —— “I Love GPLT”——竖着输出就可以了。
所谓“竖着输出”,是指每个字符占一行(包括空格),即每行只能有1个字符和回车。
输入样例:
无
输出样例:
I
L
o
v
e
G
P
L
T
题目代码:
#include <iostream>
using namespace std;
int main() {
printf("I\n \nL\no\nv\ne\n \nG\nP\nL\nT\n");
return 0;
}
L1-027 出租 (20 分)
下面是新浪微博上曾经很火的一张图:
一时间网上一片求救声,急问这个怎么破。其实这段代码很简单,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};
题目代码:
//L1-027 出租
#include<iostream>
#include<cstring>
#define MAXN 11
using namespace std;
char id[MAXN];
int nnew[MAXN],book[MAXN],dex[MAXN];
int main()
{
int num=0;
cin >>id;
for(int i=0;i<MAXN;i++)
{
book[id[i]-48]++;
}
for(int i=MAXN-1;i>=0;i--)
{
if(book[i]>0)
{
nnew[num]=i;
num++;
}
}
//cout << num << endl;
cout << "int[] arr = new int[]{";
for(int i=0;i<num;i++)
if(i!=num-1)
cout << nnew[i] << ",";
cout << nnew[num-1] << "};\n";
for(int i=0;i<MAXN;i++)
{
for(int j=0;j<num;j++)
{
if(id[i]-48==nnew[j])
{
dex[i]=j;
break;
}
}
}
cout << "int[] index = new int[]{";
for(int i=0;i<MAXN;i++)
if(i!=MAXN-1)
cout << dex[i] << ",";
cout << dex[MAXN-1] << "};\n";
//cout << id <<endl;
return 0;
}
L1-028 判断素数 (10 分)
本题的目标很简单,就是判断一个给定的正整数是否素数。
输入格式:
输入在第一行给出一个正整数N
(≤ 10),随后N
行,每行给出一个小于231的需要判断的正整数。
输出格式:
对每个需要判断的正整数,如果它是素数,则在一行中输出Yes
,否则输出No
。
输入样例:
2
11
111
输出样例:
Yes
No
题目代码:
#include"iostream"
#include"cmath"
using namespace std;
bool isprime(long long int n){
if(n==1){//注意n==1的情况
return false;
}
for(int i=2;i < sqrt(n);i++){//写成i*i< sqrt(n)这种形式好了
if(n%i==0){
return false;
}
}
return true;
}
int main(){
int n;
cin>>n;
long long int temp;
for(int i=0;i < n;i++){
cin>>temp;
if(isprime(temp)){
cout<<"Yes"<<endl;
}else{
cout<<"No"<<endl;
}
}
}
L1-029 是不是太胖了 (5 分)
据说一个人的标准体重应该是其身高(单位:厘米)减去100、再乘以0.9所得到的公斤数。已知市斤是公斤的两倍。现给定某人身高,请你计算其标准体重应该是多少?(顺便也悄悄给自己算一下吧……)
输入格式:
输入第一行给出一个正整数H
(100 < H
≤ 300),为某人身高。
输出格式:
在一行中输出对应的标准体重,单位为市斤,保留小数点后1位。
输入样例:
169
输出样例:
124.2
题目代码:
//L1-029 是不是太胖了
#include<iostream>
using namespace std;
int main()
{
float h;
cin >> h;
printf("%.1f\n",(h-100)*0.9*2);
return 0;
}
L1-030 一帮一 (15 分)
“一帮一学习小组”是中小学中常见的学习组织方式,老师把学习成绩靠前的学生跟学习成绩靠后的学生排在一组。本题就请你编写程序帮助老师自动完成这个分配工作,即在得到全班学生的排名后,在当前尚未分组的学生中,将名次最靠前的学生与名次最靠后的异性学生分为一组。
输入格式:
输入第一行给出正偶数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
题目代码:
//L1-030 一帮一
#include<iostream>
using namespace std;
struct STU{
int data;
char name[10];
};
int main()
{
int n,s,i;
struct STU boy[26],girl[26];
//队列初始化
int btop=1,gtop=1;
int bdi=1,gdi=1;
cin >> n;
for(i=1;i<=n;i++)
{
cin >> s;
getchar();
if(s==1)
{
cin >> boy[btop].name;
boy[btop].data=i;
btop++;
}
if(s==0)
{
cin >> girl[gtop].name;
girl[gtop].data=i;
gtop++;
}
}
for(int i=1;i<=n/2;i++)
{
if(boy[bdi].data==i)
{
cout << boy[bdi].name << " " << girl[--gtop].name <<endl;
bdi++;
continue;
}
if(girl[gdi].data==i)
{
cout << girl[gdi].name << " " << boy[--btop].name << endl;
gdi++;
continue;
}
}
return 0;
}
L1-031 到底是不是太胖了 (10 分)
据说一个人的标准体重应该是其身高(单位:厘米)减去100、再乘以0.9所得到的公斤数。真实体重与标准体重误差在10%以内都是完美身材(即 | 真实体重 − 标准体重 | < 标准体重×10%)。已知市斤是公斤的两倍。现给定一群人的身高和实际体重,请你告诉他们是否太胖或太瘦了。
输入格式:
输入第一行给出一个正整数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!
题目代码:
//L1-031 到底是不是太胖了
#include<stdio.h>
#include<math.h>
#include<stdlib.h>
int main(void)
{
int n,h,w;
float min,max;
scanf("%d",&n);
while(n--){
scanf("%d%d",&h,&w);
min=(h-100)*0.9*2*0.9;
max=(h-100)*0.9*2*1.1;
if(w>min&&w<max)
printf("You are wan mei!\n");
else if(w<=min)
printf("You are tai shou le!\n");
else
printf("You are tai pang le!\n");
}
return 0;
}
L1-032 Left-pad (20 分)
根据新浪微博上的消息,有一位开发者不满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
题目代码:
//L1-032 Left-pad
#include<iostream>
#include<string>
#include<cstdlib>
using namespace std;
int main()
{
int n;
char c;
string s;
cin >> n;
getchar();
cin >> c;
getchar();
getline(cin,s);
int len=s.length();
// cout << len;
// system("pause");
if(n>len)
{
for(int i=1;i<=n-len;i++)
printf("%c",c);
cout << s << endl;
}
else if(n==len)
cout << s << endl;
else if(n<len)
{
for(int i=len-n;i<=len-1;i++)
cout << s.at(i);
cout << endl;
}
return 0;
}
L1-033 出生年 (15 分)
以上是新浪微博中一奇葩贴:“我出生于1988年,直到25岁才遇到4个数字都不相同的年份。”也就是说,直到2013年才达到“4个数字都不相同”的要求。本题请你根据要求,自动填充“我出生于y
年,直到x
岁才遇到n
个数字都不相同的年份”这句话。
输入格式:
输入在一行中给出出生年份y
和目标年份中不同数字的个数n
,其中y
在[1, 3000]之间,n
可以是2、或3、或4。注意不足4位的年份要在前面补零,例如公元1年被认为是0001年,有2个不同的数字0和1。
输出格式:
根据输入,输出x
和能达到要求的年份。数字间以1个空格分隔,行首尾不得有多余空格。年份要按4位输出。注意:所谓“n
个数字都不相同”是指不同的数字正好是n
个。如“2013”被视为满足“4位数字都不同”的条件,但不被视为满足2位或3位数字不同的条件。
输入样例1:
1988 4
输出样例1:
25 2013
输入样例2:
1 2
输出样例2:
0 0001
题目代码:
//L1-033 出生年
#include<iostream>
#include<string>
using namespace std;
int main()
{
int n,ans=0;
string y;
cin >> y >> n;
if(y.size()==1)
y.insert(0,3,'0');
else if(y.size()==2)
y.insert(0,2,'0');
else if(y.size()==3)
y.insert(0,1,'0');
while(1)
{
int book[10]={0};
int sum=0;
for(int i=0;i<4;i++)
book[y.at(i)-48]++;
for(int i=0;i<10;i++)
{
if(book[i]>0)
sum++;
}
ans++;
if(sum==n)
break;
y.at(3)++;
if(y.at(3)>57)
{
y.at(3)='0';
y.at(2)++;
if(y.at(2)>57)
{
y.at(2)='0';
y.at(1)++;
if(y.at(1)>57)
{
y.at(1)='0';
y.at(0)++;
}
}
}
//cout << y << endl;
}
cout << ans-1 << " " << y<< endl;
return 0;
}
L1-034 点赞 (20 分)
微博上有个“点赞”功能,你可以为你喜欢的博文点个赞表示支持。每篇博文都有一些刻画其特性的标签,而你点赞的博文的类型,也间接刻画了你的特性。本题就要求你写个程序,通过统计一个人点赞的纪录,分析这个人的特性。
输入格式:
输入在第一行给出一个正整数N(≤1000),是该用户点赞的博文数量。随后N行,每行给出一篇被其点赞的博文的特性描述,格式为“K F1⋯FK”,其中1≤K≤10,Fi(i=1,⋯,K)是特性标签的编号,我们将所有特性标签从1到1000编号。数字间以空格分隔。
输出格式:
统计所有被点赞的博文中最常出现的那个特性标签,在一行中输出它的编号和出现次数,数字间隔1个空格。如果有并列,则输出编号最大的那个。
输入样例:
4
3 889 233 2
5 100 3 233 2 73
4 3 73 889 2
2 233 123
输出样例:
233 3
题目代码:
//L1-034 点赞 (20 分)
#include<iostream>
#include<algorithm>
#define MAXN 1005
using namespace std;
struct stack{
int id;
int time;
};
bool cmp(stack a,stack b)
{
if(a.time!=b.time) return a.time>b.time;
else if(a.id!=b.id) return a.id>b.id;
}
int main()
{
stack s[MAXN];
for(int i=0;i<MAXN;i++)
s[i].time=0;
int N,top=0;
cin >> N;
while(N--)
{
int k,m;
cin >> k;
while(k--)
{
int flag=0;
cin >> m;
for(int i=0;i<top;i++)
{
if(s[i].id==m)
{
s[i].time++;
flag=1;
break;
}
}
if(flag==0)
{
s[top].id=m;
s[top].time++;
top++;
}
}
}
sort(s,s+top,cmp);
cout << s[0].id << " " << s[0].time << endl;
return 0;
}
L1-035 情人节 (15 分)
以上是朋友圈中一奇葩贴:“2月14情人节了,我决定造福大家。第2个赞和第14个赞的,我介绍你俩认识…………咱三吃饭…你俩请…”。现给出此贴下点赞的朋友名单,请你找出那两位要请客的倒霉蛋。
输入格式:
输入按照点赞的先后顺序给出不知道多少个点赞的人名,每个人名占一行,为不超过10个英文字母的非空单词,以回车结束。一个英文句点.
标志输入的结束,这个符号不算在点赞名单里。
输出格式:
根据点赞情况在一行中输出结论:若存在第2个人A和第14个人B,则输出“A and B are inviting you to dinner...”;若只有A没有B,则输出“A is the only one for you...”;若连A都没有,则输出“Momo... No one is for you ...”。
输入样例1:
GaoXZh
Magi
Einst
Quark
LaoLao
FatMouse
ZhaShen
fantacy
latesum
SenSen
QuanQuan
whatever
whenever
Potaty
hahaha
.
输出样例1:
Magi and Potaty are inviting you to dinner...
输入样例2:
LaoLao
FatMouse
whoever
.
输出样例2:
FatMouse is the only one for you...
输入样例3:
LaoLao
.
输出样例3:
Momo... No one is for you ...
题目代码:
//L1-035 情人节
#include<iostream>
#include<string>
#include<vector>
using namespace std;
int main()
{
int i=1;
string str;
vector<string> vec;
while(1)
{
cin >> str;
if(str.size()==1&&str.at(0)=='.')
break;
if(i==2)
vec.push_back(str);
if(i==14)
vec.push_back(str);
i++;
str.clear();
}
if(vec.size()==2)
cout << vec.at(0) << " and " << vec.at(1) << " are inviting you to dinner...\n";
else if(vec.size()==1)
cout << vec.at(0) << " is the only one for you...\n";
else if(vec.size()==0)
cout << "Momo... No one is for you ...\n";
return 0;
}
L1-036 A乘以B (5 分)
看我没骗你吧 —— 这是一道你可以在 10 秒内完成的题:给定两个绝对值不超过 100 的整数 A 和 B,输出 A 乘以 B 的值。
输入格式:
输入在第一行给出两个整数 A 和 B(−100≤A,B≤100),数字间以空格分隔。
输出格式:
在一行中输出 A 乘以 B 的值。
输入样例:
-8 13
输出样例:
-104
题目代码:
#include<iostream>
using namespace std;
int main()
{
int a,b;
cin >> a >> b;
cout << a*b << endl;
return 0;
}
L1-037 A除以B (10 分)
真的是简单题哈 —— 给定两个绝对值不超过100的整数A和B,要求你按照“A/B=商”的格式输出结果。
输入格式:
输入在第一行给出两个整数A和B(−100≤A,B≤100),数字间以空格分隔。
输出格式:
在一行中输出结果:如果分母是正数,则输出“A/B=商”;如果分母是负数,则要用括号把分母括起来输出;如果分母为零,则输出的商应为Error
。输出的商应保留小数点后2位。
输入样例1:
-1 2
输出样例1:
-1/2=-0.50
输入样例2:
1 -3
输出样例2:
1/(-3)=-0.33
输入样例3:
5 0
输出样例3:
5/0=Error
题目代码:
#include<iostream>
using namespace std;
int main()
{
float a,b;
scanf("%f%f",&a,&b);
if(b==0)
cout << a << "/" << b << "=Error\n";
else if(b<0)
{
cout << a << "/(" <<b << ")=";
printf("%.2f\n",a/b);
}
else
printf("%.0f/%.0f=%.2f\n",a,b,a/b);
return 0;
}
L1-038 新世界 (5 分)
这道超级简单的题目没有任何输入。
你只需要在第一行中输出程序员钦定名言“Hello World”,并且在第二行中输出更新版的“Hello New World”就可以了。
输入样例:
无
输出样例:
Hello World
Hello New World
题目代码:
#include<iostream>
using namespace std;
int main()
{
cout << "Hello World\nHello New World\n";
return 0;
}
L1-039 古风排版 (20 分)
中国的古人写文字,是从右向左竖向排版的。本题就请你编写程序,把一段文字按古风排版。
输入格式:
输入在第一行给出一个正整数N(<100),是每一列的字符数。第二行给出一个长度不超过1000的非空字符串,以回车结束。
输出格式:
按古风格式排版给定的字符串,每列N个字符(除了最后一列可能不足N个)。
输入样例:
4
This is a test case
输出样例:
asa T
st ih
e tsi
ce s
题目代码:
//L1-039 古风排版
#include<iostream>
#include<string>
using namespace std;
int main()
{
int n,m,len;
char a[105][105];
string str;
cin >> n;
getchar();
getline(cin,str);
//对二维数组初始化
for(int i=0;i<105;i++)
for(int j=0;j<105;j++)
a[i][j]=' ';
len=str.size();
if(len%n==0)
m=len/n;
else
m=len/n+1;
//n行m列
for(int i=0;i<n;i++)
{
int k=0;
for(int j=i;j<len;j+=n)
{
a[i][k]=str.at(j);
k++;
}
}
for(int i=0;i<n;i++)
{
for(int j=m-1;j>=0;j--)
cout << a[i][j];
cout << endl;
}
return 0;
}
L1-040 最佳情侣身高差 (10 分)
专家通过多组情侣研究数据发现,最佳的情侣身高差遵循着一个公式:(女方的身高)×1.09 =(男方的身高)。如果符合,你俩的身高差不管是牵手、拥抱、接吻,都是最和谐的差度。
下面就请你写个程序,为任意一位用户计算他/她的情侣的最佳身高。
输入格式:
输入第一行给出正整数N(≤10),为前来查询的用户数。随后N行,每行按照“性别 身高”的格式给出前来查询的用户的性别和身高,其中“性别”为“F”表示女性、“M”表示男性;“身高”为区间 [1.0, 3.0] 之间的实数。
输出格式:
对每一个查询,在一行中为该用户计算出其情侣的最佳身高,保留小数点后2位。
输入样例:
2
M 1.75
F 1.8
输出样例:
1.61
1.96
题目代码:
//L1-040 最佳情侣身高差
#include<iostream>
#define biao 1.09
using namespace std;
int main()
{
int n;
cin >> n;
while(n--)
{
char c;
float gao;
cin >> c;
cin >> gao;
if(c=='M')
printf("%.2f\n",gao/biao);
else if(c=='F')
printf("%.2f\n",gao*biao);
}
return 0;
}
L1-041 寻找250 (10 分)
对方不想和你说话,并向你扔了一串数…… 而你必须从这一串数字中找到“250”这个高大上的感人数字。
输入格式:
输入在一行中给出不知道多少个绝对值不超过1000的整数,其中保证至少存在一个“250”。
输出格式:
在一行中输出第一次出现的“250”是对方扔过来的第几个数字(计数从1开始)。题目保证输出的数字在整型范围内。
输入样例:
888 666 123 -233 250 13 250 -222
输出样例:
5
题目代码:
//L1-041 寻找250
#include<iostream>
using namespace std;
int main()
{
int n;
int i=1,flag,j=1;
while(cin >> n)
{
if(n==250&&j==1)
{
flag=i;
j++;
}
i++;
}
cout << flag << endl;
return 0;
}
L1-042 日期格式化 (5 分)
世界上不同国家有不同的写日期的习惯。比如美国人习惯写成“月-日-年”,而中国人习惯写成“年-月-日”。下面请你写个程序,自动把读入的美国格式的日期改写成中国习惯的日期。
输入格式:
输入在一行中按照“mm-dd-yyyy”的格式给出月、日、年。题目保证给出的日期是1900年元旦至今合法的日期。
输出格式:
在一行中按照“yyyy-mm-dd”的格式给出年、月、日。
输入样例:
03-15-2017
输出样例:
2017-03-15
题目代码:
#include<iostream>
using namespace std;
int main()
{
char m1,m2,d1,d2,y1,y2,y3,y4;
scanf("%c%c-%c%c-%c%c%c%c",&m1,&m2,&d1,&d2,&y1,&y2,&y3,&y4);
getchar();
printf("%c%c%c%c-%c%c-%c%c\n",y1,y2,y3,y4,m1,m2,d1,d2);
return 0;
}
L1-043 阅览室 (20 分)
天梯图书阅览室请你编写一个简单的图书借阅统计程序。当读者借书时,管理员输入书号并按下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-043 阅览室
#include<iostream>
#define MAXN 1005
using namespace std;
int main()
{
int n;
cin >> n;
while(n--)
{
int a=1;
double sum=0;
int num=0,minute[MAXN]={0};
bool f[MAXN]={false};
while(a!=0)
{
char c;
int h,m;
scanf("%d %c %d:%d",&a,&c,&h,&m);
if(a==0)
break;
//借书
else if(c=='S')
{
minute[a]=h*60+m;
f[a]=true;
}
else if(c=='E')
{
//如果有借 继续处理
if(f[a])
{
sum+=h*60+m-minute[a];
f[a]=false;
num++; //次数加加
}
}
}
if(num==0)
cout << "0 0\n";
else
{
sum/=num;
int t = sum+0.5f; //四舍五入
cout << num << " " << t << endl;
}
}
return 0;
}
L1-044 稳赢 (15 分)
大家应该都会玩“锤子剪刀布”的游戏:两人同时给出手势,胜负规则如图所示:
现要求你编写一个稳赢不输的程序,根据对方的出招,给出对应的赢招。但是!为了不让对方输得太惨,你需要每隔K次就让一个平局。
输入格式:
输入首先在第一行给出正整数K(≤10),即平局间隔的次数。随后每行给出对方的一次出招:ChuiZi
代表“锤子”、JianDao
代表“剪刀”、Bu
代表“布”。End
代表输入结束,这一行不要作为出招处理。
输出格式:
对每一个输入的出招,按要求输出稳赢或平局的招式。每招占一行。
输入样例:
2
ChuiZi
JianDao
Bu
JianDao
Bu
ChuiZi
ChuiZi
End
输出样例:
Bu
ChuiZi
Bu
ChuiZi
JianDao
ChuiZi
Bu
题目代码:
//L1-044 稳赢
#include<iostream>
#include<string>
using namespace std;
int main()
{
int n,i=1;
string str;
cin >> n;
while(cin >> str)
{
if(str.at(0)=='E')
break;
//平局
if(i%(n+1)==0)
{
if(str.at(0)=='J')
cout << "JianDao\n";
else if(str.at(0)=='C')
cout << "ChuiZi\n";
else if(str.at(0)=='B')
cout << "Bu\n";
}
else
{
if(str.at(0)=='J')
cout << "ChuiZi\n";
else if(str.at(0)=='C')
cout << "Bu\n";
else if(str.at(0)=='B')
cout << "JianDao\n";
}
i++;
}
return 0;
}
L1-045 宇宙无敌大招呼 (5 分)
据说所有程序员学习的第一个程序都是在屏幕上输出一句“Hello World”,跟这个世界打个招呼。作为天梯赛中的程序员,你写的程序得高级一点,要能跟任意指定的星球打招呼。
输入格式:
输入在第一行给出一个星球的名字S
,是一个由不超过7个英文字母组成的单词,以回车结束。
输出格式:
在一行中输出Hello S
,跟输入的S
星球打个招呼。
输入样例:
Mars
输出样例:
Hello Mars
题目代码:
#include<iostream>
#include<string>
using namespace std;
int main()
{
string str;
cin >> str;
cout << "Hello " << str << endl;
return 0;
}
L1-046 整除光棍 (20 分)
这里所谓的“光棍”,并不是指单身汪啦~ 说的是全部由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
题目代码:
//L1-046 整除光棍
#include<iostream>
using namespace std;
int main()
{
int x,s=0,n=0;//定义除数,被除数,位数
cin>>x;
while(s<x)
{
s=s*10+1;//被除数末位添1直到不小于被除数
n++;//位数增1
}
while(true)//开始进行除法运算
{
cout<<s/x;//输出商
s%=x;//被除数更新为余数
if(s==0)break;//余数为0则结束
s=s*10+1;//余数末位添1
n++;//位数增1
}
cout<<' '<<n;
return 0;
}
L1-047 装睡 (10 分)
你永远叫不醒一个装睡的人 —— 但是通过分析一个人的呼吸频率和脉搏,你可以发现谁在装睡!医生告诉我们,正常人睡眠时的呼吸频率是每分钟15-20次,脉搏是每分钟50-70次。下面给定一系列人的呼吸频率与脉搏,请你找出他们中间有可能在装睡的人,即至少一项指标不在正常范围内的人。
输入格式:
输入在第一行给出一个正整数N(≤10)。随后N行,每行给出一个人的名字(仅由英文字母组成的、长度不超过3个字符的串)、其呼吸频率和脉搏(均为不超过100的正整数)。
输出格式:
按照输入顺序检查每个人,如果其至少一项指标不在正常范围内,则输出其名字,每个名字占一行。
输入样例:
4
Amy 15 70
Tom 14 60
Joe 18 50
Zoe 21 71
输出样例:
Tom
Zoe
题目代码:
//L1-047 装睡
#include<iostream>
using namespace std;
int main()
{
int n;
cin >> n;
while(n--)
{
char name[5];
int hu,mai;
cin >> name >> hu >> mai;
if(hu<15||hu>20)
cout << name << endl;
else if(mai<50||mai>70)
cout << name << endl;
}
return 0;
}
L1-048 矩阵A乘以B (15 分)
给定两个矩阵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
题目代码:
//L1-048 矩阵A乘以B
#include <bits/stdc++.h>
using namespace std;
int a[101][101], b[101][101];
int main()
{
int ra, ca, rb, cb;
scanf("%d%d", &ra, &ca);
for(int i=0; i<ra; i++)
{
for(int j=0; j<ca; j++)
{
scanf("%d", &a[i][j]);
}
}
scanf("%d%d", &rb, &cb);
for(int i=0; i<rb; i++)
{
for(int j=0; j<cb; j++)
{
scanf("%d", &b[i][j]);
}
}
if(ca == rb)
{
printf("%d %d\n", ra, cb);
for(int i=0; i<ra; i++)
{
for(int j=0; j<cb; j++)
{
int sum = 0;
for(int k=0; k<ca; k++)
{
sum += a[i][k]*b[k][j];
}
if(j < cb-1)
printf("%d ", sum);
else printf("%d\n", sum);
}
}
}
else printf("Error: %d != %d\n", ca, rb);
return 0;
}
L1-049 天梯赛座位分配 (20 分)
天梯赛每年有大量参赛队员,要保证同一所学校的所有队员都不能相邻,分配座位就成为一件比较麻烦的事情。为此我们制定如下策略:假设某赛场有 N 所学校参赛,第 i 所学校有 M[i] 支队伍,每队 10 位参赛选手。令每校选手排成一列纵队,第 i+1 队的选手排在第 i 队选手之后。从第 1 所学校开始,各校的第 1 位队员顺次入座,然后是各校的第 2 位队员…… 以此类推。如果最后只剩下 1 所学校的队伍还没有分配座位,则需要安排他们的队员隔位就坐。本题就要求你编写程序,自动为各校生成队员的座位号,从 1 开始编号。
输入格式:
输入在一行中给出参赛的高校数 N (不超过100的正整数);第二行给出 N 个不超过10的正整数,其中第 i 个数对应第 i 所高校的参赛队伍数,数字间以空格分隔。
输出格式:
从第 1 所高校的第 1 支队伍开始,顺次输出队员的座位号。每队占一行,座位号间以 1 个空格分隔,行首尾不得有多余空格。另外,每所高校的第一行按“#X”输出该校的编号X,从 1 开始。
输入样例:
3
3 4 2
输出样例:
#1
1 4 7 10 13 16 19 22 25 28
31 34 37 40 43 46 49 52 55 58
61 63 65 67 69 71 73 75 77 79
#2
2 5 8 11 14 17 20 23 26 29
32 35 38 41 44 47 50 53 56 59
62 64 66 68 70 72 74 76 78 80
82 84 86 88 90 92 94 96 98 100
#3
3 6 9 12 15 18 21 24 27 30
33 36 39 42 45 48 51 54 57 60
题目代码:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int main()
{
int n;
while(~scanf("%d",&n))
{
int a[n],b[n],cnt[n]={0},maxn=INT_MIN,flag=1;
for(int i=0;i<n;i++)
{
scanf("%d",&a[i]);
b[i]=a[i];
a[i]*=10;
if(maxn<a[i])
maxn=a[i];
}
if(n==1) // 1的特殊情况
{
printf("#1\n");
int from=-1;
for(int i=0;i<b[0];i++)
{
for(int j=0;j<10;j++)
{
if(j==0)
printf("%d",from+=2);
else
printf(" %d",from+=2);
}
puts("");
}
continue;
}
sort(b,b+n);
if(b[n-1]==b[n-2])
flag=0;
vector<int> v[n];
int last=1;
int k=1,tmax=b[n-2]*10;
for(int j=0;j<maxn;j++)
{
for(int i=0;i<n;i++)
{
if(a[i]>cnt[i])
{
cnt[i]++;
if(cnt[i]>tmax && flag==1)
{
if(last)
{
if(k-v[i][tmax-1]!=1)
k--;
last=0;
}
k++;
v[i].push_back(k++);
}
else
v[i].push_back(k++);
}
}
}
for(int i=0;i<n;i++)
{
printf("#%d\n",i+1);
int count=0;
for(int j=0;j<a[i];j++)
{
if(count==0)
printf("%d",v[i][j]);
else
printf(" %d",v[i][j]);
count++;
if(count>=10)
puts(""),count=0;
}
}
}
return 0;
}
L1-050 倒数第N个字符串 (15 分)
给定一个完全由小写英文字母组成的字符串等差递增序列,该序列中的每个字符串的长度固定为 L,从 L 个 a 开始,以 1 为步长递增。例如当 L 为 3 时,序列为 { aaa, aab, aac, ..., aaz, aba, abb, ..., abz, ..., zzz }。这个序列的倒数第27个字符串就是 zyz。对于任意给定的 L,本题要求你给出对应序列倒数第 N 个字符串。
输入格式:
输入在一行中给出两个正整数 L(2 ≤ L ≤ 6)和 N(≤105)。
输出格式:
在一行中输出对应序列倒数第 N 个字符串。题目保证这个字符串是存在的。
输入样例:
3 7417
输出样例:
pat
题目代码:
//L1-050 倒数第N个字符串
#include<iostream>
#include<cmath>
using namespace std;
int main()
{
int n,num,total,top=1;
char str[10];
cin >> n >> num;
total=pow(26,n);
num=total-num; //求第num个数
while(n--)
{
str[top]=num%26+97;
num=num/26;
top++;
}
for(int i=top-1;i>0;i--)
printf("%c",str[i]);
cout << endl;
return 0;
}
L1-051 打折 (5 分)
去商场淘打折商品时,计算打折以后的价钱是件颇费脑子的事情。例如原价 ¥988,标明打 7 折,则折扣价应该是 ¥988 x 70% = ¥691.60。本题就请你写个程序替客户计算折扣价。
输入格式:
输入在一行中给出商品的原价(不超过1万元的正整数)和折扣(为[1, 9]区间内的整数),其间以空格分隔。
输出格式:
在一行中输出商品的折扣价,保留小数点后 2 位。
输入样例:
988 7
输出样例:
691.60
题目代码:
//L1-051 打折
#include<iostream>
using namespace std;
int main()
{
float jia,zhe;
cin >> jia >> zhe;
printf("%.2f\n",jia*zhe*0.1);
return 0;
}
L1-052 2018我们要赢 (5 分)
2018年天梯赛的注册邀请码是“2018wmyy”,意思就是“2018我们要赢”。本题就请你用汉语拼音输出这句话。
输入格式:
本题没有输入。
输出格式:
在第一行中输出:“2018”;第二行中输出:“wo3 men2 yao4 ying2 !”。
输入样例:
无
输出样例:
2018
wo3 men2 yao4 ying2 !
题目代码:
#include<iostream>
using namespace std;
int main()
{
cout << "2018\nwo3 men2 yao4 ying2 !\n";
return 0;
}
L1-053 电子汪 (10 分)
据说汪星人的智商能达到人类 4 岁儿童的水平,更有些聪明汪会做加法计算。比如你在地上放两堆小球,分别有 1 只球和 2 只球,聪明汪就会用“汪!汪!汪!”表示 1 加 2 的结果是 3。
本题要求你为电子宠物汪做一个模拟程序,根据电子眼识别出的两堆小球的个数,计算出和,并且用汪星人的叫声给出答案。
输入格式:
输入在一行中给出两个 [1, 9] 区间内的正整数 A 和 B,用空格分隔。
输出格式:
在一行中输出 A + B 个Wang!
。
输入样例:
2 1
输出样例:
Wang!Wang!Wang!
题目代码:
//L1-053 电子汪
#include<iostream>
using namespace std;
int main()
{
int a,b;
cin >> a >> b;
for(int i=0;i<a+b;i++)
cout << "Wang!";
cout << endl;
return 0;
}
L1-054 福到了 (15 分)
“福”字倒着贴,寓意“福到”。不论到底算不算民俗,本题且请你编写程序,把各种汉字倒过来输出。这里要处理的每个汉字是由一个 N × N 的网格组成的,网格中的元素或者为字符 @
或者为空格。而倒过来的汉字所用的字符由裁判指定。
输入格式:
输入在第一行中给出倒过来的汉字所用的字符、以及网格的规模 N (不超过100的正整数),其间以 1 个空格分隔;随后 N 行,每行给出 N 个字符,或者为 @
或者为空格。
输出格式:
输出倒置的网格,如样例所示。但是,如果这个字正过来倒过去是一样的,就先输出bu yong dao le
,然后再用输入指定的字符将其输出。
输入样例 1:
$ 9
@ @@@@@
@@@ @@@
@ @ @
@@@ @@@
@@@ @@@@@
@@@ @ @ @
@@@ @@@@@
@ @ @ @
@ @@@@@
输出样例 1:
$$$$$ $
$ $ $ $
$$$$$ $$$
$ $ $ $$$
$$$$$ $$$
$$$ $$$
$ $ $
$$$ $$$
$$$$$ $
输入样例 2:
& 3
@@@
@
@@@
输出样例 2:
bu yong dao le
&&&
&
&&&
题目代码:
//L1-054 福到了
#include<iostream>
using namespace std;
int main()
{
char m[101][101];
int n,a[101][101]={0},b[101][101]={0};
int k,l;
char c;
cin >> c >> n;
getchar();
for(int i=0;i<n;i++)
{
for(int j=0;j<n;j++)
{
scanf("%c",&m[i][j]);
if(m[i][j]!=' ')
b[i][j]=1;
}
getchar();
}
k=n-1;
for(int i=0;i<n;i++)
{
l=n-1;
for(int j=0;j<n;j++)
{
if(m[k][l]!=' ')
a[i][j]=1;
l--;
}
k--;
}
int flag=1;
for(int i=0;i<n;i++)
for(int j=0;j<n;j++)
{
if(a[i][j]!=b[i][j])
{
flag=0;
break;
}
}
if(flag==1)
cout << "bu yong dao le\n";
for(int i=0;i<n;i++)
{
for(int j=0;j<n;j++)
if(a[i][j])
cout << c;
else
cout << " ";
cout << endl;
}
return 0;
}
L1-055 谁是赢家 (10 分)
某电视台的娱乐节目有个表演评审环节,每次安排两位艺人表演,他们的胜负由观众投票和 3 名评委投票两部分共同决定。规则为:如果一位艺人的观众票数高,且得到至少 1 名评委的认可,该艺人就胜出;或艺人的观众票数低,但得到全部评委的认可,也可以胜出。节目保证投票的观众人数为奇数,所以不存在平票的情况。本题就请你用程序判断谁是赢家。
输入格式:
输入第一行给出 2 个不超过 1000 的正整数 Pa 和 Pb,分别是艺人 a 和艺人 b 得到的观众票数。题目保证这两个数字不相等。随后第二行给出 3 名评委的投票结果。数字 0 代表投票给 a,数字 1 代表投票给 b,其间以一个空格分隔。
输出格式:
按以下格式输出赢家:
The winner is x: P1 + P2
其中 x
是代表赢家的字母,P1
是赢家得到的观众票数,P2
是赢家得到的评委票数。
输入样例:
327 129
1 0 1
输出样例:
The winner is a: 327 + 1
题目代码:
//L1-055 谁是赢家
#include<iostream>
using namespace std;
int main()
{
int pa,pb,n=3;
int a=0,b=0;
cin >> pa >> pb;
while(n--)
{
int m;
cin >> m;
if(m==0)
a++;
else if(m==1)
b++;
}
if(pa>pb&&a>0)
cout << "The winner is a: "<< pa << " + " << a << endl;
else if(pa<pb&&b>0)
cout << "The winner is b: "<< pb << " + " << b << endl;
else if(pa>pb&&b==3)
cout << "The winner is b: "<< pb << " + " << b << endl;
else if(pa<pb&&a==3)
cout << "The winner is a: "<< pa << " + " << a << endl;
return 0;
}
L1-056 猜数字 (20 分)
一群人坐在一起,每人猜一个 100 以内的数,谁的数字最接近大家平均数的一半就赢。本题就要求你找出其中的赢家。
输入格式:
输入在第一行给出一个正整数N(≤104)。随后 N 行,每行给出一个玩家的名字(由不超过8个英文字母组成的字符串)和其猜的正整数(≤ 100)。
输出格式:
在一行中顺序输出:大家平均数的一半(只输出整数部分)、赢家的名字,其间以空格分隔。题目保证赢家是唯一的。
输入样例:
7
Bob 35
Amy 28
James 98
Alice 11
Jack 45
Smith 33
Chris 62
输出样例:
22 Amy
题目代码:
#include<iostream>
#include<string>
#include<cmath>
using namespace std;
struct ndoe{
string name;
int num;
}arr[10005];
int main(){
int n, sum = 0, min = 99999;
string ans;
scanf("%d", &n);
for(int i = 0; i < n; i++){
string str;int a;
cin >> str >> a;
arr[i].name = str;
arr[i].num = a;
sum += a;
}
double x = sum * 1.0 / n / 2;
for(int i = 0; i < n; i++){
if(abs(arr[i].num - x) < min){
min = abs(arr[i].num - x);
ans = arr[i].name;
}
}
cout << (int) x << " " << ans;
return 0;
}
持续更新中……
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
所有评论(0)