【GPLT 一阶题目集】L1-056~L1-060

目录

L1-056 猜数字

L1-057 PTA使我精神焕发

L1-058 6翻了

L1-059 敲笨钟

L1-060 心理阴影面积


L1-056 猜数字

一群人坐在一起,每人猜一个 100 以内的数,谁的数字最接近大家平均数的一半就赢。本题就要求你找出其中的赢家。

输入格式:

输入在第一行给出一个正整数N(≤10^4)。随后 N 行,每行给出一个玩家的名字(由不超过8个英文字母组成的字符串)和其猜的正整数(≤ 100)。

输出格式:

在一行中顺序输出:大家平均数的一半(只输出整数部分)、赢家的名字,其间以空格分隔。题目保证赢家是唯一的。

输入样例:

7
Bob 35
Amy 28
James 98
Alice 11
Jack 45
Smith 33
Chris 62

输出样例:

22 Amy

#include <stdio.h>
#include <math.h>

typedef struct infor{
    char name[10];
    int num;
    double len;
}infor;

int main()
{
    int n;
    scanf("%d",&n);
    getchar();
    infor stud[10000];
    double sum=0,aver;
    for(int i=0;i<n;i++)
    {
        scanf("%[^ ] %d",stud[i].name,&stud[i].num);
        getchar();
        sum+=stud[i].num;
    }
    aver=sum/n/2;
    stud[0].len=fabs(aver-stud[0].num);
    infor winner=stud[0];
    for(int i=1;i<n;i++)
    {
        stud[i].len=fabs(aver-stud[i].num);
        if(stud[i].len<winner.len)
            winner=stud[i];
    }
    printf("%.0f %s",aver,winner.name);
    return 0;
}

注意事项:

如有疑问,欢迎提出。

L1-057 PTA使我精神焕发

以上是湖北经济学院同学的大作。本题就请你用汉语拼音输出这句话。

输入格式:

本题没有输入。

输出格式:

在一行中按照样例输出,以惊叹号结尾。

输入样例:

输出样例:

PTA shi3 wo3 jing1 shen2 huan4 fa1 !

#include <stdio.h>

int main()
{
    printf("PTA shi3 wo3 jing1 shen2 huan4 fa1 !");
    return 0;
}

注意事项:

如有疑问,欢迎提出。

L1-058 6翻了

“666”是一种网络用语,大概是表示某人很厉害、我们很佩服的意思。最近又衍生出另一个数字“9”,意思是“6翻了”,实在太厉害的意思。如果你以为这就是厉害的最高境界,那就错啦 —— 目前的最高境界是数字“27”,因为这是 3 个 “9”!

本题就请你编写程序,将那些过时的、只会用一连串“6666……6”表达仰慕的句子,翻译成最新的高级表达。

输入格式:

输入在一行中给出一句话,即一个非空字符串,由不超过 1000 个英文字母、数字和空格组成,以回车结束。

输出格式:

从左到右扫描输入的句子:如果句子中有超过 3 个连续的 6,则将这串连续的 6 替换成 9;但如果有超过 9 个连续的 6,则将这串连续的 6 替换成 27。其他内容不受影响,原样输出。

输入样例:

it is so 666 really 6666 what else can I say 6666666666

输出样例:

it is so 666 really 9 what else can I say 27

#include <stdio.h>
#include <string.h>

int main()
{
    char str[1001];
    int count = 0;
    gets(str);
    int len=strlen(str);
    for(int i=0;i<len;i++)
    {
        if(str[i]=='6')
        {
            count++;
            if(str[i+1]!='6')
            {
                if (count > 9)
                    printf("27");
                else if (count > 3)
                    printf("9");
                else
                    for (int k = 0; k < count; k++)
                        printf("6");
                count=0;
            }
        }
        else
            printf("%c",str[i]);
    }
    return 0;
}

注意事项:

如有疑问,欢迎提出。

L1-059 敲笨钟

