团体程序设计天梯赛 L1-题目

天梯 专栏收录该内容
41 篇文章 0 订阅

L1-001 Hello World (5 分)

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

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

输入样例:

输出样例:

Hello World!
#include<bits/stdc++.h>

using namespace std;
int main()
{
    cout<<"Hello World!"<<endl;
    return 0;
}

 

 

 

L1-002 打印沙漏 (20 分)

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

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

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

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

输入格式:

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

输出格式:

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

输入样例:

19 *

输出样例:

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

 模拟题

#include<bits/stdc++.h>
using namespace std;
int s[1000];
int main()
{
	s[1]=1;
	s[2]=7;
	for(int i=2;i<=23;i++){
		s[i]=s[i-1]+(2*(i-1)+1)*2;
	}
	int n;
	char ch;
	scanf("%d %c",&n,&ch);
	int flag;
	for(int i=1;i<=23;i++){
		if(s[i]>n){
			flag=i-1;
			break;
		}
	}
	for(int i=flag;i>0;i--){
		for(int j=flag-i;j>0;j--){
			printf(" ");
		}
		for(int j=0;j<i*2-1;j++){
			printf("%c",ch);
		}
		printf("\n");
	}
	for(int i=1;i<flag;i++){
		for(int j=flag-i-1;j>0;j--){
			printf(" ");
		}
		for(int j=1;j<=i*2+1;j++){
			printf("%c",ch);
		}
		printf("\n");
	}
	printf("%d\n",n-s[flag]);
	return 0;
 } 

 

 

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<bits/stdc++.h>
using namespace std;
int main()
{
	string s;
	cin>>s;
	map<char,int>mp;
	for(int i=0;i<s.length();i++){
		mp[s[i]]++;
	}
	for(auto it:mp){
		cout<<it.first<<":"<<it.second<<endl;
	}
	return 0;
}

 

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

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

输入格式:

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

输出格式:

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

输入样例:

150

输出样例:

Celsius = 65
#include<bits/stdc++.h>
using namespace std;
int main()
{
	int n;
	scanf("%d",&n);
	printf("Celsius = %d\n",5*(n-32)/9);
	return 0;
 } 

 

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

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

输入格式:

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

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

输出格式:

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

输入样例:

4
3310120150912233 2 4
3310120150912119 4 1
3310120150912126 1 3
3310120150912002 3 2
2
3 4

输出样例:

