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

相关推荐
算AI4 小时前
人工智能+牙科:临床应用中的几个问题
人工智能·算法
我不会编程5555 小时前
Python Cookbook-5.1 对字典排序
开发语言·数据结构·python
owde6 小时前
顺序容器 -list双向链表
数据结构·c++·链表·list
第404块砖头6 小时前
分享宝藏之List转Markdown
数据结构·list
hyshhhh6 小时前
【算法岗面试题】深度学习中如何防止过拟合?
网络·人工智能·深度学习·神经网络·算法·计算机视觉
蒙奇D索大6 小时前
【数据结构】第六章启航:图论入门——从零掌握有向图、无向图与简单图
c语言·数据结构·考研·改行学it
A旧城以西6 小时前
数据结构(JAVA)单向,双向链表
java·开发语言·数据结构·学习·链表·intellij-idea·idea
杉之7 小时前
选择排序笔记
java·算法·排序算法
烂蜻蜓7 小时前
C 语言中的递归:概念、应用与实例解析
c语言·数据结构·算法
OYangxf7 小时前
图论----拓扑排序
算法·图论