当前位置:   article > 正文

GPLT练习集L1 33--40_gpltj

gpltj

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。
  • 1
  • 2
  • 3

输出格式:
根据输入,输出x和能达到要求的年份。数字间以1个空格分隔,行首尾不得有多余空格。年份要按4位输出。注意:所谓“n个数字都不相同”是指不同的数字正好是n个。如“2013”被视为满足“4位数字都不同”的条件,但不被视为满足2位或3位数字不同的条件。

输入样例1:
1988 4

输出样例1:
25 2013

输入样例2:
1 2

输出样例2:
0 0001
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

代码

#include <bits/stdc++.h>
using namespace std;

string str;
int y,x,n;
int main() {
    cin >> y >> n;
    for(int i = y ; ; ++i) {
        int p = 0,num[10] = {0};
        str = to_string(i);
        while(str.length()!=4) str += '0';
        /*
        if(i<1000) num[0] = 1;
        */
        for(int j = 0 ;  j < 4 ; ++j) num[str[j] - '0']++;
        for(int k = 0 ; k < 10 ; ++k)
            if(num[k]) ++p;
        if(p == n ){
            printf("%d %04d",i - y ,i);
            break;
        }
    }
    return 0;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24

说明

  1. 本 题 的 思 路 就 是 得 到 由 n 个 数 组 成 的 年 份 , 比 如 2011 由 2 , 0 , 1 这 3 个 数 组 成 , 这 时 n = 3 本题的思路就是得到由n个数组成的年份,比如2011由2,0,1这3个数组成,这时n=3 n,20112,0,13,n=3

  2. 由 题 可 知 , 当 年 份 y < 1000 时 , 有 无 前 置 0 的 问 题 , 我 们 输 入 和 定 义 的 整 型 , 不 会 前 置 0 , 但 需 要 前 置 0 由题可知,当年份y<1000时,有无前置0的问题,我们输入和定义的整型,不会前置0,但需要前置0 ,y<1000,0,,0,0

  3. 处 理 这 个 有 两 种 方 法 : 处理这个有两种方法: :

    ① 若 y < 1000 , 则 计 数 数 组 n u m [ 0 ] = 1 ; / / 只 需 要 知 道 有 多 少 个 非 零 的 数 即 可 , 不 用 知 道 到 底 有 多 少 个 ①若y<1000,则计数数组num[0] = 1;//只需要知道有多少个非零的数即可,不用知道到底有多少个 y<1000,num[0]=1;//,
    ② 不 足 4 位 直 接 补 0 , 可 把 它 转 换 为 字 符 串 , 利 用 ②不足4位直接补0,可把它转换为字符串,利用 40,,to_string() 函 数 函数

  4. 最 后 需 要 前 置 0 最后需要前置0 0 printf("%d %04d",i - y ,i);

L1-034 点赞 (20 分)

题目描述

在这里插入图片描述

代码

#include <iostream>
using namespace std;

int main() {
    int n;
    cin>>n;
    int num[1001]={0};
    while(n--) {
        int k;
        cin>>k;
        while(k--) {
            int f;
            cin>>f;
            num[f]++;
        }
    }
    int max = -1,j=0;
    for(int i = 0 ; i<1001; i++ ) {
        if(num[i]!=0) {
            if( num[i] >= max ) {
                max = num[i];
                j=i;
            }
        }
    }
    cout<<j<<" "<<max;
    return 0;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28

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 ...
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33

代码

#include <iostream>
using namespace std;
int main() {
	int i=0;
	string s,a,b;
	for(;;i++) {
		cin>>s;
		if(i == 1)
  			a=s;
		if(i == 13)
  			b=s;
		if(s == ".")
			break;
	}
	if(i>=14)
		cout<<a<<" and "<<b<<" are inviting you to dinner...";
	else if(i>=2 && i<14)
		cout<<a<<" is the only one for you...";
	else
		cout<<"Momo... No one is for you ...";
    return 0;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22

L1-036 A乘以B (5 分)

题目描述

看我没骗你吧 —— 这是一道你可以在 10 秒内完成的题:给定两个绝对值不超过 100 的整数 A 和 B,输出 A 乘以 B 的值。

输入格式:
输入在第一行给出两个整数 A 和 B(−100≤A,B≤100),数字间以空格分隔。

输出格式:
在一行中输出 A 乘以 B 的值。

输入样例:
-8 13

输出样例:
-104
  • 1
  • 2
  • 3
  • 4
  • 5

代码

#include <bits/stdc++.h>
using namespace std;
int main() {
	int a,b;
	cin >> a >> b ;
	cout << a * b ;
	return 0;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

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
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17

代码

#include <stdio.h>
#include <iostream>
#include <math.h>
using namespace std;

int main() {
    int a,b;//a位分子,b为分母
    cin>>a>>b;
    if(b!=0) {
    	double c=(double)a/b;
        if(b>0)
            printf("%d/%d=%.2lf",a,b,c);
        else
            printf("%d/(%d)=%.2lf",a,b,c);
    }
    else
        cout<<a<<"/"<<b<<"=Error";

	return 0;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20

L1-038 新世界 (5 分)

题目描述

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

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

输入样例:

输出样例:
Hello World
Hello New World
  • 1
  • 2
  • 3

代码

#include<iostream>
using namespace std;
int main() {
	cout<<"Hello World"<<endl<<"Hello New World";
  	return 0;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

L1-039 古风排版 (20 分)

题目描述

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

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

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

输入样例:
4
This is a test case

输出样例:
asa T
st ih
e tsi
 ce s
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

代码

#include <iostream>
#include <cmath>
#include <cstring>
using namespace std;
int main() {
	int n;
	cin>>n;
	getchar();
	string s;
	getline(cin,s);
	int N = s.length(), M = (N+n-1)/n; //行数
	char str[n][M];//利用二位数组来存储字符
	int l = 0;
	for(int j = M-1 ; j>=0 ; j--)
		for(int i = 0 ; i<n ; i++) {
            str[i][j] = s[l++];
            if(l>N)
               str[i][j] = ' ';//超过其长度就补 ' '
        }
			
	for(int i = 0 ; i<n ; i++) {
		for(int j = 0 ; j<M ; j++)
			cout<<str[i][j];
		cout<<endl;
	}
	return 0;
}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28

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
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

代码

#include <iostream>
using namespace std;

int main() {
	int n;
	cin>>n;
	while(n--) {
		double hei,height;
		char ch;
		cin >> ch >> hei;
		if(ch == 'M')
			height=hei/1.09;
		else if(ch == 'F')
			height=hei*1.09;
		printf("%.2lf\n",height);
	}
	return 0;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家自动化/article/detail/449432
推荐阅读
相关标签
  

闽ICP备14008679号