简单编码
Time Limit: 1000 ms
Memory Limit: 65536 KiB
Problem Description
将一串文本译成密码,密码的规律是:
将原来的小写字母全部翻译成大写字母,大写字母全部翻译成小写字母,数字的翻译规律如下:
0——>9
1——>8
2——>7
3——>6
4——>5
5——>4
6——>3
7——>2
8——>1
9——>0
然后将所有字符的顺序颠倒。
将原来的小写字母全部翻译成大写字母,大写字母全部翻译成小写字母,数字的翻译规律如下:
0——>9
1——>8
2——>7
3——>6
4——>5
5——>4
6——>3
7——>2
8——>1
9——>0
然后将所有字符的顺序颠倒。
Input
输入一串文本,最大字符个数不超过100。
Output
输出编码后的结果。
Sample Input
china
Sample Output
ANIHC
Hint
Source
这道题尝试了包括strrev、reverse在内的多种函数,发现都是编译错误。strrev不是所有编译器都承认的函数,需要谨慎使用。
#include<stdio.h>
#include<string.h>
int main()
{
char a[100];
int i;
gets(a);
for( i=0; a[i]!='\0'; i++)
{
if(a[i]>='A'&&a[i]<='Z')
{
a[i]=a[i]+32;
}
else if(a[i]>='a'&&a[i]<='z')
{
a[i]=a[i]-32;
}
if(a[i]>='0'&&a[i]<='9')
a[i]='i'-a[i];
}
for(int i = strlen(a) - 1;i >= 0;i--)
printf("%c",a[i]);
printf("\n");
return 0;
}