郝纪


私信TA

用户名:dotcpp0732815

访问量:698

签 名:

等  级
排  名 2560
经  验 2186
参赛次数 0
文章发表 14
年  龄 0
在职情况 学生
学  校
专  业

  自我简介:

TA的其他文章

解题思路:先左移,再逆序,再转换大小写

我这个为什么提交91分啊,哪里有问题啊

注意事项:

参考代码:

#define _CRT_SECURE_NO_WARNINGS 1

#pragma warning (disable:6031)

#include<stdio.h>

#include<string.h>

/*

一个加密的字符串。(长度小于50且只包含大小写字母)

经过研究,小英发现了如下加密规律(括号中是一个“原文 -> 密文”的例子)

1.  原文中所有的字符都在字母表中被循环左移了三个位置(dec  -> abz)   

2.  逆序存储(abcd -> dcba )

3.  大小写反转(abXY -> ABxy)

*/

int main()

{

//1.定义数组

char a[50] = { 0 };


//2.获取字符

gets(a);

int len = strlen(a);


//3.循环右移

for (int i = 0; i < len; i++)

{

if (a[i] >= 'a' && a[i] <= 'z' || a[i] >= 'A' && a[i] <= 'Z')

{

a[i] += 3;

}

}


//4.逆序存储

for (int i = 0; i < len / 2; i++)

{

int temp = a[i];

a[i] = a[len - 1 - i];

a[len - 1 - i] = temp;

}


//5.大小写转换

for (int i = 0; i < len; i++)

{

if (a[i] >= 'a' && a[i] <= 'z')

{

a[i] = a[i] - 'a' + 'A'; // 小写转大写 

}

else if (a[i] >= 'A' && a[i] <= 'Z')

{

a[i] = a[i] - 'A' + 'a'; // 大写转小写

}

}

puts(a);

return 0;

}


 

0.0分

0 人评分

  评论区