PTA|团体程序设计天梯赛-练习题目题解锦集(C/C++)(持续更新中……)

PTA|团体程序设计天梯赛-练习题目题解锦集(持续更新中)

实现语言:C/C++;      欢迎各位看官交流讨论、指导题解错误;或者分享更快的方法!!

题目链接:https://pintia.cn/problem-sets/994805046380707840/problems


目录

(点击对应题目即可进入相应题解……小声BB……)

L1-001 Hello World (5 分)

L1-002 打印沙漏 (20 分)

L1-003 个位数统计 (15 分)

L1-004 计算摄氏温度 (5 分)

L1-005 考试座位号 (15 分)

L1-006 连续因子 (20 分)

L1-007 念数字 (10 分)

L1-008 求整数段和 (10 分)

L1-009 N个数求和 (20 分)

L1-010 比较大小 (10 分)

L1-011 A-B (20 分)

L1-012 计算指数 (5 分)

L1-013 计算阶乘和 (10 分)

L1-014 简单题 (5 分)

L1-015 跟奥巴马一起画方块 (15 分)

L1-016 查验身份证 (15 分)

L1-017 到底有多二 (15 分)

L1-018 大笨钟 (10 分)

L1-019 谁先倒 (15 分)

L1-020 帅到没朋友 (20 分)

L1-021 重要的话说三遍 (5 分)

L1-022 奇偶分家 (10 分)

L1-023 输出GPLT (20 分)

L1-024 后天 (5 分)

L1-025 正整数A+B (15 分)

L1-026 I Love GPLT (5 分)

L1-027 出租 (20 分)

L1-028 判断素数 (10 分)

L1-029 是不是太胖了 (5 分)

L1-030 一帮一 (15 分)

L1-031 到底是不是太胖了 (10 分)

L1-032 Left-pad (20 分)

L1-033 出生年 (15 分)

L1-034 点赞 (20 分)

L1-035 情人节 (15 分)

L1-036 A乘以B (5 分)

L1-037 A除以B (10 分)

L1-038 新世界 (5 分)

L1-039 古风排版 (20 分)

L1-040 最佳情侣身高差 (10 分)

持续更新中……


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=d?k?1??10?k?1??+?+d?1??10?1??+d?0?? (0≤d?i??≤9, i=0,?,k?1, d?k?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<2?31??)。

输出格式:

首先在第 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。两字符串的长度都不超过10?4??,并且保证每个字符串都是由可见的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,要求你输出 2?n??。不难吧?

输入格式:

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

输出格式:

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

输入样例:

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 分)

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

输入格式:

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

