Problem Description
对于输入的每个字符串,查找其中的最大字母,在该字母后面插入字符串“(max)”。
Input
输入数据包括多个测试实例,每个实例由一行长度不超过100的字符串组成,字符串仅由大小写字母构成。
Output
对于每个测试实例输出一行字符串,输出的结果是插入字符串“(max)”后的结果,如果存在多个最大的字母,就在每一个最大字母后面都插入"(max)"。
Sample Input
abcdefgfedcba
xxxxx
Sample Output
abcdefg(max)fedcba
x(max)x(max)x(max)x(max)x(max)
解题思路:使用字符数组将一行的字符串存储起来,使用遍历来找出字符串中的最大值并记录下来,输出时将每个字符和最大字符相比,若相等就在后面输出指定字符串。
#include<stdio.h>
#include<string.h>
int main()
{
int i, len;
char max, arr[101];
while(~scanf("%s",arr))
{
len = strlen(arr);
max = arr[0];
for( i = 1; i < len; i++ )
{
if( max < arr[i] )
max = arr[i];
}
for( i = 0; i < len; i++ )
{
if( max == arr[i] )
printf("%c(max)",arr[i]);
else
printf("%c",arr[i]);
}
printf("\n");
memset(arr,'\0',len);
}
return 0;
}