二维数组中的查找

在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。

时间限制:1秒 空间限制:32768K 热度指数:617731
本题知识点: 查找
 
思路:直接暴力查找即可,也可以二分。
class Solution {
public:
bool Find(int target, vector<vector<int> > array) {
for(int i=0;i<array.size();i++){
for(int j=0;j<array[i].size();j++)
if(target==array[i][j]) return true;
}
return false;
}
};

替换空格

请实现一个函数,将一个字符串中的空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。

时间限制:1秒 空间限制:32768K 热度指数:530285
本题知识点:字符串
 
思路:从后往前插入,先查找空格的个数,然后新字符串的长度即为原长度+2*空格个数。
class Solution {
public:
void replaceSpace(char *str,int length) {
char *ptr=str;///str所代表的即是字符串数组
int newlength=0,oldlength=strlen(str),numofblock=0;
while(*ptr){
if(*ptr==' ') numofblock++;
ptr++;
}
newlength=oldlength+2*numofblock;
while(oldlength<newlength){
if(str[oldlength]!=' ') str[newlength--]=str[oldlength--];
else{
oldlength--;
str[newlength--]='0';
str[newlength--]='2';
str[newlength--]='%';
}
}
}
};

从尾到头打印链表

输入一个链表,从尾到头打印链表每个节点的值

思路:使用栈来存储从头到尾的值,然后将栈中的值存入结果数组返回即可。
 
/**
* struct ListNode {
* int val;
* struct ListNode *next;
* ListNode(int x) :
* val(x), next(NULL) {
* }
* };
*/
class Solution {
public:
vector<int> printListFromTailToHead(ListNode* head) {
ListNode *p=head;
stack<int> temp;
vector <int > ans;
ans.clear();
while(p!=NULL){
temp.push(p->val);
p=p->next;
}
while(!temp.empty()){
ans.push_back(temp.top());
temp.pop();
}
return ans;
}
};

重建二叉树

输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。

思路:二叉树的前序遍历是访问根结点,前序遍历左子树,前序遍历右子树,因而前序遍历的第一个元素即为根结点,然后后面接着左子树,最后即为右子树;而中序遍历是先遍历左子树,再访问根结点,最后遍历右子树,即数组中根节点往前全部为左子树,往后全部为右子树。因而可以通过前序遍历确定根结点,通过已经确定的根结点来统计中序遍历里面左子树和右子树的数量,然后找出前序遍历中对应的左右子树。使用递归思想求解即可。

