小球荷兰国旗问题

荷兰vps  时间:2020-12-31  阅读:()

1 .问题描述

我们将乱序的红白蓝三色小球排列成有序的红白蓝三色的同颜色在一起的小球组。这个问题之所以叫荷兰国旗 是因为我们可以将红白蓝三色小球想象成条状物有序排列后正好组成荷兰国旗。

2.问题分析

这个问题我们可以将这个问题视为一个数组排序问题 这个数组分为前部 中部和后部三个部分每一个元素红白蓝分别对应0、 1 、 2必属于其中之一。 由于红、 白、蓝三色小球数量并不一定相同 所以这个三个区域不一定是等分的也就是说如果我们将整个区域放在[0, 1]的区域里 由于三色小球之间数量的比不同此处假设1 :2:2 可能前部为[0,0.2) 中部为[02,0 6)  后部为[06, 1] 。 我们的思路如下将前部和后部各排在数组的前边和后边 中部自然就排好了。具体的

设置两个标志位begin和end分别指向这个数组的开始和末尾 然后用一个标志位current从头开始进行遍历

1 若遍历到的位置为0 则说明它一定属于前部 于是就和begin位置进行交换然后current向前进 begin也向前进表示前边的已经都排好了 。

2若遍历到的位置为1  则说明它一定属于中部 根据总思路 中部的我们都不动然后current向前进。

3若遍历到的位置为2 则说明它一定属于后部 于是就和end位置进行交换 由于交换完毕后current指向的可能是属于前部的 若此时current前进则会导致该位置不能被交换到前部所以此时current不前进。而同1   end向后退1 。

//author:何佳

#include<iostream>usingnamespacestd;voidSwap(int*n1, int*n2) {inttemp;temp=*n1 ;

*n1=*n2;

*n2=temp;

}voidPrint(int*num, intlen)

{for(inti=0; i<len;++i)

{cout<<num[i]<<"";

}cout<<endl;

}

//0, 1,2, 1, 1,2,0,2, 1,0,2, 1,0,2,0, 1,2,0voidWork(int*num, intbegin, intend)

{intcur=begin;whi le(num[cur]==0)

{begin++;cur=begin;

}whi le(num[cur] !=2)

{cur++;

}while(cur!=end)

{if(num[cur]==2)

{

Swap(&num[cur] ,&num[end]) ;end--;

}if(num[cur] !=num[begin]&&num[cur] !=2) {Swap(&num[begin] ,&num[cur]) ;begin++;

}while(num[cur]==num[begin])

{cur++;

}

}if(num[end] !=2)

{

Swap(&num[cur] ,&num[begin]) ;

}

}intmain()

{intnum[]={0, 1,2, 1, 1,2,0,2, 1,0,2,0, 1,2,0, 1,2,0, 1, 1, 1,2, 1,2, 1, 1} ; int len=sizeof(num)/sizeof(int) ;

Print(num, len) ;

Work(num,0, len-1) ;

Print(num, len) ;

}

/*左飞C++数据结构与经典问题求解*/

/*荷兰国旗问题*/

/*众所周知荷兰国旗由红色、 白色和蓝色3中颜色组成现在假设有很多这3中颜色的线被存放在一个数字里 要求每次操作仅能进行一次交换 待对数字进行一遍扫描后 3中颜色自然分开颜色顺序应为红、 白、蓝。 另外 要求在O(n)的复杂度下使移动次数最小。

*/

#include<iostream>usingnamespacestd;constintN=15;intflag[N];intpre[N];intspl it1;intspl it2;intblue_red;intwhite_red;intcounts=0;

//输出结果voidPrint()

{for(inti=0;i<N;++i)

{cout<<flag[ i] ;

}cout<<endl;

}voidSwap(int&x, int&y)

{inttemp=x;x=y;y=temp;counts++;

}voidWork()

{for(inti=0;i<spl it1;++i)

{if(flag[i] !=0)

{if(blue_red>=spl it2)

{

Swap(flag[ i] ,flag[blue_red] ) ;blue_red=pre[blue_red];}else

{

Swap(flag[ i] ,flag[white_red] );white_red=pre[white_red];}

}

}intb=N-1;for(inti=spl it1;i<spl it2;++i)

{if(flag[i] !=1)

{whi le(flag[b]==2)b--;

Swap(flag[ i] ,flag[b]) ;b--;

}

}

}

