剑指offer第五章
剑指offer第五章
1.数组中出现次数超过一半的数
class Solution {
public:
int MoreThanHalfNum_Solution(vector<int> numbers)
{
int length=numbers.size();
int ans=;
if(numbers.empty())
return ;
sort(numbers.begin(),numbers.end());//排序
int midNum=numbers[length/];
int count=;//统计次数初始化
for(int i=;i<length;i++)
{
if(numbers[i]==midNum)
++count;//次数统计
}
if(count>length/)//进行判断,是否为要求
ans=midNum;
return ans;
}
};
class Solution {
public:
int MoreThanHalfNum_Solution(vector<int> numbers)
{
if(numbers.empty()) return ;
// 遍历每个元素,并记录次数;若与前一个元素相同,则次数加1,否则次数减1
int result = numbers[];
int times = ; // 次数
for(int i=;i<numbers.size();++i)
{
if(times == )
{
// 更新result的值为当前元素,并置次数为1
result = numbers[i];
times = ;
}
else if(numbers[i] == result)
{
++times; // 相同则加1
}
else
{
--times; // 不同则减1
}
}
// 判断result是否符合条件,即出现次数大于数组长度的一半
times = ;
for(int i=;i<numbers.size();++i)
{
if(numbers[i] == result) ++times;
}
return (times > numbers.size()/) ? result : ;
}
2.最小的k个数
class Solution {
public:
vector<int> GetLeastNumbers_Solution(vector<int> input, int k)
{
int length=input.size();
vector<int> ans;
if(input.empty()||k>length)
return ans;
sort(input.begin(),input.end());
for(int i=;i<k;i++)
ans.push_back(input[i]);
return ans;
}
};
3.连续子数组的最大和
{6,-3,-2,7,-15,1,2,2},连续子向量的最大和为8(从第0个开始,到第3个为止)。你会不会被他忽悠住?(子向量的长度至少是1) 
class Solution {
public:
int FindGreatestSumOfSubArray(vector<int> array)
{
if (array.empty())
return ;
int temp1 = array[], max = array[];
for (int i = ; i < array.size(); i++)
{
if (temp1 + array[i] > array[i])
temp1 += array[i];
else
temp1 = array[i];
if (temp1 > max)
max = temp1;
}
return max;
}
};
4.从1到n整数1出现的次数
class Solution {
public:
int numberOf1(int n)
{
int number=;
while(n)
{
if(n%==)
{
number++;
}
n=n/;
}
return number;
}
int NumberOf1Between1AndN_Solution(int n)
{
int number=;//参数初始化
for(int i=;i<=n;++i)
number+=numberOf1(i);
return number;
}
};
5.把数组排成最小的数
class Solution {
public:
static bool cmp(int a,int b){
string A="";
string B="";
A+=to_string(a);
A+=to_string(b);
B+=to_string(b);
B+=to_string(a);
return A<B;
}
string PrintMinNumber(vector<int> numbers) {
string answer="";
sort(numbers.begin(),numbers.end(),cmp);
for(int i=;i<numbers.size();i++){
answer+=to_string(numbers[i]);
}
return answer;
}
};
6.丑数
分析:所谓一个数m是另一个数n的因子,是指n能被m整除,也就是n%m==0
class Solution {
public:
bool IsUglyNumber(int number)
{
while(number%==)
number/=;
while(number%==)
number/=;
while(number%==)
number/=;
if(number==)
return true;
else
return false;
}
int GetUglyNumber_Solution(int index)
{
if(index<=)
return ;
int number=;
int uglyFound=;
while(uglyFound<index)
{
++number;
if(IsUglyNumber(number))
{
++uglyFound;
}
}
return number;
}
};
思路2:创建数组保存已经找到的丑数,用空间换时间
class Solution {
public:
int GetUglyNumber_Solution(int index) {
if(index<=)
return ;
int *pUglyNumber=new int[index];
pUglyNumber[]=;
int NextUglyIndex=;
int *pMutiply2=pUglyNumber;
int *pMutiply3=pUglyNumber;
int *pMutiply5=pUglyNumber;
while(NextUglyIndex<index)
{
int min=Min(*pMutiply2*,*pMutiply3*,*pMutiply5*);
pUglyNumber[NextUglyIndex]=min;
while(*pMutiply2*<=pUglyNumber[NextUglyIndex]) //当前最大丑数pUglyNumber[NextUglyIndex]
pMutiply2++;
while(*pMutiply3*<=pUglyNumber[NextUglyIndex])
pMutiply3++;
while(*pMutiply5*<=pUglyNumber[NextUglyIndex])
pMutiply5++;
NextUglyIndex++;
}
int ugly=pUglyNumber[index-];
delete[]pUglyNumber;
return ugly;
}
int Min(int a,int b,int c)
{
int min=a;
if(min>b)
min=b;
if(min>c)
min=c;
return min;
}
};
7.第一个只出现一次的字符
class Solution {
public:
int FirstNotRepeatingChar(string str)
{
if ( str.length() == )
return -;
unsigned int hashTime[] = {};
for(int i =;i<str.length();++i)
hashTime[str[i]]++;
for(int i =;i<str.length();++i)
{
if(hashTime[str[i]] == )
return i;
}
return -;
}
};
8.数组中的逆序对
class Solution {
public:
int InversePairs(vector<int> d) {
int r = ;
for(int i = ; i < d.size(); ++i){
for(int j = ; j < i; ++j) if(d[j] > d[i]) ++r;
}
return r;
}
};
class Solution {
public:
int InversePairs(vector<int> data)
{
int length=data.size();
if(length<=)
return ;
vector<int> copy;
for(int i=;i<length;i++)
copy.push_back(data[i]);
long long count=InversePairsCore(data,copy,,length-);
return count%;
}
long long InversePairsCore(vector<int> &data,vector<int> ©,int start,int end)
{
if(start==end)
{
copy[start]=data[start];
return ;
}
int length=(end-start)/;
long long left=InversePairsCore(copy,data,start,start+length);
long long right=InversePairsCore(copy,data,start+length+,end);
int i=start+length;
int j=end;
int indexcopy=end;
long long count=;
while(i>=start&&j>=start+length+)
{
if(data[i]>data[j])
{
copy[indexcopy--]=data[i--];
count=count+j-start-length; //count=count+j-(start+length+1)+1;
}
else
{
copy[indexcopy--]=data[j--];
}
}
for(;i>=start;i--)
copy[indexcopy--]=data[i];
for(;j>=start+length+;j--)
copy[indexcopy--]=data[j];
return left+right+count;
}
};
9.两个链表的第一个公共点
/*
struct ListNode {
int val;
struct ListNode *next;
ListNode(int x) :
val(x), next(NULL) {
}
};*/
class Solution {
public:
ListNode* FindFirstCommonNode( ListNode *pHead1, ListNode *pHead2) {
ListNode *p1 = pHead1;
ListNode *p2 = pHead2;
while(p1!=p2)
{
if(p1==NULL)
p1=pHead2;
else
p1=p1->next;
if(p2==NULL)
p2=pHead1;
else
p2=p2->next;
}
return p1;
}
};
剑指offer第五章的更多相关文章
- 剑指offer第七章&第八章
剑指offer第七章&第八章 1.把字符串转换成整数 将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数. 数值为0或者字符串不是一个合法的数值则返回0 输入描述: 输入一个字符串 ...
- 剑指offer第六章
剑指offer第六章 1.数字在排序数组中出现的次数 统计一个数字在排序数组中出现的次数.例如输入排序数组{1,2,3,3,3,3,4,5}和数字3,由于3在数组中出现了4次,所以输出4 分析:思路1 ...
- 剑指offer第四章
剑指offer第四章 1.二叉树的镜像 二叉树的镜像:输入一个二叉树,输出它的镜像 分析:求树的镜像过程其实就是在遍历树的同时,交换非叶结点的左右子结点. 求镜像的过程:先前序遍历这棵树的每个结点,如 ...
- 剑指offer第三章
剑指offer第三章 1.数值的整数次方 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. class Solution { public ...
- 《剑指Offer》第二章(一)题3-8
为春招实习做准备,记录一下<剑指Offer>里面的面试题 第二章 面试题3:数组之中的重复数字. 这个题吧,虽然不难,但是不知道为什么就是看了很久,可能很久没有做算法题了.最后面一句话说的 ...
- 《剑指Offer》第二章(一)题 9 -12
第二章 面试题9:用两个栈实现队列 题目:如面试题,给你两个栈, 实现队列的先进先出,即在队列头删除一个元素以及在队列的尾部添加一个元素 思路:这个题的分析感觉很巧妙,从一个具体的例子入手,找出其中的 ...
- 剑指offer—第三章高质量代码(o(1)时间删除链表节点)
题目:给定单向链表的头指针和一个节点指针,定义一个函数在O(1)时间删除该节点,链表节点与函数的定义如下:struct ListNode{int m_nValue;ListNode* m_pValue ...
- 剑指offer—第三章高质量的代码(按顺序打印从1到n位十进制数)
题目:输入一个数字n,按照顺序打印出1到最大n位十进制数,比如输入3,则打印出1,2,3直到最大的3位数999为止. 本题陷阱:没有考虑到大数的问题. 本题解题思路:将要打印的数字,看成字符串,不足位 ...
- 剑指offer—第三章高质量代码(数值的整数次方)
高质量的代码:容错处理能力,规范性,完整性.尽量展示代码的可扩展型和可维护性. 容错处理能力:特别的输入和处理,异常,资源回收. 规范性:清晰的书写,清晰的布局,合理的命名. 完整性:功能测试,边界测 ...
随机推荐
- IIS服务器管理学习
工欲善其事必先利其器 首先给服务器配上强力的软件,用于安全防护和监控. 公司服务器用的阿里云的ECS,已经有防护和监控了,之后又选择额外加了一个安全狗 为了监控服务器上系统的各项运行指标,又买了听云平 ...
- 使用idea引入注解@SpringBootApplication报错Cannot resolve symbol 'SpringBootApplication'
我在使用idea时,在类上使用注解@SpringBootApplication,但是一直报错. Cannot resolve symbol 'SpringBootApplication' 网络上有很多 ...
- mysql数据库优化课程---13、mysql基础操作
mysql数据库优化课程---13.mysql基础操作 一.总结 一句话总结:mysql复制表,索引,视图 1.mysql如何复制表? like select * 1.复制表结构 create tab ...
- ItemsControl的应用
ItemsControl是集合类控件的基类,如:ListBox.ComboBox.TreeView 所以,我们可以直接应用“ItemsControl”自定义我们“需要的”集合类型控件
- CAJ2PDF
该项目不成熟,很容易遇到转换失败的例子. https://github.com/JeziL/caj2pdf https://github.com/JeziL/caj2pdf/wiki caj2pdf ...
- Jqeury ajax 调用C#的后台程序
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="JQueryTest.aspx. ...
- 网关-zuul介绍 第一篇 网关解决的问题
基于网关,我们可以实现 限流,认证,监控,路由 等功能,这样说,我们可能觉得很生硬,那我们反过来推一下, 假如没有网关会怎么样?1 :客户端需要访问多个后端服务,则前端得存储多个后端的地址(ip+po ...
- LeetCode OJ:Number of Islands(孤岛计数)
Given a 2d grid map of '1's (land) and '0's (water), count the number of islands. An island is surro ...
- 本地如何搭建IPv6环境测试你的APP(转)
IPv6的简介 IPv4 和 IPv6的区别就是 IP 地址前者是 .(dot)分割,后者是以 :(冒号)分割的(更多详细信息自行搜索). PS:在使用 IPv6 的热点时候,记得手机开 飞行模式 哦 ...
- Python中常用的内值方法
1)min(2,4) ## 求最小值 2)max(2,4) ## 求最大值3)sum(range(1,100,2)) ## 求和4)枚举:返回 ...