标题
转换排序
描述
输入一维字符数组str[N](N≤80),查找出其中小写字母并转换成大写字母,按下面方式排序:1、只对大写字母进行排序;2、其他字符原位保持不动;3、转换后的各大写字母由小到大排序。输出排序后的结果。
时间限制
1
内存限制
10000
类别
1
输入说明
输入一行字符数据str[N](N≤80)。
输出说明
格式输出:输出仅对转换后的大写字母排序结果,其他字符原位不动输出。
输入样例
xA3T7p
输出样例
AP3T7X
提示
注意转换方式和排序要求。
代码:(运用了从其他博主那里新学到的gets()和puts()函数,很nice)
#include<stdio.h>
int main()
{
char a[80];
gets(a);
int n,t;
int i,j;
i = j = 0;
while(a[i]!='\0')
{
if(a[i]>='a'&&a[i]<='z')
{
a[i] = a[i] - 32;
}
i++;
}
n = i;
for(i=0;i<n-1;i++)
{
if(a[i]>='A'&&a[i]<='Z')
{
for(j=i+1;j<n;j++)
{
if(a[j]>='A'&&a[j]<='Z')
{
if(a[i]>a[j])
{
t = a[i];
a[i] = a[j];
a[j] = t;
}
}
}
}
}
puts(a);
}