算法设计分析----搞定考研代码题[部分院校]具体看自己院校考纲----目标院校考察只需要掌握这3种算法思想应该就可以搞定算法题
1.绪论-----渐进符号理解
定义太冗长,直接记通俗理解就行-------(O为上界,阶数越小越精确,Ω为下界,阶数越大越精确)。
1.分治法(例子:多数元素)
先分治,再合并;
向下分治,递归(终止条件:分解到最小情况未知,分不动了)
给定一个大小为 n 的数组 nums ,返回其中的多数元素。多数元素是指在数组中出现次数 大于 ⌊ n/2 ⌋ 的元素。
你可以假设数组是非空的,并且给定的数组总是存在多数元素。
示例 1:
输入:nums = [3,2,3]
输出:3
示例 2:
输入:nums = [2,2,1,1,1,2,2]
输出:2
//伪代码
func(nums)->int:
return getMajority(nums,0,nums.length-1)
if left == right :
return nums[left]
mid = left + (right-left)/2
leftMajority = getMajority(nums,left,mid)
rightMajority = getMajority(nums,mid+1,right)
if leftMajority == rightMajority :
return leftMajority
leftCount =0
rightCount =0
for i in nums[left,night]
if i == leftMajority:
leftCount++
else if i == rightMajority:
rightCount++
if leftCount > rightCount:
return leftMajority
else :
return rightMajority
源码部分
int majorityElement(int nums[],int numSize) {
return findMajorElenment(nums,0,numSize-1);
}
findMajorElenment(int nums[],int low,int high){
if(low == high){
return nums[low];
}
int mid = (high-low)/2 + low;
int left = findMajorElenment(nums,low,mid);
int right = findMajorElenment(nums,mid+1,high);
if(left == right){
return left;
}
int leftCount = findMajorCount(nums,left,low,mid);
int rightCount = findMajorCount(nums,right,mid+1,high);
return (leftCount>rightCount)?l