天梯赛前训练-2

前三道相信大家肯定之前就做过了,所以就不放代码了。

7-4 打印沙漏 (20 分)

这个题就是找规律:第i行有i个空格(从0开始数),然后符号就用数组预处理一下(我喜欢先存在数组里)。两个数组,a记录每行多少个字符,sum记录上半部分共有多少个字符(不包含一个字符的那一行)。总的字符就是2*sum[k]+1;所以最后一行要输出的就是n-2*sum[k]-1。

#include<bits/stdc++.h>
using namespace std;
int a[31];
int sum[31];
void get1()
{
	a[0]=1;
	for(int i=1;i<=30;i++) a[i]=a[i-1]+2;
} 
void get2()
{
	for(int i=1;i<=30;i++) sum[i]=sum[i-1]+a[i];
}
int main()
{
	get1();
	get2(); 
	int n;
	char ch;
	cin>>n;
	cin>>ch;
	int k;
	for(int i=1;i<=30;i++)
	{
		if(sum[i]*2+1>n) 
		{
			k=i-1;
			break;
		}
	}
	for(int i=0;i<k+1;i++)
	{
		for(int kong=0;kong<i;kong++) cout<<' ';
		for(int j=1;j<=a[k-i];j++)
		{
			cout<<ch;
		}
		printf("\n");
	}
	for(int i=1;i<=k;i++)
	{
		for(int kong=0;kong<k-i;kong++)	cout<<' ';
		for(int j=1;j<=a[i];j++) cout<<ch;
		cout<<endl;
	}
	cout<<n-2*sum[k]-1<<endl;
} 

7-5 A-B (20 分)

好像天梯赛的题很喜欢出带空格字符串,输入格式为:scanf("%[^\n]",s);

大概就是拿个数组去把s2出现过的字母记录一下。

#include<bits/stdc++.h>
using namespace std;
bool a[150];
int main()
{
	char s1[10001],s2[10001];
	scanf("%[^\n]",s1);
	char ch=getchar();
	scanf("%[^\n]",s2);
	int len1=strlen(s1);
	int len2=strlen(s2);
	for(int i=0;i<len2;i++)
	{
		a[(int)(s2[i])]=1;
	}
	for(int i=0;i<len1;i++)
	{
		if(a[(int)(s1[i])]==0) cout<<s1[i];
	}
 } 

7-6 敲笨钟 (20 分)

遍历字符串然后找到 “ , “ 和 “ . ” ,判断他们的前三个字符是不是ong。

然后遍历一遍字符串,把后面的改为"qiao ben zhong. " 当时因为这个句号浪费了一点时间。 

#include<bits/stdc++.h>
using namespace std;
int main()
{
	int t;
	cin>>t;
	char ch=getchar();
	while(t--)
	{
		char s[1000];
		scanf("%[^\n]",s);
		char ch1=getchar();
		int len=strlen(s);
		int t1=0,t2=0;
		for(int i=0;i<len;i++)
		{
			if(s[i]==',')
			{
				if(s[i-3]=='o'&&s[i-2]=='n'&&s[i-1]=='g') t1=1;
			}
			if(s[i]=='.')
			{
				if(s[i-3]=='o'&&s[i-2]=='n'&&s[i-1]=='g') t2=1;
			 } 
		}
		if(t1*t2)
		{
			int cnt=0,vis;
			for(int i=len-1;i>=0;i--)
			{
				if(s[i]==' ') cnt++;
				if(cnt==3)
				{
					vis=i;
					break;
				}
			}
			for(int i=0;i<=vis;i++) cout<<s[i];
			cout<<"qiao ben zhong."<<endl;
		}else{
			printf("Skipped\n");
		}
	}
 } 

7-7 前世档案 (20 分)

用l和r来表示范围 l到r,每遍历到一个字符范围就缩小一半,最后范围会被缩小到只有一个元素,就输出。然后这里面总元素个数是pow(2,n);

#include<bits/stdc++.h>
using namespace std;
int main()
{
	int n,m;
	cin>>n>>m;
	int k=pow(2,n);
	while(m--)
	{
		string s;
		cin>>s;
		int l=1,r=k;
		for(int i=0;i<n;i++)
		{
			int mid=l+r>>1;
			if(s[i]=='y') r=mid;
			if(s[i]=='n') l=mid+1;
		}
		cout<<l<<endl;
	 } 
 } 

7-8 这是二叉搜索树吗? (25 分)

二叉树没学,我不会。。 。

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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值