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点点博客园博客,原文链接:http://www.cnblogs.com/coder2012/archive/2012/11/04/2753621.html,如需转载请自行联系原作者

## 01、数据介绍 数据整理全国30个省份制造业细分行业产值,能够反映一定时期内细分行业工业生产总规模和总水平的指标,是计算工业生产发展速度和主要比例关系、计算工业产品销售率等其他经济指标的基础。先进制造业数据可用于两业融合测算。 数据名称:全国30省-制造业细分行业产值/先进制造业细分行业产值数据 数据年份:2001-2022年 ## 02、数据指标 农副食品加工业;食品制造业;饮料制造业;烟草制造业;纺织业;纺织服装鞋帽制造业;皮革、毛皮、羽毛(绒)极其制品业;木材加工及木、竹、藤、棕、草制品业;家具制造业;造纸及纸制品业;印刷业和记录媒介的复制;文教体育用品制造业;石油加工、炼焦及核燃料加工业化;学原料及化学制品制造业;医药制造业;化学纤维制造业;橡胶和塑料制品制品业;非金属矿物制品业;黑色金属冶炼及压延加工业;有色金属冶炼及压延加工业;金属制品业;通用设备制造业;专用设备制造业;汽车制造业;其他运输设备制造业;电气机械及器材制造业;通信设备计算机及其他电子设备制造业;仪器仪表及文化、办公用机械制造业;其他制造业;废弃资源和废旧材料回收加工业;制造业总产值 印刷业和记录媒介的复制;石油加工、炼焦及核燃料加工业;化学原料及化学制品制造业;医药制造业;橡胶和塑料制品制品业;非金属矿物制品业;黑色金属冶炼及压延加工业;有色金属冶炼及压延加工业;金属制品业;通用设备制造业;专用设备制造业;汽车制造业;其他运输设备制造业;电气机械及器材制造业;通信设备计算机及其他电子设备制造业;仪器仪表及文化、办公用机械制造业;废弃资源和废旧材料回收加工业
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值