设计一个尽可能高效的划分算法,满足|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)。

相关推荐
森焱森15 分钟前
水下航行器外形分类详解
c语言·单片机·算法·架构·无人机
QuantumStack2 小时前
【C++ 真题】P1104 生日
开发语言·c++·算法
写个博客3 小时前
暑假算法日记第一天
算法
绿皮的猪猪侠3 小时前
算法笔记上机训练实战指南刷题
笔记·算法·pta·上机·浙大
hie988944 小时前
MATLAB锂离子电池伪二维(P2D)模型实现
人工智能·算法·matlab
杰克尼4 小时前
BM5 合并k个已排序的链表
数据结构·算法·链表
.30-06Springfield4 小时前
决策树(Decision tree)算法详解(ID3、C4.5、CART)
人工智能·python·算法·决策树·机器学习
我不是哆啦A梦4 小时前
破解风电运维“百模大战”困局,机械版ChatGPT诞生?
运维·人工智能·python·算法·chatgpt
xiaolang_8616_wjl4 小时前
c++文字游戏_闯关打怪
开发语言·数据结构·c++·算法·c++20
small_wh1te_coder5 小时前
硬件嵌入式学习路线大总结(一):C语言与linux。内功心法——从入门到精通,彻底打通你的任督二脉!
linux·c语言·汇编·嵌入式硬件·算法·c