皮一下

题目:


将 “China” 译成密码,译码规律是:用原来字母后面的第 4 个字母代替原来的字母.

例如,字母 “A” 后面第 4 个字母是 “E”.”E” 代替 “A”。因此,”China” 应译为 “Glmre”。

样例输入:

China

样例输出:

Glmre

原题链接:加密 China

http://www.dotcpp.com/oj/problem1003.html

解题思路:

先定义 5 个 char 型变量,然后再分别加 4.

直接给出部分代码

	c1 += 4;  //用法等于 c1 = c1+ 4;
	c2 += 4;

参考代码:


先给一个 C++ 的错误代码,这里虽然能够被 AC (accept 通过),但其实是错的。

#include<iostream>
using namespace std;
int main()
{
	char c1 = 'C'; char c2 = 'h'; char  c3 = 'i'; char  c4 = 'n'; char  c5 = 'a';
	c1 += 4;
	c2 += 4;
	c3 += 4;
	c4 += 4;
	c5 += 4;
	cout << c1 << c2 << c3 << c4 << c5 << endl;
	return 0;
}

这里错在只有一种情况,如果 oj(Online Judge) 系统有多个检测点的话就无法通过。

修改一下就是正确代码

#include<iostream>
using namespace std;
int main()
{
	char c1, c2, c3, c4, c5;
	cin >> c1 >> c2 >> c3 >> c4 >> c5;
	c1 += 4;
	c2 += 4;
	c3 += 4;
	c4 += 4;
	c5 += 4;
	cout << c1 << c2 << c3 << c4 << c5 << endl;
	return 0;
}

本地测试结果如下图,这里测试了 3 次: 本地测试结果 大家都知道,我个人比较骚气,所以我试了一下,发现这个 oj 其实没有那么严格,就连下面的代码都可以通过。

#include<iostream>
using namespace std;
int main()
{
    cout <<"Glmre"<< endl;
    return 0;
}