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

相关推荐
yzx99101330 分钟前
基于 Q-Learning 算法和 CNN 的强化学习实现方案
人工智能·算法·cnn
亮亮爱刷题33 分钟前
算法练习-回溯
算法
眼镜哥(with glasses)1 小时前
蓝桥杯 国赛2024python(b组)题目(1-3)
数据结构·算法·蓝桥杯
int型码农6 小时前
数据结构第八章(一) 插入排序
c语言·数据结构·算法·排序算法·希尔排序
UFIT6 小时前
NoSQL之redis哨兵
java·前端·算法
喜欢吃燃面6 小时前
C++刷题:日期模拟(1)
c++·学习·算法
SHERlocked936 小时前
CPP 从 0 到 1 完成一个支持 future/promise 的 Windows 异步串口通信库
c++·算法·promise
怀旧,6 小时前
【数据结构】6. 时间与空间复杂度
java·数据结构·算法
积极向上的向日葵7 小时前
有效的括号题解
数据结构·算法·
GIS小天7 小时前
AI+预测3D新模型百十个定位预测+胆码预测+去和尾2025年6月7日第101弹
人工智能·算法·机器学习·彩票