信息学奥赛一本通_1133_输出亲朋字符串

题目相关

【题目描述】

编写程序,求给定字符串s的亲朋字符串s1。
亲朋字符串s1定义如下:给定字符串s的第一个字符的ASCII值加第二个字符的ASCII值,得到第一个亲朋字符; 给定字符串s的第二个字符的ASCII值加第三个字符的ASCII值,得到第二个亲朋字符;依此类推,直到给定字符串s的倒数第二个字符。亲朋字符串的最后一个字符由给定字符串s的最后一个字符ASCII值加s的第一个字符的ASCII值。

【输入】

输入一行,一个长度大于等于2,小于等于100的字符串。字符串中每个字符的ASCII值不大于63。

【输出】

输出一行,为变换后的亲朋字符串。输入保证变换后的字符串只有一行。

【输入样例】

1234

【输出样例】

cege

来源

http://ybt.ssoier.cn:8088/problem_show.php?pid=1133

分析

遍历整个字符串s,设长度为len。新字符串的内容 s 1 [ i ] = s [ i ] + s [ i + 1 ] s1[i]=s[i]+s[i+1] s1[i]=s[i]+s[i+1]。最后一个字符 s 1 [ l e n − 1 ] = s [ l e n 1 − 1 ] + s [ 1 ] s1[len-1]=s[len1-1]+s[1] s1[len1]=s[len11]+s[1]。再次进行总结,其实能发现,若将字符串首尾连成环,新的字符串的内容等于当前位置与后一个的ASCII值相加的总和。s1[i]=s[i]+s[(i+1) % len ]

代码实现

#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;

int main()
{
	char s[105]={0},s1[105]={0};
	gets(s);
	int len=strlen(s);
	for(int i=0;i<len;i++){
		s1[i]=s[i]+s[(i+1)%len];
	}
	cout<<s1;
	return 0;
} 
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值