荷兰国旗问题

问题: 3种颜色(012)在一个数组里,每次只可交换一次,扫描一边后,三种颜色自然分开,应为颜色为:红,白,蓝,(荷兰国旗的颜色)所也叫荷兰国旗问题!

 代码:

#include <stdlib.h>
#include 
<iostream.h>

int  main()
{
     
int a[10
];
     
forint i=0 ; i<10 ; i++
 )
  
{
      a[i] 
= rand() % 3
;
      cout
<<a[i]<<' '
;     
     }

     cout
<<endl;
     
     
int first = 0
;
     
int end = 9
;
     
int mem = 0
;
     
     
while( first <=
 end )
  
{
        
if( a[first] == 0
 )
     
{
            
int temp =
 a[first];
            a[first] 
=
 a[mem];
            a[mem] 
=
 temp;
            mem
++
;
            first
++
;
        }

        
else if( a[first] == 1 )
        
{
             first
++
;
        }

        
else if( a[first] == 2 )
     
{
            
int temp =
 a[first];
            a[first] 
=
 a[end];
            a[end] 
=
 temp;
            end
--
;
        }

    }

    
    
return 0;
}

PS:这个解决办法是O(n)的!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值