1.3一摞烙饼的排序

简介:

下面是我自己的解法

复制代码
/******************************
2012.11.4
yxd
******************************/
#include <iostream>
using namespace std;
/*******************************
这里存在一个问题,如果我们先找到
一组大->小的情况,接下来出现相同
大小的情况,我们应该把相同元素一
起倒置,否则的话下次到这个位置时
侯就会多一次倒置。
*******************************/
int changeNum(int E[],int i)
{
    int n=0;//记录需要倒置的个数
    while(E[i]>E[i+1])
    {
        ++n;
        i++;
        while(E[i]==E[i+1])//只有出现大->小的情况
                           //,才有机会到达这里
        {
            i++;
            n++;
        }
    }
    return n;
}
//简单的元素交换(首位互换,这里只采用了一个存储空间)
void exChange(int E[],int i,int j)
{
    for(i,j;i<j;i++,j--)
    {
        int t;
        t=E[i];
        E[i]=E[j];
        E[j]=t;
    }
}

void sort(int E[],int length)
{
    int m;//记录不交换的次数
    while (m!=(length-1))
    {
        m=0;//记录没有发生交换的次数,加入一趟下来没有发生交换,就表示完成交换了
        for(int i=0;i<length-1;i++)
            if(E[i]<=E[i+1])
            {    ++m;
                continue;
            }
            else
            {
                int n=changeNum(E,i);
                if(i>length)//防止越界
                    return;
                else
                    exChange(E,i,i+n);
                i+=n;
            }
    }
            
}

int main(int argc,char* argv[])
{
    int E[5]={3,4,5,2,1};
    sort(E,5);
    for(int i=0;i<5;i++)
        cout<<E[i]<<" ";

    return 0;
}
复制代码

晚上再给出时间复杂度吧,空间复杂度为0(1),这里我们只接住一个位置来交换元素。

书上的一部分内容还看不明白,但是感觉方法差不多,但是没有这种方法好。

知识共享许可协议
本文 由 cococo点点 创作,采用 知识共享 署名-非商业性使用-相同方式共享 3.0 中国大陆 许可协议进行许可。欢迎转载,请注明出处:
转载自:cococo点点 http://www.cnblogs.com/coder2012


相关文章
|
7月前
|
算法 搜索推荐 调度
排序的介绍
排序的介绍
|
6月前
|
算法 搜索推荐
排序篇(六)----排序小结
排序篇(六)----排序小结
21 0
|
8月前
|
搜索推荐 算法
排序实现
排序实现
42 0
|
8月前
排序进行曲-v4.0
排序进行曲-v4.0
|
8月前
|
搜索推荐
排序进行曲-v1.0
排序进行曲-v1.0
|
9月前
|
算法
排序(详解)下
排序(详解)
40 0
|
搜索推荐 算法 Java
六个排序比较
主要介绍六个排序比较
103 0

热门文章

最新文章