题解 | #图片整理#

图片整理

http://www.nowcoder.com/practice/2de4127fda5e46858aa85d254af43941

题目的主要信息:

根据题意,把英语单词按照大小(ASCII码值从小到大)排列。

方法一:

用sort函数对str进行排序。

具体做法:

#include <iostream>
#include <string>
#include <algorithm>

using  namespace std;

int main(){
    string str;
    while(cin>>str)//可能有多组输入
    {
        sort(str.begin(),str.end());//排序
        cout<<str<<endl;
    }   
    return 0;
}

复杂度分析:

  • 时间复杂度:O(nlog2n)O(nlog_2n),sort排序用的快速排序。
  • 空间复杂度:O(1)O(1),只用了常数空间。

方法二:

通过查ASCII码表可知0-9,a-z,A-Z的ASCII码的范围是48-57,97-122,65-90,用一个大小为123的vector count来存储每个字符的个数。输出的时候遍历一遍count,即按照ASCII码大小遍历一遍,若当前ASCII码有字符则输出该字符,需要注意的是可能会有重复字符,因此需要重复输出至count为0。 alt

具体做法:

#include <iostream>
#include <string>
#include <vector>
#include <algorithm>

using  namespace std;

int main(){
    string str;
    vector<int> count(123,0);
    while(cin>>str)//可能有多组输入
    {
        for(int i=0;i<str.size();i++)
        {
            count[str[i]]++;//统计出现的次数
        }
        for(int i=0;i<count.size();i++)//按照ASCII码遍历
        {
            while(count[i]!=0)//需要重复输出
            {
                cout<<char(i);
                count[i]--;
            }
        }
        cout<<endl;
    }   
    return 0;
}

复杂度分析:

  • 时间复杂度:O(n)O(n),需要遍历一遍字符串。
  • 空间复杂度:O(1)O(1),只用了常数空间统计字符数量。
全部评论

相关推荐

整顿职场的柯基很威猛:这种不可怕,最可怕的是夹在一帮名校里的二本选手,人家才是最稳的。
点赞 评论 收藏
分享
10-09 00:50
已编辑
长江大学 算法工程师
不期而遇的夏天:1.同学你面试评价不错,概率很大,请耐心等待;2.你的排名比较靠前,不要担心,耐心等待;3.问题不大,正在审批,不要着急签其他公司,等等我们!4.预计9月中下旬,安心过节;5.下周会有结果,请耐心等待下;6.可能国庆节前后,一有结果我马上通知你;7.预计10月中旬,再坚持一下;8.正在走流程,就这两天了;9.同学,结果我也不知道,你如果查到了也告诉我一声;10.同学你出线不明朗,建议签其他公司保底!11.同学你找了哪些公司,我也在找工作。
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务