题目概述:
给定一个长度不超过10000的、仅由英文字母构成的字符串。请将字符重新调整顺序,按GPLTGPLT…这样的顺序输出,并忽略其它字符。当然,四种字符(不区分大小写)的个数不一定是一样多的,若某种字符已经输出完,则余下的字符仍按GPLT的顺序打印,直到所有字符都被输出。
编程:
#include< iostream>
#include< string>
using namespace std;
int main()
{
char a[10000];
cin >> a;
int i = 0, q = 0, w = 0, e = 0, r = 0;
while (i <= strlen(a))
{
if (a[i] == ‘G’ || a[i] == ‘g’)
q++;
if (a[i] == ‘P’ || a[i] == ‘p’)
w++;
if (a[i] == ‘L’ || a[i] == ‘l’)
e++;
if (a[i] == ‘T’ || a[i] == ‘t’)
r++;
i++;
}
while (q >= 0 || w >= 0 || e >= 0 || r >= 0)
{
if (q >= 0) {
cout << “G”; q–;
}
if (w >= 0) {
cout << ‘P’; w–;
}
if (e >= 0) {
cout << ‘L’; e–;
}
if (r >= 0) {
cout << ‘T’; r–;
}
}
cout << endl;
}
上机实践:
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)