1072:字母排列

1072: 字母排列

时间限制: 10 Sec   内存限制: 128 MB
提交: 0   解决: 0
[ 提交][ 状态][ 讨论版]

题目描述

编写一个程序,当输入不超过60个字符组成的英文文字时,计算机将这个句子中的字母按英文字典字母顺序重新排列,排列后的单词的长度要与原始句子中的长度 相同。例如:

    输入:

    THE PRICE OFBREAD IS ¥1 25 PER POUND

    输出:

    ABC DDEEE EFHIINO OP ¥1 25 PPR RRSTU

 并且要求只对A到Z的字母重新排列,其它字符保持原来的状态。

输入

输出

样例输入

 THE PRICE OFBREAD IS ¥1 25 PER POUND

样例输出

ABC DDEEE EFHIINO OP ¥1 25 PPR RRSTU


题目似乎挺简单的,不过一定要注意细节!我试了五六次才得到正确的排列结果……
思路清楚了,写的程序才能逻辑清晰。
二重循环,第一重循环首先判断是不是字母,不是就continue
第二重循环也要首先判断是不是字母,不是就continue,是的话就比较大小,按从小到大的顺序排列。
#include <iostream>
#include <string>
using namespace std;
int main(){
	string a;
	getline(cin,a,'\n');//读取方式,用cin的话以空格为字符串结束标志,无法读取整行
	int len = a.length();
	int i,j;
	for (i = 0; i < len; i++){
		if (a[i]<'A' || (a[i]>'Z'&&a[i]<'a') || a[i]>'z')
			continue;
		for (j = i+1 ; j<len; j++)
		{
			if (a[j]<'A' || (a[j]>'Z'&&a[j]<'a') || a[j]>'z')
				continue;
			if (a[i]>a[j]){
				char temp;
				temp = a[i];
				a[i] = a[j];
				a[j] = temp;
			}
		}
	}
	for (i = 0; i < len; i++)
		cout << a[i];
	system("pause");
	return 0;
}


评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值