//初始化voidInit( )

{intred_num=0;intwhite_num=0;intpreI=-1;for(inti=0;i<N;++i)

{flag[i ]=rand()%3;if(flag[i]==0)

{red_num++;pre[ i]=preI;preI=i;

}else if(flag[i]==1)

{white_num++;

}

}

//将国旗分成3中颜色区域

//0~spl it1-1(红),spl ite1~spl it2-1(白)  spl it2~N-1(蓝)spl it1=red_num;spl it2=red_num+white_num;blue_red=preI;inti=spl it2-1;whi le(flag[i] !=0) i--;//检查白色中有没有红色white_red=i;

}intmain()

{

Init();cout<<"原始 "<<endl ;

Print( ) ;

Work();cout<<"移动 "<<counts<<"次"<<endl;Print( ) ;return0;

}

RAKsmartCloud服务器,可自定义配置月$7.59

RAKsmart商家一直以来在独立服务器、站群服务器和G口和10G口大端口流量服务器上下功夫比较大,但是在VPS主机业务上仅仅是顺带,尤其是我们看到大部分主流商家都做云服务器,而RAKsmart商家终于开始做云服务器,这次试探性的新增美国硅谷机房一个方案。月付7.59美元起,支持自定义配置,KVM虚拟化,美国硅谷机房,VPC网络/经典网络,大陆优化/精品网线路,支持Linux或者Windows操作...

提速啦(900元/月),杭州BGP E5-2665/89*2 32核 48G 100G防御

提速啦的来历提速啦是 网站 本着“良心 便宜 稳定”的初衷 为小白用户避免被坑提速啦的市场定位提速啦主要代理市场稳定速度的云服务器产品,避免新手购买云服务器的时候众多商家不知道如何选择,妮妮云就帮你选择好了产品,无需承担购买风险,不用担心出现被跑路 被诈骗的情况。提速啦的售后保证提速啦退款 通过于合作商的友好协商,云服务器提供3天内全额退款,超过3天不退款 物理机部分支持当天全额退款提速啦提现 充...

PacificRack(19.9美元/年)内存1Gbps带vps1GB洛杉矶QN机房,七月特价优惠

pacificrack怎么样?pacificrack商家发布了七月最新优惠VPS云服务器计划方案,推出新款优惠便宜VPS云服务器采用的是国产魔方管理系统,也就是PR-M系列,全系基于KVM虚拟架构,这次支持Windows server 2003、2008R2、2012R2、2016、2019、Windows 7、Windows 10以及Linux等操作系统,最低配置为1核心2G内存1Gbps带宽1...

荷兰vps为你推荐
com域名空间域名解析,我是一个新手站长,我买了一个空间跟一个COM域名,空间自带一个2级域名,我想把这个COM域名绑定到空间上,咋么办?急急急!求大神帮我,我创建一个游戏论坛,也查不到资料,可以给20元,我的手机13685455534,谢谢asp虚拟空间ASP空间是什么意思?天津虚拟主机在天津哪个地方能买到较好的价格又实惠还可以送货上门的虚拟主机!美国免费虚拟主机哪有便宜的美国虚拟主机?246数据美国虚拟主机一年才40元http://246idc.com/host/长沙虚拟主机在长沙,哪个兼职网站最最可靠??沈阳虚拟主机网站慢想要换一个沈阳的双线机房双线虚拟主机双线虚拟主机说是比单线的好是吧?域名停靠域名停靠是什么啊? 谁能告诉我谢谢!域名邮箱域名是干什么的?域名邮箱和自己注册的邮箱有什么不一样吗?org域名org域名怎么样
个人虚拟主机 美国域名 3322免费域名 l5639 165邮箱 宁波服务器 网站木马检测工具 安徽双线服务器 最漂亮的qq空间 备案空间 免费asp空间申请 阿里云个人邮箱 广州主机托管 服务器托管价格 google搜索打不开 websitepanel 发证机构 美国服务器 byebyelove ddos攻击小组 更多