博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Leetcode题解学习笔记------第二章数组
阅读量:6474 次
发布时间:2019-06-23

本文共 1339 字,大约阅读时间需要 4 分钟。

代码2和代码3完全看不懂。。。该题就是查找重复元素以及设置重复次数。

 

在一个旋转过的有序数组中查找指定元素:(实际上就是一个二分查找问题,确定边界问题)

 

首先涉及到有序数组被旋转过了,你不用管它怎么旋转,怎样旋转。反正就是前面一段大,后面一段小。该题就是二分查找的边界确定问题。二分查找的时间复杂度怎么回是(log n)呢。

 

class Solution{

public:
int search(vector<int>& nums,int target){
int first=0;
int last=nums.size()-1;
int mid=(first+last)/2;
if(target=nums[mid])
return mid;
else{//start to search
if(nums[first]<nums[mid])//chose the bigger part
{
if(nums[first]<=target&&nums[mid]>target)
last=mid;
else
first=mid+1;
}
else{//chose the smaller part
if(nums[mid]<target&&target<=nums[last])
first=mid+1;
else
last=mid;
}
}
return -1;
}

 

};编译没通过,虽然我不知道为什么

 

变形:如果允许出现重复元素。实质就是nums[first]和nums[mid]之间的关系从上题的两种变为了三种。

代码略

寻找两个有序数组的中间元素:等价于寻找第K大的元素。

 

 

class Solution{

public:
double FindKth(const vector<int>& A,const vector<int>& B){
int total=A.size()+B.size();
//实质上就是寻找第K个元素
if(total%2==1)
return FindKth(A.begin(),m,B.begin(),n,total/2+1);
else
return (FindKth(A.begin(),m,B.begin(),n,total/2)+FindKth(A.begin(),m,B.begin(),n,total/2+1))/2;

 

}

private:
int FindKth(A,m,B,n,k){
//永远假定m小于等于n
if(m>n)
return FindKth(A,n,B,m,k);
//start to devide K into two parts
int ia=min(k/2,m); int ib=k-ia;
if(*(A+ia-1)<*(B=ib-1))
return FindKth(A+ia,m-ia,B,m,k-ia);
else if(*(A+ia-1)>*(B=ib-1))
return FindKth(A,m,B+ib,m-ib,k-ib);
else
return A[ia-1];

 

}

};

 

转载于:https://www.cnblogs.com/maowuyu-xb/p/6589930.html

你可能感兴趣的文章
TortoiseSVN 命令
查看>>
“云”技术和P2P技术有什么区别?
查看>>
Linux 查看某个端口号被哪个进程占用
查看>>
关于Java中基类构造器的调用问题
查看>>
国产ARM核心板推荐
查看>>
如何在电脑上录制游戏视频画面
查看>>
一文带你快速了解,python是如何解析XML文件
查看>>
JFinal快速体验-quickstart
查看>>
Android获取网络
查看>>
【有趣】这段java代码太古怪
查看>>
iTerm和Alfred 2的安装和使用
查看>>
OSPF简介
查看>>
关系型数据库和nosql数据库的区别
查看>>
Java中变量名命名的一些规定和规范
查看>>
给定一个链表,删除链表的倒数第 n 个节点(已知该结点存在),并且返回链表的头结点。...
查看>>
成都【猎人营】健身私教请还是不请?
查看>>
AJPFX关于java的依赖 关联 聚合的关系解释
查看>>
AJPFX详解jsp的九大内置对象和四大作用域
查看>>
redis 该端口,设置认证
查看>>
PHP header()生成文件
查看>>