3310120150912002 2
3310120150912119 1
#include<bits/stdc++.h>
using namespace std;
vector<pair<string,int> >vec[1010];
int main()
{
	int n;
	scanf("%d",&n);
	for(int i=0;i<n;i++){
		string s;
		cin>>s;
		int a,b;
		scanf("%d %d",&a,&b);
		vec[a].push_back(make_pair(s,b));
	}
	int k;
	scanf("%d",&k);
	for(int i=0;i<k;i++){
		int a;
		scanf("%d",&a);
		cout<<vec[a][0].first<<" "<<vec[a][0].second<<endl;
	}
	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<bits/stdc++.h>
using namespace std;
int main()
{
	int n;
	cin>>n;
	int first=0,len=0;
	for(int i=2;i<=sqrt(n)+1;i++){
		int j=i;
		int temp=1;
		for(j=i;j<=sqrt(n)+1;j++){
			temp=temp*j;
			if(n%temp!=0) break;
		}
		if(j-i>len){
			len=j-i;
			first=i;
		}
	}
	if(first==0){
		cout<<"1"<<endl<<n<<endl;
	}
	else{
		cout<<len<<endl;
		for(int i=0;i<len;i++){
			if(i) cout<<"*";
			cout<<first+i;
		}
		cout<<endl;
	}
	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
#include<bits/stdc++.h>
using namespace std;
int main()
{
	map<char,string>mp;
	mp['-']="fu";
	mp['0']="ling";
	mp['1'] ="yi";
	mp['2'] ="er";
	mp['3']="san";
	mp['4']="si";
	mp['5']="wu";
	mp['6']="liu";
	mp['7']="qi";
	mp['8']="ba";
	mp['9']="jiu";
	string s;
	cin>>s;
	for(int i=0;i<s.length();i++){
		if(i) cout<<" ";
		cout<<mp[s[i]];
	}
	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
#include<bits/stdc++.h>
using namespace std;
int main()
{
	int a,b;
	scanf("%d %d",&a,&b);
	int flag=0;
	int sum=0;
	for(int i=a;i<=b;i++){
		if(flag!=0&&flag%5==0) cout<<endl;
		printf("%5d",i);
		sum+=i;
		flag++;
	}
	cout<<endl;
	cout<<"Sum = "<<sum<<endl;
	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<bits/stdc++.h>
using namespace std;
typedef long long LL;
LL gcd(LL a,LL b)
{
	return b==0?a:gcd(b,a%b);
}
struct node
{
	LL up,down;
};
node Inn(node x)
{
	if(x.up==0) x.down=1;
	else{
		LL d=gcd(abs(x.up),abs(x.down));
		x.up/=d;
		x.down/=d;
		
	}
	return x;
}
node add(node a,node b)
{
	node c;
	c.up=a.up*b.down+a.down*b.up;
	c.down=a.down*b.down;
	return Inn(c);
}
int main()
{
	int n;
	scanf("%d",&n);
	node x;
	x.up=0,x.down=1;
	for(int i=0;i<n;i++){
		node t;
		scanf("%lld/%lld",&t.up,&t.down);
		t=Inn(t);
		x=add(x,t);
	}
	if(x.up&&x.up/x.down==0) printf("%lld/%lld\n",x.up%x.down,x.down);
	else if(x.up%x.down==0) printf("%lld\n",x.up/x.down);
	else printf("%lld %lld/%lld\n",x.up/x.down,x.up%x.down,x.down);
	return 0;
}

 

L1-010 比较大小 (10 分)

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

输入格式:

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

输出格式:

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

输入样例:

4 2 8

输出样例:

2->4->8

 

#include<bits/stdc++.h>
using namespace std;
int main()
{
	int s[4];
	cin>>s[0]>>s[1]>>s[2];
	sort(s,s+3);
	cout<<s[0]<<"->"<<s[1]<<"->"<<s[2]<<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<bits/stdc++.h>
using namespace std;
int flag[300];
int main()
{
	string s1,s2;
	getline(cin,s1);
	getline(cin,s2);
	for(int i=0;i<s2.length();i++){
		flag[s2[i]]=1;//自己会转换层整数型
	}
	for(int i=0;i<s1.length();i++){
		if(flag[s1[i]]) continue;
		cout<<s1[i];
	}
	cout<<endl; 
	return 0;
 } 

 

L1-012 计算指数 (5 分)

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

输入格式:

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

输出格式:

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

输入样例:

5

输出样例:

2^5 = 32
#include<bits/stdc++.h>
using namespace std;
int main()
{
	int n;
	cin>>n;
	int a=pow(2,n);
	printf("2^%d = %d\n",n,a);
	return 0;
}

 

 

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

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

输入格式:

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

输出格式:

在一行中输出S的值。

输入样例:

3

输出样例:

9

 

#include<bits/stdc++.h>
using namespace std;
int main()
{
	int n;
	cin>>n;
	int sum=0;
	for(int i=1;i<=n;i++){
		int t=1;
		for(int j=1;j<=i;j++){
			t*=j;
		} 
		sum+=t;
	}
	cout<<sum<<endl;
	return 0;
}

 

 

L1-014 简单题 (5 分)

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

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

输入样例:

输出样例:

This is a simple problem.

 

#include<bits/stdc++.h>
using namespace std;
int main()
{
	puts("This is a simple problem.");
	return 0;
}

 

 

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

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

输入格式:

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

输出格式:

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

输入样例:

10 a

输出样例:

aaaaaaaaaa
aaaaaaaaaa
aaaaaaaaaa
aaaaaaaaaa
aaaaaaaaaa
#include<bits/stdc++.h>
using namespace std;
int main()
{
	int n;
	char ch;
	scanf("%d %c",&n,&ch);
	int a=(int)(n*1.0/2+0.5);
	for(int i=0;i<a;i++){
		for(int j=0;j<n;j++){
			printf("%c",ch);
		}
		printf("\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
#include <iostream>
#include <string>
using namespace std;
bool func(string a);
int main() {
    int n;
    int count = 0;
    cin >> n;
    for (int i = 0; i < n; i++) {
        string a;
        cin >> a;
        if (func(a))
            count++;
    }
    if (count == 0)
        cout << "All passed";
    return 0;
}

bool func(string s) {
    int sum = 0;
    int a[18];
    for (int i = 0; i < 17; i++) {
        if(!isdigit(s[i])) {
            cout << s << endl;
            return false;
        }
        a[i] = s[i] - '0';
    }
    if (s[17] == 'X')
        a[17] = 10;
    else
        a[17] = s[17] - '0';
    int b[17] = {7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2};
    for (int i = 0; i < 17; i++) {
        sum = sum + a[i] * b[i];
    }
    sum = sum % 11;
    int c[11] = {1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2};
    if (c[sum] != a[17]) {
        for (int i = 0; i < 17; i++) {
            cout << s[i];
        }
        if (a[17] != 10)
            cout << a[17] << endl;
        else {
            cout << "X" << endl;
        }
        return true;
    }
    else {
        return false;
    }
}

 

 

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%

 

#include<bits/stdc++.h>
using namespace std;
int main()
{
	string s;
	cin>>s;
	int flag=(s[0]=='-'?1:0);
	int cnt=0;
	int len=s.length();
	for(int i=0;i<len;i++){
		if(s[i]=='2') cnt++;
	}
	double sum=1.0*cnt/(len-flag)*100;
	if(flag) sum*=1.5;
	if((s[len-1]-'0')%2==0) sum*=2;
	printf("%.2f%\n",sum); 
	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.
#include<bits/stdc++.h>
using namespace std;
int main()
{
  int h,m;
  scanf("%d:%d",&h,&m);
  if(h>=0&&h<=12){
    if(h==12){
      if(m>0) puts("Dang");
      else printf("Only %02d:%02d.  Too early to Dang.",h,m);
    }
    else{
      printf("Only %02d:%02d.  Too early to Dang.",h,m);
    }
  }
  else{
    int len=h-12;
    if(m>0) len++;
    for(int i=0;i<len;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
#include<bits/stdc++.h>
using namespace std;
int main()
{
	int n,m;
	scanf("%d %d",&n,&m);
	int t1=n,t2=m;
	int T;
	scanf("%d",&T);
	while(T--){
		int a,b,c,d;
		scanf("%d %d %d %d",&a,&b,&c,&d);
		int sum=a+c;
		if(b==sum&&d==sum) continue;
		else{
			if(b==sum) n--;
			if(d==sum) m--;
		}
		if(n<0){
			puts("A");
			printf("%d\n",t2-m);
			return 0;
		}
		else if(m<0){
			puts("B");
			printf("%d\n",t1-n);
			return 0;
		}
	} 
	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

 

#include<bits/stdc++.h>
using namespace std;
const int N=1e6;
int vis[N];
int main()
{
	int n;
	scanf("%d",&n);
	for(int i=0;i<n;i++){
		int k;
		scanf("%d",&k);
		for(int j=0;j<k;j++){
			int x;
			scanf("%d",&x);
			if(k>1) vis[x]=1;
		}
	}
	int m;
	scanf("%d",&m);
	vector<int>vec;
	for(int i=0;i<m;i++){
		int x;
		scanf("%d",&x);
		if(!vis[x]){
			if(find(vec.begin(),vec.end(),x)==vec.end())
			vec.push_back(x);
		}
	}
	if(vec.size()==0) puts("No one is handsome");
	else{
		for(int i=0;i<vec.size();i++){
			if(i) printf(" ");
			printf("%05d",vec[i]); 
		}
		printf("\n");
	}
	return 0;
}

 

 

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

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

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

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

输入样例:

输出样例:

I'm gonna WIN!
I'm gonna WIN!
I'm gonna WIN!
#include<bits/stdc++.h>
using namespace std;
int main()
{
  puts("I'm gonna WIN!");
  puts("I'm gonna WIN!");
  puts("I'm gonna WIN!");
  return 0;
}

 

 

L1-022 奇偶分家 (10 分)

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

输入格式:

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

输出格式:

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

输入样例:

9
88 74 101 26 15 0 34 22 77

输出样例:

3 6
#include<bits/stdc++.h>
using namespace std;
int main()
{
  int n;
  cin>>n;
  int qnum=0,onum=0;
  for(int i=0;i<n;i++){
    int x;
    cin>>x;
    if(x&1) qnum+=1;
    else onum+=1;
  }
  cout<<qnum<<" "<<onum<<endl;
  return 0;
}

 

L1-023 输出GPLT (20 分)

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

输入格式:

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

输出格式:

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

输入样例:

pcTclnGloRgLrtLhgljkLhGFauPewSKgt

输出样例:

GPLTGPLTGLTGLGLL

 

#include<bits/stdc++.h>
using namespace std;
int main()
{
	string s;
	cin>>s;
	int len=s.length();
	vector<char>g,p,l,t; 
	for(int i=0;i<len;i++){
		s[i]=toupper(s[i]);
		if(s[i]=='G'){
			g.push_back(s[i]);
		}
		if(s[i]=='P') p.push_back(s[i]);
		if(s[i]=='L') l.push_back(s[i]);
		if(s[i]=='T') t.push_back(s[i]);
	}
	while(g.size()||p.size()||l.size()||t.size()) {
		 if(g.size()){
		 	cout<<g[0];
		 	g.pop_back();
		 } 
		 if(p.size()){
		 	cout<<p[0];
		 	p.pop_back();
		 }
		 if(l.size()){
		 	cout<<l[0];
		 	l.pop_back();
		 }
		 if(t.size()){
		 	cout<<t[0];
		 	t.pop_back();
		 }
		 //cout<<endl;
	} 
	cout<<endl;
	return 0;
}

 

L1-024 后天 (5 分)

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

输入格式:

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

输出格式:

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

输入样例:

3

输出样例:

5
#include<bits/stdc++.h>
using namespace std;
int main()
{
  int n;
  cin>>n;
  n+=2;
  if(n==7) cout<<7<<endl;
  else
  cout<<n%7<<endl;
  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:

? + ? = ?
#include<bits/stdc++.h>
using namespace std;
bool solve(string s)
{
	if(s.length()==0) return false;
	for(int i=0;i<s.length();i++){
		if(!isdigit(s[i])) return false;
	}
	stringstream ss(s);
	int a;
	ss>>a;
	if(a<1||a>1000) return false;
	return true;
}
int main()
{
	string t,s1,s2;
	getline(cin,t);
	for(int i=0;i<t.length();i++){
		if(t[i]==' '){
			s1=t.substr(0,i);
			s2=t.substr(i+1);
			break;
		}
	}
	if(!solve(s1)) s1="?";
	if(!solve(s2)) s2="?";
	cout<<s1<<" + "<<s2<<" = ";
	if(s1!="?"&&s2!="?"){
		stringstream ss1(s1),ss2(s2);
		int a,b;
		ss1>>a;
		ss2>>b;
		cout<<a+b<<endl;
	}
	else cout<<"?"<<endl;
	return 0;
}

 

 

L1-026 I Love GPLT (5 分)

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

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

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

输入样例:

输出样例:

I

L
o
v
e

G
P
L
T

注意:输出的两个空行中各有一个空格。

#include<bits/stdc++.h>
using namespace std;
int main()
{
  puts("I");
  puts(" ");
  puts("L");
  puts("o");
  puts("v");
  puts("e");
  puts(" ");
  puts("G");
  puts("P");
  puts("L");
  puts("T");
  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};
#include<bits/stdc++.h>
using namespace std;
int main()
{
	string s;
	cin>>s;
	set<int,greater<int> >st;
	for(int i=0;i<s.length();i++){
		st.insert(s[i]-'0');
	}
	vector<int>vec;
	for(auto it:st){
		vec.push_back(it);
	}
	vector<int>p;
	for(int i=0;i<s.length();i++){
		int a=find(vec.begin(),vec.end(),s[i]-'0') -vec.begin();
		p.push_back(a);
	}
	cout<<"int[] arr = new int[]{";
	for(int i=0;i<vec.size();i++){
		if(i) cout<<",";
		cout<<vec[i];
	}
	cout<<"};"<<endl;
	cout<<"int[] index = new int[]{";
	for(int i=0;i<p.size();i++){
		if(i) cout<<",";
		cout<<p[i];
	}
	cout<<"};" <<endl;
	return 0;
}






 

 

L1-028 判断素数 (10 分)

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

输入格式:

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

输出格式:

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

输入样例:

2
11
111

输出样例:

Yes
No
#include<bits/stdc++.h>
using namespace std;
bool isprime(int x)
{
	for(int i=2;i<=sqrt(x);i++){
		if(x%i==0) return false;
	}
	return true;
}
int main()
{
	int T;
	cin>>T;
	while(T--){
		int n;
		cin>>n;
		if(n==1) cout<<"No"<<endl;
		else{
			if(isprime(n)) cout<<"Yes"<<endl;
			else cout<<"No"<<endl;	
		}
	}
	return 0;
}

 

 

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

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

输入格式:

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

输出格式:

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

输入样例:

169

输出样例:

124.2
#include<bits/stdc++.h>
using namespace std;
int main()
{
	int h;
	cin>>h;
	h-=100;
	double x=h*0.9*2;
	printf("%.1f\n",x);
}

 

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
#include<bits/stdc++.h>
using namespace std;
bool vis[100];
int main()
{
	int n;
	cin>>n;
	vector<pair<int,string> >vec1,vec2;
	for(int i=0;i<n;i++){
		int a;
		string s;
		cin>>a>>s;
		if(i>=n/2) vec2.push_back(make_pair(a,s));
		else vec1.push_back(make_pair(a,s));
	}
	reverse(vec2.begin(),vec2.end());
	for(int i=0;i<n/2;i++){
		for(int j=0;j<n/2;j++){
			if(!vis[j]){
				if(vec1[i].first!=vec2[j].first){
					cout<<vec1[i].second<<" "<<vec2[j].second<<endl;
					vis[j]=true;
					break;
				}
			}
		}
	}
	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!
#include<bits/stdc++.h>
using namespace std;
int main() {
	int n;
	cin >> n;
	for(int i = 0; i < n; i++) {
		float height, weight;
		cin >> height >> weight;
		float stan = (height - 100) * 0.9 * 2;
		if(abs(stan - weight) < stan * 0.1) {
			cout << "You are wan mei!" << endl;
		} else if(stan > weight) {
			cout << "You are tai shou le!" << endl;
		} else {
			cout << "You are tai pang le!" << endl;
		}
	}
	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
#include<bits/stdc++.h>
using namespace std;
int main() {
    int cnt;
    char c;
    string s;
    cin >> cnt >> c;
    getchar();
    getline(cin, s);
    int len = s.length();
    if(len >= cnt) {
        cout << s.substr(s.size() - cnt);
    } else {
        for(int i = 0; i < cnt - len; i++) {
            cout << c;
        }
        cout << s;
    }
    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
#include<bits/stdc++.h>
using namespace std;

int solve(int x)
{
	set<int>st;
	int n=x;
	while(x){
		st.insert(x%10); 
		x/=10; 
	}
	if(n<1000) st.insert(0);
	return st.size();
}
int main()
{
	int n,k;
	cin>>n>>k;
	int t=n;
	while(n){
		int x=solve(n);
		if(x==k){
			printf("%d %04d\n",n-t,n);
			break;
		}
		n++;
	}
	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
#include<bits/stdc++.h>
using namespace std;
int main()
{
	int n;
	cin>>n;
	map<int,int,greater<int> >mp;
	for(int i=0;i<n;i++){
		int k;
		cin>>k;
		for(int j=0;j<k;j++){
			int x;
			cin>>x;
			mp[x]++;
		}
	}
	map<int,int,greater<int> >mp1;
	for(auto it:mp){
		mp1.insert(make_pair(it.second,it.first));
	}
	auto it=mp1.begin();
	cout<<it->second<<" "<<it->first<<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 ...
#include<bits/stdc++.h>
using namespace std;
int main()
{
	string s;
	int flag=1;
	string s2,s14;
	while(cin>>s,s!="."){
		if(flag==2){
			s2=s;
			//cout<<s2<<" "<<s<<endl;
		}
		if(flag==14){
			s14=s;
			//cout<<s14<<" "<<s<<endl;
		}
		flag++;
	}
	if(flag>=14){
		cout<<s2<<" and "<<s14<<" are inviting you to dinner..."<<endl;
	}
	else if(flag>2){
		cout<<s2<<" is the only one for you..."<<endl;
	}
	else{
		cout<<"Momo... No one is for you ..."<<endl;
	}
	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<bits/stdc++.h>
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<bits/stdc++.h>
using namespace std;
int main()
{
  double a,b;
  cin>>a>>b;
  if(b==0){
	printf("%.0f/0=Error\n",a,b); 
  }
  else{
    double c=1.0*a/b;
    if(b<0){
    	printf("%.0f/(%.0f)=%.2f\n",a,b,c); 
	}
	else{
		printf("%.0f/%.0f=%.2f\n",a,b,c); 
	}
    
  }
  
  
  return 0;
}

 

 

L1-038 新世界 (5 分)

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

你只需要在第一行中输出程序员钦定名言“Hello World”,并且在第二行中输出更新版的“Hello New World”就可以了。

输入样例:

输出样例:

Hello World
Hello New World
#include<bits/stdc++.h>
using namespace std;
int main()
{
  cout<<"Hello World"<<endl;
  cout<<"Hello New World"<<endl;
  return 0;
}

 

 

L1-039 古风排版 (20 分)

中国的古人写文字,是从右向左竖向排版的。本题就请你编写程序,把一段文字按古风排版。

输入格式:

输入在第一行给出一个正整数N(<100),是每一列的字符数。第二行给出一个长度不超过1000的非空字符串,以回车结束。

输出格式:

按古风格式排版给定的字符串,每列N个字符(除了最后一列可能不足N个)。

输入样例:

4
This is a test case

输出样例:

asa T
st ih
e tsi
 ce s
#include<bits/stdc++.h>
using namespace std;
int main()
{
	int n;
	cin>>n;
	string s;
	getchar();
	getline(cin,s);
	string t[110];
	int flag=0;
	for(int i=0;i<s.size();i++){
		if(flag!=0&&flag%n==0) flag=0;
		t[flag++].push_back(s[i]);
		//cout<<s[i]<<endl;
	}
	if(flag!=n){
		while(flag!=n){
			t[flag++].push_back(' ');
		}
	}
	for(int i=0;i<n;i++){
		reverse(t[i].begin(),t[i].end());
		for(int j=0;j<t[i].size();j++){
			cout<<t[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
#include<bits/stdc++.h>
using namespace std;
int main()
{
  int n;
  cin>>n;
  while(n--){
    char s[10];
    double a;
    
    cin>>s;
    cin>>a;
    if(s[0]=='M') printf("%.2f\n",a*1.0/1.09);
    else printf("%.2f\n",a*1.09);
  }
  return 0;
}

 

 

L1-041 寻找250 (10 分)

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

输入格式:

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

输出格式:

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

输入样例:

888 666 123 -233 250 13 250 -222

输出样例:

5
#include<bits/stdc++.h>

using namespace std;
int main()
{
    int x;
    int cnt=1;
    bool flag=false;
    int m;
    while(cin>>x){
        if(x==250){
            if(!flag){
                flag=true;
                m=cnt;
            }
        }
        cnt++;
    }
    cout<<m<<endl;
    return 0;
}

 

L1-042 日期格式化 (5 分)

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

输入格式:

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

输出格式:

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

输入样例:

03-15-2017

输出样例:

2017-03-15
#include<bits/stdc++.h>

using namespace std;
int main()
{
    int m,d,y;
    scanf("%d-%d-%d",&m,&d,&y);
    printf("%d-%02d-%02d\n",y,m,d);
    return 0;
}

 

 

L1-043 阅览室 (20 分)

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

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

输入格式:

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

书号([1, 1000]内的整数) 键值SE) 发生时间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
#include<bits/stdc++.h>

using namespace std;
int mintue[1010];
bool vis[1010];
int main() {
    int n;
    cin >> n;
    for (int i = 0; i < n; i++) {
        int id = -1;
        double time = 0;
        int num = 0;
        while (true) {
            char a;
            int h, f;
            scanf("%d %c %d:%d", &id, &a, &h, &f);
            if (id == 0) {
                break;
            } else if (a == 'S') {
                mintue[id] = h * 60 + f;
                vis[id] = true;
            } else if (a == 'E') {
                if (vis[id]) {
                    vis[id] = false;
                    time += h * 60 + f - mintue[id];
                    mintue[id] = 0;
                    num++;
                }
            }
        }
        int t;
        if (num != 0) {
            time /= num;
        }
        t = time+0.5;
        printf("%d %d\n", num, t);
    }
    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
#include<bits/stdc++.h>

using namespace std;
int main()
{
    int k;
    scanf("%d",&k);
    map<string,string>mp;
    mp["ChuiZi"]="Bu";
    mp["JianDao"]="ChuiZi";
    mp["Bu"]="JianDao";
    string s;
    int flag=0;
    while(cin>>s){
        //cout<<"**********"<<flag<<endl;
        if(s=="End") break;
        if(flag!=0&&flag%k==0){
            cout<<s<<endl;
            flag=0;
            continue;
        }
        else{
            cout<<mp[s]<<endl;
        }
        flag++;
    }
    return 0;
}

 

L1-045 宇宙无敌大招呼 (5 分)

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

输入格式:

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

输出格式:

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

输入样例:

Mars

输出样例:

Hello Mars

 

#include<bits/stdc++.h>

using namespace std;
int main()
{
    string s;
    cin>>s;
    cout<<"Hello "<<s<<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)。

输出格式:

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

输入样例:

31

输出样例:

3584229390681 15
#include<bits/stdc++.h>
using namespace std;
vector<int>p,vec;
bool solve(int x)
{
	vec.clear();
	int r=0;
	for(int i=0;i<p.size();i++){
		r=r*10+p[i];
		if(r<x){
			vec.push_back(0);
		}
		else{
			vec.push_back(r/x);
			r=r%x;
		}
	}
	//cout<<r<<endl;
	if(r==0) return true;
	else return false;
}
int main()
{
	int x;
	cin>>x;
	int t=1;
	p.push_back(1);
	while(true){
		//for(int i=0;i<p.size();i++) cout<<p[i];
		//cout<<endl;
		if(t<x){
			t=t*10+1;
			p.push_back(1);
		}
		else{
			if(solve(x)){
				int cnt=0;
				while(cnt<vec.size()-1&&vec[cnt]==0) cnt++;
				for(int i=cnt;i<vec.size();i++) cout<<vec[i];
				cout<<" "<<p.size()<<endl;
				return 0;
			}
			else{
				p.push_back(1);
			}
		}
	}
	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
#include<bits/stdc++.h>

using namespace std;
int main()
{
    int n;
    cin>>n;
    for(int i=0;i<n;i++){
        string s;
        int a,b;
        cin>>s>>a>>b;
        if(a<15||a>20||b<50||b>70) cout<<s<<endl;
    }
    return 0;
}

 

 

L1-048 矩阵A乘以B (15 分)

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

输入格式:

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

输出格式:

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

输入样例1:

2 3
1 2 3
4 5 6
3 4
7 8 9 0
-1 -2 -3 -4
5 6 7 8

输出样例1:

2 4
20 22 24 16
53 58 63 28

输入样例2:

3 2
38 26
43 -5
0 17
3 2
-11 57
99 68
81 72

输出样例2:

Error: 2 != 3
#include<bits/stdc++.h>
using namespace std;
int a[1000][1000];
int b[1000][1000];
int c[1000][1000];

int main()
{
    
    int n1,m1;
    cin>>n1>>m1;
    for(int i=0;i<n1;i++){
        for(int j=0;j<m1;j++){
            cin>>a[i][j];
        }
    }
    int n2,m2;
    cin>>n2>>m2;
    for(int i=0;i<n2;i++){
        for(int j=0;j<m2;j++){
            cin>>b[i][j];
        }
    }

    if(m1!=n2){
        printf("Error: %d != %d",m1,n2);
    }
    else{
        memset(c,0,sizeof(c));
        for(int i=0;i<n1;i++){
            for(int j=0;j<m2;j++){
                for(int k=0;k<m1;k++){

                    c[i][j]+=a[i][k]*b[k][j];
                }
            }
        }
        cout<<n1<<" "<<m2<<endl;
        for(int i=0;i<n1;i++){
            for(int j=0;j<m2;j++){
                if(j) cout<<" ";
                cout<<c[i][j];
            }
            cout<<endl;
        }
    }

    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;
int s[110];
bool vis[110];
int main()
{
	int n;
	scanf("%d",&n);
	for(int i=0;i<n;i++){
		scanf("%d",&s[i]);
		s[i]=s[i]*10;
	}
	int num=1;
	vector<int>vec[110];
	int pos=1;
	while(num<=n){
		for(int i=0;i<n;i++){
			if(vec[i].size()<s[i]){
				vec[i].push_back(pos);
				if(num<n) pos++;
				else pos+=2;
			}
			if(vec[i].size()==s[i]&&!vis[i]){
				vis[i]=true;
				num++;
			}
		}
	}
	for(int i=0;i<n;i++){
		printf("#%d\n",i+1);
		for(int j=0;j<vec[i].size();j++){
			printf("%d",vec[i][j]);
			if(j&&(j+1)%10==0) printf("\n");
			else printf(" ");
		}
	}
	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(≤10​5​​)。

输出格式:

在一行中输出对应序列倒数第 N 个字符串。题目保证这个字符串是存在的。

输入样例:

3 7417

输出样例:

pat
#include<bits/stdc++.h>
using namespace std;
int main()
{
//	for(int i=0;i<26;i++){
	//	cout<<char(i+'a')<<endl;
	//}
	int l,n;
	cin>>l>>n;
	n--;//边界处理 第n个就是下标为n-1 
	vector<int>vec;
	// 0~25分别对应正数的a~z,即倒数的z~a
	while(n){
		vec.push_back(n%26);
		n/=26;
	}
	// 将不足位赋值0,对应a
	while(vec.size()!=l) vec.push_back(0);
	reverse(vec.begin(),vec.end());
	for(int i=0;i<l;i++){
		cout<<char(25-vec[i]+'a');
	}
	cout<<endl;
	return 0;
}

 

 

L1-051 打折 (5 分)

去商场淘打折商品时,计算打折以后的价钱是件颇费脑子的事情。例如原价 ¥988,标明打 7 折,则折扣价应该是 ¥988 x 70% = ¥691.60。本题就请你写个程序替客户计算折扣价。

输入格式:

输入在一行中给出商品的原价(不超过1万元的正整数)和折扣(为[1, 9]区间内的整数),其间以空格分隔。

输出格式:

在一行中输出商品的折扣价,保留小数点后 2 位。

输入样例:

988 7

输出样例:

691.60
#include<bits/stdc++.h>
using namespace std;
int main()
{
	int n,f;
	cin>>n>>f;
	double a=n*1.0*f/10;
	printf("%.2f\n",a); 
	return 0;
 } 

 

 

L1-052 2018我们要赢 (5 分)

2018年天梯赛的注册邀请码是“2018wmyy”,意思就是“2018我们要赢”。本题就请你用汉语拼音输出这句话。

输入格式:

本题没有输入。

输出格式:

在第一行中输出:“2018”;第二行中输出:“wo3 men2 yao4 ying2 !”。

输入样例:

输出样例:

2018
wo3 men2 yao4 ying2 !
#include<bits/stdc++.h>
using namespace std;
int main()
{
	cout<<"2018"<<endl;
	puts("wo3 men2 yao4 ying2 !");
	return 0;
 } 

 

 

 

L1-053 电子汪 (10 分)

据说汪星人的智商能达到人类 4 岁儿童的水平,更有些聪明汪会做加法计算。比如你在地上放两堆小球,分别有 1 只球和 2 只球,聪明汪就会用“汪!汪!汪!”表示 1 加 2 的结果是 3。

本题要求你为电子宠物汪做一个模拟程序,根据电子眼识别出的两堆小球的个数,计算出和,并且用汪星人的叫声给出答案。

输入格式:

输入在一行中给出两个 [1, 9] 区间内的正整数 A 和 B,用空格分隔。

输出格式:

在一行中输出 A + B 个Wang!

输入样例:

2 1

输出样例:

Wang!Wang!Wang!
#include<bits/stdc++.h>
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
&&&
 & 
&&&
#include<bits/stdc++.h>
using namespace std;
int main()
{
	char ch;
	int n;
	cin>>ch>>n;
	string s[110];
	getchar();
	for(int i=0;i<n;i++){
		getline(cin,s[i]);
	}
	char t[110][110];
	memset(t,0,sizeof(t));
	for(int i=0;i<n;i++){
		for(int j=0;j<n;j++){
			if(s[abs(n-i)-1][abs(n-1-j)]==' ') t[i][j]=' ';
			else t[i][j]=ch;
		}
	}
	bool flag=false;
	for(int i=0;i<n;i++){
		for(int j=0;j<n;j++){
			if(s[i][j]==' '&&t[i][j]!=' ') flag=true;
			if(s[i][j]!=' '&&t[i][j]==' ') flag=true;
		}
	}
    if(!flag) puts("bu yong dao le");
	for(int i=0;i<n;i++){
		for(int j=0;j<n;j++){
			cout<<t[i][j];
		}
		cout<<endl;
	}
	
	return 0;
 } 

 

  • 0
    点赞
  • 0
    评论
  • 0
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

©️2021 CSDN 皮肤主题: 技术黑板 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值