祸梦 2022-01-03 22:03 采纳率: 100%
浏览 301
已结题

PTA 英文单词排序 为什么我的代码过不了

本题要求编写程序,输入若干英文单词,对这些单词按长度从小到大排序后输出。如果长度相同,按照输入的顺序不变。

输入格式:
输入为若干英文单词,每行一个,以#作为输入结束标志。其中英文单词总数不超过20个,英文单词为长度小于10的仅由小写英文字母组成的字符串。

输出格式:
输出为排序后的结果,每个单词后面都额外输出一个空格。

输入样例:

blue
red
yellow
green
purple
#

输出样例:

red blue green yellow purple 

我的代码

#include <bits/stdc++.h>
#define LL long long
using namespace std;
bool cmp(string a,string b)
{
    return a.length() < b.length();
}
int main()
{
    string a[50];
    int n = 0;
    while(cin >> a[n])
    {
        if(a[n][0] == '#')
        {
            break;
        }
        n++;
    }
    sort(a,a+n,cmp);
    for(int i = 0;i < n;i++)
        cout << a[i] << " ";
    return 0;
}

img

  • 写回答

1条回答 默认 最新

  • 神仙别闹 2022-01-03 22:08
    关注

    sort排序不稳定,对于相等的情况不能保证保持原顺序。

    
    #include <bits/stdc++.h>
    using namespace std;
    string s[21];
    int main() {
        string a;
        int h=0;
        while (1)
        {
            cin>>a;
            if(a=="#")break;
            s[h]=a;
            h++;
        }
        int c=h;
        while(c--)
        {
            for (int j = 1; j < h; ++j) {
                if(s[j-1].length()>s[j].length())
                    swap(s[j],s[j-1]);
            }
        }
        for (int i = 0; i < h; ++i) {
            cout<<s[i]<<" ";
        }
        return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 1月11日
  • 已采纳回答 1月3日
  • 创建了问题 1月3日

悬赏问题

  • ¥20 用HslCommunication 连接欧姆龙 plc有时会连接失败。报异常为“未知错误”
  • ¥15 网络设备配置与管理这个该怎么弄
  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?