数组的区间调整

 给定一个数组,比如{1,2,2,2,3,3,4,5,6,6,7,7,8,8,8,9};要求进行区间调整,该数组为有序数组,令左半部分为增序,右半部分可以无序

比如这个数组,排序后左半部分就是 1 2 3 4 5 6 7 8 9,右半部分则是否增序无所谓。

 思路:

   设置两个变量 u 和i  u初始为0   i初始为1

   我们假定a【0】到a【u】为左半区间,a【u+1】到a【i】为右半区间

   于是从左到右遍历

   此题中   当i=1   2不等于a[u]=a[0]=1时候,交换a[u]

#include <iostream>
#include <algorithm>
using namespace std;
double arr[]={1,2,2,2,3,3,4,5,6,6,7,7,8,8,8,9};
int len=16;

void fun1()
{
  int u=0;
  int i=1;
  //
  for(;i<len;i++)
  {
    if(arr[i]!=arr[u])
	{
	  u++;
	  swap(arr[i],arr[u]);
	}
  }


}
void Print()
{
  for(int i=0;i<len;i++)
	  cout<<arr[i]<<" ";
  cout<<endl;
}
int main()
{
  fun1();
  Print();
  return 0;
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值