设计一个尽可能高效的划分算法,满足|n1-n2|最小且|S1-S2|最大

已知由n(n>=2)个正整数构成的集合A ,将其划分成两个不相交的子集A1和A2,元素个数分别为n1和n2,A1和A2中元素之和分别为S1和S2。设计一个尽可能高效的划分算法,满足|n1-n2|最小且|S1-S2|最大。要求:

1)给出算法的基本设计思想。

2)根据设计思想,采用C或C++语言描述算法,关键之处给出注释。

3)说明你所设计算法的平均时间复杂度和空间复杂度。

思想:|n1-n2|最小且|S1-S2|最大,也就是说A1和A2中的元素个数尽可能接近,并且两个表中的元素差距尽可能大。也就意味着,元素尽可能相等,但是A1中元素尽可能小,A2中元素尽可能大。通过快速排序,可以将表划分成左表小,右表元素大的两个表。(块间有序,内部可以无序)。

划分后,i=(n/2)-1;向下取整,表示划分完成,且左表为0.....i,右表为i+1.........n-1)

i<(n/2)-1;向下取整,继续对右边进行处理

i>(n/2)-1;向下取整,继续对左边进行处理

代码:

复制代码
int divite(int A[],int n){
	int left=0,right=n-1;
	while(true){
		int low=left,high=righ;//用来记录开始时的left和right
		
		int pivot=A[left];//枢纽
		while(left<right){
			//处理右侧 
			while(left<righ&&A[righ]>=pivot){
				--righ;
			}
			A[left]=A[right]
			//处理左侧 
			while(left<righ&&A[left]<=pivot){
				++left;
		    }
		    A[righ]=A[left];
		} 
		A[left]=pivot;//处理枢纽 
		
			//看本次枢纽所在的情况
		if(left==n/2-1){
			break;
			} else if(left<n/2-1){
			left++;
		    right=high;
			}else{
			righ--;
		    left=low;
			}	
	}	
	return left;//划分完成,left为A1中最后一个元素 
}

时间复杂度O(n),空间复杂度O(1)。

相关推荐
灵感__idea3 小时前
Hello 算法:贪心的世界
前端·javascript·算法
澈2074 小时前
深入浅出C++滑动窗口算法:原理、实现与实战应用详解
数据结构·c++·算法
ambition202425 小时前
从暴力搜索到理论最优:一道任务调度问题的完整算法演进历程
c语言·数据结构·c++·算法·贪心算法·深度优先
cmpxr_5 小时前
【C】原码和补码以及环形坐标取模算法
c语言·开发语言·算法
qiqsevenqiqiqiqi5 小时前
前缀和差分
算法·图论
代码旅人ing5 小时前
链表算法刷题指南
数据结构·算法·链表
Yungoal5 小时前
常见 时间复杂度计算
c++·算法
不爱吃炸鸡柳6 小时前
单链表专题(完整代码版)
数据结构·算法·链表
CylMK6 小时前
题解:AT_abc382_d [ABC382D] Keep Distance
算法
Dfreedom.6 小时前
计算机视觉全景图
人工智能·算法·计算机视觉·图像算法