团体程序设计天梯赛-练习集 L1-059 敲笨钟 (20 分)

本文介绍了一个有趣的程序设计挑战,旨在通过自动识别并修改古诗词中压ong韵的句子,将其转化为一种幽默的形式。该程序不仅需要准确地识别诗句的韵律,还要能够巧妙地将特定的词语替换成敲笨钟,以此向微博上的大笨钟V致敬。文章提供了两种不同的实现方法,包括一种存在轻微显示问题的解决方案和一个完全正确的版本。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

微博上有个自称“大笨钟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

题解:本题并不难,就是需要找到句号逗号,以及倒数第三个空格的位置。然后分情况输出就好。

发现一个问题:题目是给了一堆,但是你却可以输入一组就输出一组,不一定要堆到最后才输出。

第一个题解:都是对的,就是每次输出押韵情况的长句时就会在其前面多出一个空行,找了半个多小时问题,没找到问题,最终放弃,若有哪位大神能找到第一种做法的毛病,本人将不胜感激。最终换为了string类型来存储字符。同时建议以后尽量使用string类型来用。

第二个完全正确:就是输入一组,输出一组。

给出第一种解法运行错误的图片:(多一行空格)

在这里插入图片描述

#include <iostream>
#include <cstdio>
#include <string>
#include <cstring>
#include <vector>
#include <algorithm>
using namespace std;

char ch[25][105],c;
int num[25],douhao[25],black[25];
int main()
{
    int i=0,j=0,n;
    int count=0;

    cin>>n;

    for(i=0;i<n;i++)
    {
        j=0;
        while((c=getchar())!='.')
        {
            ch[i][j++]=c;//此时j指向小数点
        }
        num[i]=j;
    }
    //找小数点
    for(i=0;i<n;i++)
    {
        for(j=0;j<num[i];j++)
        {
            if(ch[i][j]==',')
                douhao[i]=j;
        }
    }
    //找倒数第三个空格位置
    for(i=0;i<n;i++)
    {
        count=0;
        for(j=num[i];j>=0;j--)
        {
            if(ch[i][j]==' ')
                count++;
            if(count==3)
            {
                black[i]=j;
                break;
            }
        }
    }

    //输出结果
    for(i=0;i<n;i++)
    {
        //输出不符合情况的
        if(ch[i][num[i]-3]!='o'||ch[i][num[i]-2]!='n'||ch[i][num[i]-1]!='g'
           ||ch[i][douhao[i]-3]!='o'||ch[i][douhao[i]-2]!='n'||ch[i][douhao[i]-1]!='g')
        {
            cout<<"Skipped"<<endl;
        }
        else//输出押韵的
        {
            for(j=0;j<=black[i];j++)
            {
                cout<<ch[i][j];
            }
            //修改结尾
            cout<<"qiao ben zhong."<<endl;
        }
    }


    return 0;
}


此做法完全正确:

#include <iostream>
#include <cstdio>
#include <string>
#include <cstring>
#include <vector>
#include <algorithm>
using namespace std;

string str;
int douhao,black,juhao,A,B,k;

int main()
{
    int n,i;
    cin>>n;
    getchar();//接受回车字符

    while(n--)
    {
        getline(cin,str);

        k=0;A=0;B=0;

        //找小数点

        for(i=0;i<str.size();i++)
        {
            if(str[i]==',')
                douhao=i;
            if(str[i]=='.')
                juhao=i;
        }

        //找倒数第三个空格位置

        for(i=str.size()-1;i>=0;i--)
        {
            if(str[i]==' ')
                k++;
            if(k==3)
            {
                black=i;
                break;
            }
        }

        if(str[juhao-3]=='o'&&str[juhao-2]=='n'&&str[juhao-1]=='g')
        {
            A=1;
        }
        if(str[douhao-3]=='o'&&str[douhao-2]=='n'&&str[douhao-1]=='g')
        {
            B=1;
        }
        if(A&&B)
        {
            for(i=0;i<=black;i++)
                cout<<str[i];
            cout<<"qiao ben zhong."<<endl;
        }
        else
            cout<<"Skipped"<<endl;
    }

    return 0;
}

### 关于 PTA 团体程序设计天梯赛 L1 练习题的解答与资源 PTA(Programming Teaching Assistant)是一个在线编程评测平台,广泛用于高校的教学和竞赛训练。对于团体程序设计天梯赛中的L1级别题目,通常涉及基础算法、数据结构以及简单的逻辑推理[^1]。 以下是针对此类问题的一个通用解决方案框架: #### 输入处理 假设输入的第一行为列宽 \( N \) (\( N < 100 \)),第二行为待排版的字符串(长度不超过1000)。可以通过标准输入读取这些数据并存储到变量中[^2]。 ```python n = int(input()) # 列宽 text = input() # 待排版字符串 ``` #### 排版实现 为了完成古风排版功能,可以按照以下方式割字符串并将结果按指定宽度打印出来。这里提供了一个基于Python的语言示例。 ```python def format_text(text, n): result = [] while len(text) > n: line = text[:n] text = text[n:] # 如果最后一字为空格,则删除该空格 if line[-1].isspace(): line = line.rstrip() text = ' ' + text result.append(line) if text: # 添加剩余部 result.append(text) return result formatted_lines = format_text(text, n) for line in formatted_lines: print(line) ``` 此函数`format_text`接受两个参数:原始文本 `text` 和每行的最字符数 `n` 。它会逐步截取字符串直到其长度小于等于给定列宽为止,并妥善处理边界情况如单词间多余空白等问题。 #### 输出展示 最终输出将是重新格式化后的多行文字串列表形式,其中每一项代表新的一行内容。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值