微博上有个自称“大笨钟V”的家伙,每天敲钟催促码农们爱惜身体早点睡觉。为了增加敲钟的趣味性,还会糟改几句古诗词。其糟改的方法为:去网上搜寻压“ong”韵的古诗词,把句尾的三个字换成“敲笨钟”。例如唐代诗人李贺有名句曰:“寻章摘句老雕虫,晓月当帘挂玉弓”,其中“虫”(chong)和“弓”(gong)都压了“ong”韵。于是这句诗就被糟改为“寻章摘句老雕虫,晓月当帘敲笨钟”。

现在给你一大堆古诗词句,要求你写个程序自动将压“ong”韵的句子糟改成“敲笨钟”。

输入格式:

输入首先在第一行给出一个不超过 20 的正整数 N。随后 N 行,每行用汉语拼音给出一句古诗词,分上下两半句,用逗号 , 分隔,句号 . 结尾。相邻两字的拼音之间用一个空格分隔。题目保证每个字的拼音不超过 6 个字符,每行字符的总长度不超过 100,并且下半句诗至少有 3 个字。

输出格式:

对每一行诗句,判断其是否压“ong”韵。即上下两句末尾的字都是“ong”结尾。如果是压此韵的,就按题面方法糟改之后输出,输出格式同输入;否则输出 Skipped,即跳过此句。

输入样例:

5
xun zhang zhai ju lao diao chong, xiao yue dang lian gua yu gong.
tian sheng wo cai bi you yong, qian jin san jin huan fu lai.
xue zhui rou zhi leng wei rong, an xiao chen jing shu wei long.
zuo ye xing chen zuo ye feng, hua lou xi pan gui tang dong.
ren xian gui hua luo, ye jing chun shan kong.

输出样例:

xun zhang zhai ju lao diao chong, xiao yue dang lian qiao ben zhong.
Skipped
xue zhui rou zhi leng wei rong, an xiao chen jing qiao ben zhong.
Skipped
Skipped

#include <stdio.h>
#include <string.h>
int main()
{
    int n;
    scanf("%d", &n);
    getchar();
    char up[100] = { '\0' };
    char down[100] = { '\0' };
    int lenu = 0, lend = 0;
    for (int i = 0; i < n; i++)
    {
        scanf("%[^,]%[^\n]", up, down);
        getchar();
        lenu = strlen(up);
        lend = strlen(down);
        if (up[lenu - 3] == 'o' && up[lenu - 2] == 'n' && up[lenu - 1] == 'g' && down[lend - 4] == 'o' && down[lend - 3] == 'n' && down[lend - 2] == 'g')
        {
            printf("%s", up);
            int count = 0, temp;
            for (int j = lend - 1; j >= 0; j--)
            {
                if (down[j] == ' ') //找到下半句倒数第三个单词前的空格
                    count++;
                if (count == 3)
                {
                    temp = j;
                    break;
                }
            }
            for (int j = 0; j <= temp; j++)
                printf("%c", down[j]);
            printf("qiao ben zhong.\n");
            continue;
        }
        else {
            printf("Skipped\n");
        }
    }
    return 0;
}

注意事项:

如有疑问,欢迎提出。

L1-060 心理阴影面积

这是一幅心理阴影面积图。我们都以为自己可以匀速前进(图中蓝色直线),而拖延症晚期的我们往往执行的是最后时刻的疯狂赶工(图中的红色折线)。由红、蓝线围出的面积,就是我们在做作业时的心理阴影面积。

现给出红色拐点的坐标 (x,y),要求你算出这个心理阴影面积。

输入格式:

输入在一行中给出 2 个不超过 100 的正整数 x 和 y,并且保证有 x>y。这里假设横、纵坐标的最大值(即截止日和最终完成度)都是 100。

输出格式:

在一行中输出心理阴影面积。

友情提醒:三角形的面积 = 底边长 x 高 / 2;矩形面积 = 底边长 x 高。嫑想得太复杂,这是一道 5 分考减法的题……

输入样例:

90 10

输出样例:

4000

#include <stdio.h>

int main()
{
    int x,y;
    scanf("%d %d",&x,&y);
    printf("%d",5000-x*y/2-(100-x)*(100-y)/2-y*(100-x));
    return 0;
}

注意事项:

如有疑问,欢迎提出。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

花辞树dor

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值