/**
* Definition for binary tree
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
TreeNode* reConstructBinaryTree(vector<int> pre,vector<int> vin) {
if (pre.empty() || vin.empty()) return NULL;
vector<int > pre_left,pre_right,vin_left,vin_right;
int val=pre[0],pos=0;
TreeNode *root=new TreeNode(val);
while(vin[pos]!=val) pos++;//找出根结点的位置
if(pos>vin.size()) return NULL;
for(int i=0;i<pos;i++){
vin_left.push_back(vin[i]);
pre_left.push_back(pre[i+1]);//存储左子树,由于前序遍历是先遍历左子树的,所以根结点后面跟着的即是左子树,数量跟中序遍历中的左子树相同,位置+1是因为第一个结点是根结点,故需要向后推一位
}
for(int i=pos+1;i<vin.size();i++){
vin_right.push_back(vin[i]);
pre_right.push_back(pre[i]);//存储右子树
}
root->left=reConstructBinaryTree(pre_left,vin_left);
root->right=reConstructBinaryTree(pre_right,vin_right);
return root;
}
};

用两个栈实现队列

用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。

思路:使用第一个栈存储,然后需要pop时将第一个栈的元素全部转入第二个栈中,此时第二个栈的栈顶元素即为所需元素,弹出后再将第二个栈中的元素全部转回第一个栈中即可。

class Solution
{
public:
void push(int node) {
stack1.push(node);
} int pop() {
while(!stack1.empty()){
int tmp=stack1.top();
stack1.pop();
stack2.push(tmp);
}
int ans=stack2.top();
stack2.pop();
while(!stack2.empty()){
int tmp=stack2.top();
stack2.pop();
stack1.push(tmp);
}
return ans;
} private:
stack<int> stack1;
stack<int> stack2;
};

旋转数组的最小数字

把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。 输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素。 例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。 NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。

思路:即找出输入数组中第一个比前一个数小的元素即可,如不存在比前一个元素小的元素,即数组中所有元素相同。

class Solution {
public:
int minNumberInRotateArray(vector<int> rotateArray) {
if(rotateArray.size()==0) return 0;
int ans=rotateArray[0];
for(int i=1;i<rotateArray.size();i++){
if(rotateArray[i]<rotateArray[i-1]) ans=rotateArray[i];
}
return ans;
}
};

  

 

剑指offer前6题的更多相关文章

  1. 浅谈《剑指offer》原题:不使用条件、循环语句求1+2+……+n

    转载自:浅谈<剑指offer>原题:求1+2+--+n 如侵犯您的版权,请联系:windeal12@qq.com <剑指offer>上的一道原题,求1+2+--+n,要求不能使 ...

  2. 《剑指offer》算法题第十二天

    今天是<剑指offer>算法题系列的最后一天了,但是这个系列并没有包括书上的所有题目,因为正如第一天所说,这些代码是在牛客网上写并且测试的,但是牛客网上并没有涵盖书上所有的题目. 今日题目 ...

  3. 《剑指offer》刷题目录

    <剑指offer>刷题目录 面试题03. 数组中重复的数字 面试题04. 二维数组中的查找 面试题05. 替换空格 面试题06. 从尾到头打印链表 面试题07. 重建二叉树 面试题09. ...

  4. 剑指offer 面试65题

    题目65题:不用加减乘除做加法. 解法一:Python特性 # -*- coding:utf-8 -*- class Solution: def Add(self, num1, num2): # wr ...

  5. 剑指offer部分编程题

    一 斐波那契数列 题目描述: 大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项. n<=39 问题分析: 可以肯定的是这一题通过递归的方式是肯定能做出来,但是这样会有 ...

  6. 《剑指offer》算法题第十天

    今日题目: 数组中的逆序对 两个链表的第一个公共节点 数字在排序数组中出现的次数 二叉搜索树的第k大节点 字符流中第一个不重复的字符 1. 数组中的逆序对 题目描述: 在数组中的两个数字,如果前面一个 ...

  7. JS数据结构与算法 - 剑指offer二叉树算法题汇总

    ❗❗ 必看经验 在博主刷题期间,基本上是碰到一道二叉树就不会碰到一道就不会,有时候一个下午都在搞一道题,看别人解题思路就算能看懂,自己写就呵呵了.一气之下不刷了,改而先去把二叉树的基础算法给搞搞懂,然 ...

  8. 《剑指Offer》附加题_用两个队列实现一个栈_C++版

    在<剑指Offer>中,在栈和队列习题中,作者留下来一道题目供读者自己实现,即"用两个队列实现一个栈". 在计算机数据结构中,栈的特点是后进先出,即最后被压入(push ...

  9. 剑指offer 面试5题

    面试5题: 题目:请实现一个函数,将一个字符串中的空格替换成“%20”.例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy. 方法一: # -*- co ...

随机推荐

  1. FastReport预览后直接邮件发送

  2. 关于python那些事儿

    学习总结: 1.输入一个数据 a=input. 2.在输出结果中增加字符 # 运行如下语句: print("你的名字叫{}.".format("饺子")) (以 ...

  3. 团队作业3——alpha阶段冲刺

    1.博客链接集合 敏捷冲刺1 敏捷冲刺2 敏捷冲刺3 敏捷冲刺4 敏捷冲刺5 敏捷冲刺6 敏捷冲刺7 测试随笔 冲刺总结随笔 2.项目git地址 git地址 3.项目成员贡献比例 成员 比例 张艺琳( ...

  4. spring Onions and wine

    Before and after the cold dew, the air is drier and the "autumn dryness" is vulnerable. Nu ...

  5. Python常用数据类型

    一 .列表 name = ['zhangshan', 'lishi', 'wangwu']# 列表赋值 name.append('liujun')# 增,默认增加到最后位置 name.insert(1 ...

  6. idea构建spark开发环境,并本地运行wordcount

    1.首先现在idea,官网:https://www.jetbrains.com/idea/ 2.安装jdk1.8,scala2.11 3.下载idea后,需要在idea中安装scala的插件,安装的方 ...

  7. springboot +redis配置

    springboot +redis配置 pom依赖 <dependency> <groupId>org.springframework.boot</groupId> ...

  8. 关于Hibernate级联更新插入信息时提示主键不为空的问题“org.hibernate.StaleStateException: Batch update returned unexpected row count from update: 0 actual row count: 0 expected: 1 ”

    org.hibernate.StaleStateException: Batch update returned unexpected row count from update: 0 actual ...

  9. 测序数据质控-FastQC

    通常我们下机得到的数据是raw reads,但是公司通常会质控一份给我们,所以到很多人手上就是clean data了.我们再次使用fastqc来进行测序数据质量查看以及结果分析. fastqc的操作: ...

  10. Python环境搭建遇到问题及解决方案记录

    pip版本问题 环境使用Ubuntu16.04 , 安装pip3 $sudo apt-get install python3-pip 默认安装pip8.1.1,更新后是18.1 $pip3 insta ...