| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 551 人关注过本帖
标题:很简单的一个排序,那位高手给出最高效的算法
只看楼主 加入收藏
arrow521521
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2009-11-3
结帖率:0
收藏
 问题点数:0 回复次数:7 
很简单的一个排序,那位高手给出最高效的算法
一个字符串,包含大小写和空格
使小写在最前面,大写在最后面,字符相对顺序不变
给出占用内存最少,时间复杂度最低的算法?
搜索更多相关主题的帖子: 算法 
2009-11-03 11:13
qlc00
Rank: 7Rank: 7Rank: 7
等 级:黑侠
威 望:2
帖 子:157
专家分:540
注 册:2007-11-26
收藏
得分:0 
用快速排序,分为三部分,一部分是小于Z的部分,一部分是小于z的部分还有一部分就是空格!

Anything is possible!
2009-11-03 11:17
arrow521521
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2009-11-3
收藏
得分:0 
回复 2楼 qlc00
这样会打乱字母的相对顺序啊~
2009-11-03 11:45
pywepe
Rank: 6Rank: 6
等 级:侠之大者
威 望:4
帖 子:296
专家分:483
注 册:2009-4-5
收藏
得分:0 
stl

java群
62635216
欢迎加入
2009-11-03 12:31
无诲今生
Rank: 8Rank: 8
来 自:桂林理工大学
等 级:蝙蝠侠
威 望:2
帖 子:373
专家分:726
注 册:2009-5-11
收藏
得分:0 
#include<iostream>
#include<string>
using namespace std;

class list{              //这是一个队列,用来存放字符
public:
    char ch;
    list *next;
    list()
    {
        next=NULL;
    }
};
void printA(list *tpp)
{
    for(list *pp=tpp->next;pp;pp=pp->next)
        cout<<pp->ch;
    cout<<endl;
}
void main()
{
    list *tpp,*tpp1,*temp11;
    char *a="asdDGJHfggfDDS dSDFFGDSsS";
    int i=1;
    list *tp=new list;          //一个队列,用来存放小写
    tp->ch='a';
    tpp=tp;
    list *tp1=new list;         //一个队列,用来存放大写
    tp1->ch='A';
    tpp1=tp1;
    while(a[i]!='\0')
    {
        if(a[i]>=97&&a[i]<=128)
        {
            list *temp1=new list;
            temp1->ch=a[i];
            tp->next=temp1;
            tp=temp1;
        }
        if(a[i]>=65&&a[i]<=96)
        {
            list *temp2=new list;
            temp2->ch=a[i];
            tp1->next=temp2;
            tp1=temp2;
        }
        i++;
    }
    tp->next=tpp1->next;           //把两个队列连起来
    list *temp2=new list;
    temp2->ch='\0';
    temp2->next=NULL;
    printA(tpp);
}

顺境逆境切莫止境,得意失意切莫在意。
2009-11-03 14:07
fuqingjun
Rank: 2
来 自:山东
等 级:论坛游民
帖 子:48
专家分:80
注 册:2009-11-2
收藏
得分:0 
回复 5楼 无诲今生
占用内存最少吗?

我是猪猪,我很想进步,寻志同道合者革命途中并肩行路!
2009-11-03 16:14
arrow521521
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2009-11-3
收藏
得分:0 
我把我写的发上来。我在想有没有在快点的算法。。。。。


void onSite(char pszArr[])
{
    int left = 1;
    int right = strlen(pszArr) - 1;
    int cnt;
    bool flag;
    do
    {
        flag = false;
        //小写字母往前
        for (int i = right; i >= left; i--)
        {
            if ((pszArr[i] & 96) == 96 && (pszArr[i-1] & 96) != 96)
            {
                char tmp;
                tmp = pszArr[i];
                pszArr[i] = pszArr[i - 1];
                pszArr[i - 1] = tmp;
                cnt = i;
                flag = true;
            }
            if (!flag)
            {
                cnt = left;
            }

        }
        left = cnt + 1;
        
        //大写字母往后
        for (i = left; i <= right; i++)
        {
            if ((pszArr[i] & 96) != 64 && (pszArr[i-1] & 96) == 64)
            {
                char tmp;
                tmp = pszArr[i];
                pszArr[i] = pszArr[i - 1];
                pszArr[i - 1] = tmp;
                cnt = i;
            }
        }
        right = cnt - 1;
    } while (left < right);
}
2009-11-04 19:36
快速回复:很简单的一个排序,那位高手给出最高效的算法
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.078174 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved