天梯赛-- 敲笨钟

L1-3 敲笨钟 (20 分)

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

 字符串处理的时候可以记录一下需要处理的位置,这个题可以先找到,的位置   然后再判断该位置前面是否为ong 再判断末尾是否为ong 输出的时候可以记录一下倒数第三个空格的位置,然后把该位置前面的内容输出,后面就是qiao ben zhong 啦

#include<iostream>
using namespace std;

int main()
{
	int n;cin>>n;
	getchar();
	
	while(n--)
	{
		string s;getline(cin,s);
		int flag=0;
		for(int i=0;i<s.size();i++)
		{
			if(s[i]==',') 
			{
				flag=i;break;
			}
		}
		int ans=0,sum=0;
		for(int i=s.size() -1;i>=0;i--)
		{
			if(s[i]==' ') sum++;
			if(sum==3)
			{
				ans=i;break;
			}
		}
		int len=s.size();
		if(s[len-2]=='g'&&s[len-3]=='n'&&s[len-4]=='o')
		{
			if(s[flag-1]=='g'&&s[flag-2]=='n'&&s[flag-3]=='o')
			{
				for(int i=0;i<=ans;i++)
				{
					cout<<s[i];
				}
				cout<<"qiao ben zhong."<<endl;
			}
			else cout<<"Skipped"<<endl;
		}
		else cout<<"Skipped"<<endl;
	}
	
	
	
	return 0;
}

 

7-8 (15) 微博上有个自称“大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
### PTA团体程序设计天梯赛概述 PTA团体程序设计天梯赛是一项面向高校学生的编程竞赛活动,旨在通过团队协作的方式提升学生们的算法能力和编程水平[^3]。比赛通常会涉及基础的编程知识以及较为复杂的算法应用,参赛者需要具备扎实的数据结构和算法功底。 #### 比赛特点 - **难度布**:题目覆盖范围广泛,从简单的输入输出到复杂的数据结构操作均有涉及。例如,“L1-001 Hello World”属于入门级题目,主要考察基本语法掌握情况[^1]。 - **时间管理**:由于部题目耗时较长,合理配答题时间成为取得好成绩的关键因素之一。 #### 技术要点 对于某些特定类型的题目(如图遍历),可能需要用到高级数据结构比如邻接表来实现广度优先搜索(BFS)[^2]。以下是基于C语言的一个简单BFS模板: ```c #include <stdio.h> #include <stdlib.h> #define MAX_VERTICES 100 typedef struct Node { int vertex; struct Node* next; } Node; Node* adjList[MAX_VERTICES]; int visited[MAX_VERTICES]; void addEdge(int u, int v) { Node* newNode = (Node*)malloc(sizeof(Node)); newNode->vertex = v; newNode->next = adjList[u]; adjList[u] = newNode; } void BFS(int startVertex) { int queue[MAX_VERTICES], front = 0, rear = 0; queue[rear++] = startVertex; visited[startVertex] = 1; while(front != rear){ int currentVertex = queue[front++]; printf("%d ", currentVertex); for(Node* temp=adjList[currentVertex];temp!=NULL;temp=temp->next){ if(!visited[temp->vertex]){ queue[rear++]=temp->vertex; visited[temp->vertex]=1; } } } } ``` 此代码片段展示了如何构建并执行一次标准的广度优先搜索过程。 ### 学习建议 为了更好地准备此类赛事,可以参考历年真题解析视频或者文档资料,并积极参与在线练习平台上的模拟测试。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值