注意:我们把输入中出现的第1个空格认为是AB的分隔。题目保证至少存在一个空格,并且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]=1index[1]=0 对应 arr[0]=8index[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行,每行给出一个小于2?31??的需要判断的正整数。

输出格式:

对每个需要判断的正整数,如果它是素数,则在一行中输出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(≤10?4??)和一个字符,分别是填充结果字符串的长度和用于填充的字符,中间以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 F?1???F?K??”,其中1≤K≤10,F?i??(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;
}


持续更新中……

原文地址:https://www.cnblogs.com/lesileqin/p/10264226.html

时间: 2024-10-22 13:16:21

PTA|团体程序设计天梯赛-练习题目题解锦集(C/C++)(持续更新中……)的相关文章

PAT 团体程序设计天梯赛 部分题目题解

L1-002 打印沙漏 L1-006 连续因子 L1-010 比较大小 L1-014 简单题 L1-018 大笨钟 L2-002 链表去重 L2-010 排座位 L3-002 堆栈 L3-006 迎风一刀斩 L1-002. 打印沙漏 本题要求你写个程序把给定的符号打印成沙漏的形状.例如给定17个"*",要求按下列格式打印 ***** *** * *** ***** 所谓"沙漏形状",是指每行输出奇数个符号:各行符号中心对齐:相邻两行符号数差2:符号数先从大到小顺序递

PTA 团体程序设计天梯赛 L3-020 至多删三个字符

$f[i][j]$表示到第$i$个字符,已经删去了$j$个字符的方案数. 显然的转移: $f[i][j] = f[i - 1][j] + f[i - 1][j - 1]$ 但是这样会有重复,我们考虑什么情况会重复. 比如说:'aabab'中的'bab',我们删去'ba',得到'aab',删去'ab'得到'aab',两者是相同的 1 2 3 4 5 a a b a b 我们假设之前的每一位存的都是没有重复的方案数 就刚才的情况,我们发现当我们递推到第$5$个位置的时候,删去第三位和第四位的'ba'

PAT 团体程序设计天梯赛-练习集L1-011. A-B

本题要求你计算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! 1 #inclu

PAT 团体程序设计天梯赛-练习集 L1-015. 跟奥巴马一起画方块

美国总统奥巴马不仅呼吁所有人都学习编程,甚至以身作则编写代码,成为美国历史上首位编写计算机代码的总统.2014年底,为庆祝“计算机科学教育周”正式启动,奥巴马编写了很简单的计算机代码:在屏幕上画一个正方形.现在你也跟他一起画吧! 输入格式: 输入在一行中给出正方形边长N(3<=N<=21)和组成正方形边的某种字符C,间隔一个空格. 输出格式: 输出由给定字符C画出的正方形.但是注意到行间距比列间距大,所以为了让结果看上去更像正方形,我们输出的行数实际上是列数的50%(四舍五入取整). 输入样例

PAT 团体程序设计天梯赛-练习集 L1-007. 念数字

输入一个整数,输出每个数字对应的拼音.当整数为负数时,先输出“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

PAT 团体程序设计天梯赛-练习集 L1-005. 考试座位号

每个PAT考生在参加考试时都会被分配两个座位号,一个是试机座位,一个是考试座位.正常情况下,考生在入场时先得到试机座位号码,入座进入试机状态后,系统会显示该考生的考试座位号码,考试时考生需要换到考试座位就座.但有些考生迟到了,试机已经结束,他们只能拿着领到的试机座位号码求助于你,从后台查出他们的考试座位号码. 输入格式: 输入第一行给出一个正整数N(<=1000),随后N行,每行给出一个考生的信息:“准考证号 试机座位号 考试座位号”.其中准考证号由14位数字组成,座位从1到N编号.输入保证每个

PAT 团体程序设计天梯赛-练习集 L1-016. 查验身份证

一个合法的身份证号码由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 10M:1 0 X 9 8 7 6 5 4 3 2 现在给定一些身份证号码,请你验证校验码的有效性,并输出有问题的号码. 输入格式: 输入第一行给出正整数N(<= 100

PAT 团体程序设计天梯赛-练习集 L1-017. 到底有多二

一个整数“犯二的程度”定义为该数字中包含2的个数与其位数的比值.如果这个数是负数,则程度增加0.5倍:如果还是个偶数,则再增加1倍.例如数字“-13142223336”是个11位数,其中有3个2,并且是负数,也是偶数,则它的犯二程度计算为:3/11*1.5*2*100%,约为81.82%.本题就请你计算一个给定整数到底有多二. 输入格式: 输入第一行给出一个不超过50位的整数N. 输出格式: 在一行中输出N犯二的程度,保留小数点后两位. 输入样例: -13142223336 输出样例: 81.8

【题解】PAT团体程序设计天梯赛 - 模拟赛

由于本人愚笨,最后一题实在无力AC,于是只有前14题的题解Orz 总的来说,这次模拟赛的题目不算难,前14题基本上一眼就有思路,但是某些题写起来确实不太容易,编码复杂度有点高~ L1-1 N个数求和 设计一个分数类,重载加法运算符,注意要约分,用欧几里得算法求个最大公约数即可. 1 #include <cstdio> 2 3 long long abs(long long x) 4 { 5 return x < 0 ? -x : x; 6 } 7 8 long long gcd(long