天梯赛打卡10

此题涉及C++编程,要求实现一个程序:根据输入时间敲击大笨钟,同时按GPLT顺序处理字母字符串。
摘要由CSDN通过智能技术生成

题目十八

题目

微博上有个自称“大笨钟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 大笨钟 - 团体程序设计天梯赛-练习集 (pintia.cn)

代码

#include<bits/stdc++.h>
using namespace std;
int main()
{
    int hh,mm;
    scanf("%02d:%02d",&hh,&mm);
    if(hh>=0&&hh<12)
    {
        printf("Only %02d:%02d.  Too early to Dang.",hh,mm);
    }
    else if(hh==12&&mm==0)
    {
        printf("Only %02d:%02d.  Too early to Dang.",hh,mm);
    }
    else
    {
       for(int i=13;i<=hh;i++)
       {
            cout<<"Dang";
       }
        if(mm>0)
        {
             printf("Dang");
        }
    }
    return 0;
}

题目十九

题目

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

输入格式:

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

输出格式:

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

输入样例:

pcTclnGloRgLrtLhgljkLhGFauPewSKgt

输出样例:

GPLTGPLTGLTGLGLL

链接

L1-023 输出GPLT - 团体程序设计天梯赛-练习集 (pintia.cn)

代码

#include<iostream>
#include<string>
using namespace std;
int main()
{
    string a;
    int i,b[4]={0,0,0,0};
    getline(cin,a);
	for(i=0;i<a.length();i++)
    {
        if(a[i]=='g'||a[i]=='G')
            b[0]++;
        else if(a[i]=='p'||a[i]=='P')
            b[1]++;
        else if(a[i]=='l'||a[i]=='L')
            b[2]++;
        else if(a[i]=='t'||a[i]=='T')
            b[3]++;
    }
	while(b[0]+b[1]+b[2]+b[3])
    {
        if(b[0]>0)
		{
			printf("G");
			b[0]--;
		}
		if(b[1]>0)
		{
			printf("P");
			b[1]--;
		}
		if(b[2]>0)
		{
			printf("L");
			b[2]--;
		}
		if(b[3]>0)
		{
			printf("T");
			b[3]--;
		}
    }
    return 0;
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值