面试题1:

题目描述:

  如下为类型CMyString的声明,请为该类型添加赋值运算符函数。
    class CMyString
    {
    public:
      CMyString(char* pData = NULL);
      CMyString(const CMyString& str);
      ~CMyString(void);

    private:
      char* m_pData;
    };

思路: 现代写法,传一个临时参数tmp,然后将tmp的m_pData值与this指针指向的值进行交换,就实现了运算符的重载。

  注:tmp出了作用域会自动调用析构函数释放,所以当tmp区域与this指向的为同一区域时,tmp释放,则this指针

  指向的区域也释放了,就会出现问题,所以需要加上条件(this!=&str)。

代码:

CMyString& CMyString::operator=(const CMyString& str)
{
   if (this != &str)
   {
    CMyString temp(str);     char* data = temp.m_pData;
    temp.m_pData = this->m_pData;
    this->m_pData = data;
  }
  return *this;
}
 

面试题3:

题目描述:

  在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
输入描述:
  array: 待查找的二维数组
  target:查找的数字
输出描述:
  查找到返回true,查找不到返回false

思路:从二维数组的左下角开始找,若当前位置比target小,则向右移;反之,向上移动。

代码:

class Solution
{
public:
bool Find(vector<vector<int> > array,int target)
{ int row =array.size(); //行
int col=array[].size(); //列
int x=row-; //横坐标
int y=; //纵坐标
while(x>= && y<col)
{
if(array[x][y]>target) //当前位置值>target,上移
x--;
else if(array[x][y]<target) //当前位置值<target,右移
y++;
else
return true;
}
return false;
}
};

面试题4:

题目描述:

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

思路:先计算空格个数,str原长及新长度,然后从后向前拷贝,避免内存覆盖

代码:

//假定length为系统规定字符串输出的最大长度,固定为一个常数
class Solution
{
public:
void replaceSpace(char *str,int length)
{
if(str==NULL||length<)//当str为空或最大长度非法,则返回
{
return;
}
int len=;//str的长度
int blank=;//空格的个数
int i=;
while(str[i]!='\0')
{
if(str[i++]==' ')
blank++;
len++;
}
int newlen=len+*blank;//str替换后新的长度
if(newlen>length)//新长度<系统分配的最大长度时,返回
return; //str的替换过程,从后向前拷贝
while(len>= && newlen>len)
{
if(str[len]!=' ')
str[newlen--]=str[len];
else
{
str[newlen--]='';
str[newlen--]='';
str[newlen--]='%';
}
len--;
}
}
};

面试题5:

题目描述:

  输入一个链表,从尾到头打印链表每个节点的值。
输入描述:
  输入为链表的表头
输出描述:
  输出为需要打印的“新链表”的表头

思路:递归,直至找到最后一个节点,进行打印。

代码:

/**
* struct ListNode {
* int val;
* struct ListNode *next;
* ListNode(int x) :
* val(x), next(NULL) {
* }
* };
*/
class Solution {
public:
vector<int> printListFromTailToHead(struct ListNode* head)
{
vector<int> tail;
if(head!=NULL)
{
if(head->next!=NULL)
tail=printListFromTailToHead(head->next);
tail.push_back(head->val);
}
return tail;
}
};

面试题6:

题目描述:

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

思路:前序遍历的第一个节点为根节点root,再根据中序遍历的结果,查找到中序遍历结果中与root值相等的位置index,

  则该值左边的为左子树的节点,右边的为右子树的节点。然后以左、右子树为子问题,递归调用函数重建子树。

代码:

/**
* Definition for binary tree
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
struct TreeNode* reConstructBinaryTree(vector<int> pre,vector<int> in)
{
int Size = in.size();//遍历这棵树的节点数
if(Size == ) //树为空
return NULL;
vector<int> preLeft, preRight, inLeft, inRight;
int val = pre[]; //根节点的值(前序遍历的第一个值)
TreeNode* node = new TreeNode(val);//构建根节点
int index = ;
for(index = ; index < Size; ++index)
{
if(in[index] == val) //在前序遍历结果中查找根节点值的位置
break;
}
for(int i = ; i < Size; ++i)
{
if(i < index)//在中序遍历结果中,在根节点前的值均为二叉树的左子树的值
{
//构建左子树
inLeft.push_back(in[i]);
preLeft.push_back(pre[i+]);
}
else if(i > index)
{
//构建右子树
inRight.push_back(in[i]);//Construct the right pre and in preRight.push_back(pre[i]);
}
}
//分为子问题,递归调用
node->left = reConstructBinaryTree(preLeft, inLeft);
node->right = reConstructBinaryTree(preRight, inRight);
return node;
}
};

面试题7:

题目描述:

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

思路: 两个栈实现一个队列,记两个栈分别为stack1、stack2。入队列操作,即为入栈stack1操作;

    而出队列可先将stack1中的数据全部push到stack2中,两次先进后出,使得stack2中数据顺

    序就是队列先进先出的顺序,然后再将stack2的top数据pop即可。

    但须注意的是:将stack1中数据push到stack2之前,徐判断stack2是否为空:

          1)若为空,则将stack1中数据全部push进来后在pop它的top数据。

          2)若stack2中原本就有数据,则需先将stack2中原有的数据先pop

代码:

class Solution
{
public:
void push(int node) //直接将数据入stack1,先进后出一次
{
stack1.push(node);
}
int pop()
{
if(stack2.empty())//若stack2为空,将stack1的数据全push进stack2中,先进后出二次(stcak2中的数据顺序为队列中的数据顺序)
{
while(!stack1.empty())
{
stack2.push(stack1.top());
stack1.pop();
}
}
int top=stack2.top();//保存stack2的顶部数据
stack2.pop();//将stack2中的顶部元素pop出去
return top;
}
private:
stack<int> stack1;
stack<int> stack2;
};
												

剑指Offer面试题1的更多相关文章

  1. 剑指Offer:面试题15——链表中倒数第k个结点(java实现)

    问题描述 输入一个链表,输出该链表中倒数第k个结点.(尾结点是倒数第一个) 结点定义如下: public class ListNode { int val; ListNode next = null; ...

  2. 剑指offer面试题3 二维数组中的查找(c)

    剑指offer面试题三:

  3. 剑指Offer——笔试题+知识点总结

    剑指Offer--笔试题+知识点总结 情景回顾 时间:2016.9.23 12:00-14:00 19:00-21:00 地点:山东省网络环境智能计算技术重点实验室 事件:笔试 注意事项:要有大局观, ...

  4. C++版 - 剑指offer之面试题37:两个链表的第一个公共结点[LeetCode 160] 解题报告

    剑指offer之面试题37 两个链表的第一个公共结点 提交网址: http://www.nowcoder.com/practice/6ab1d9a29e88450685099d45c9e31e46?t ...

  5. C++版 - 剑指offer 面试题23:从上往下打印二叉树(二叉树的层次遍历BFS) 题解

    剑指offer  面试题23:从上往下打印二叉树 参与人数:4853  时间限制:1秒  空间限制:32768K 提交网址: http://www.nowcoder.com/practice/7fe2 ...

  6. C++版 - 剑指offer 面试题39:判断平衡二叉树(LeetCode 110. Balanced Binary Tree) 题解

    剑指offer 面试题39:判断平衡二叉树 提交网址:  http://www.nowcoder.com/practice/8b3b95850edb4115918ecebdf1b4d222?tpId= ...

  7. Leetcode - 剑指offer 面试题29:数组中出现次数超过一半的数字及其变形(腾讯2015秋招 编程题4)

    剑指offer 面试题29:数组中出现次数超过一半的数字 提交网址: http://www.nowcoder.com/practice/e8a1b01a2df14cb2b228b30ee6a92163 ...

  8. C++版 - 剑指Offer 面试题39:二叉树的深度(高度)(二叉树深度优先遍历dfs的应用) 题解

    剑指Offer 面试题39:二叉树的深度(高度) 题目:输入一棵二叉树的根结点,求该树的深度.从根结点到叶结点依次经过的结点(含根.叶结点)形成树的一条路径,最长路径的长度为树的深度.例如:输入二叉树 ...

  9. C++版 - 剑指offer 面试题24:二叉搜索树BST的后序遍历序列(的判断) 题解

    剑指offer 面试题24:二叉搜索树的后序遍历序列(的判断) 题目:输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则返回true.否则返回false.假设输入的数组的任意两个 ...

  10. C++版 - 剑指Offer 面试题45:圆圈中最后剩下的数字(约瑟夫环问题,ZOJ 1088:System Overload类似)题解

    剑指Offer 面试题45:圆圈中最后剩下的数字(约瑟夫环问题) 原书题目:0, 1, - , n-1 这n个数字排成一个圈圈,从数字0开始每次从圆圏里删除第m个数字.求出这个圈圈里剩下的最后一个数字 ...

随机推荐

  1. webots自学笔记(二)节点与机器人建模

    原创文章,出自"博客园, _阿龙clliu" :http://www.cnblogs.com/clliu/ 上一次介绍了界面和一个简单的自由落体,然而在实际运用中,机器人的结构都是 ...

  2. 深度剖析Spark分布式执行原理

    让代码分布式运行是所有分布式计算框架需要解决的最基本的问题. Spark是大数据领域中相当火热的计算框架,在大数据分析领域有一统江湖的趋势,网上对于Spark源码分析的文章有很多,但是介绍Spark如 ...

  3. ThinkPhp框架:验证码功能

    Think\Verify类可以支持验证码的生成和验证功能. 为了显示这个验证码功能,第一要有控制器,再就是有方法,然后是显示的页面. 一.最简单的方式生成验证码 (1)我们还是继续在那个控制器编写方法 ...

  4. .NET Core项目从xproj+project.json向csproj迁移简介

    3月7日,微软发布了Visual Studio 2017 RTM,与之一起发布的还有.NET Core Runtime 1.1.0以及.NET Core SDK 1.0.0,尽管这些并不是最新版,但也 ...

  5. App对接支付宝移动支付功能

    前段时间看了下app对接支付宝移动支付的功能,并自己总结了下支付宝移动支付的实现流程 一.申请流程          前提是已有现成的应用. 1.  申请地址            https://b ...

  6. 学习一点Markdown的基本知识

    本文于2017年3月18日首发于LinkedIn,请参考链接 这个世界的进步是由一些"懒"的人推动的.今天讲的这个Markdown,其实也是因为一批厌倦了HTML的各种标签的语法, ...

  7. appledoc导出iOS代码文档的使用和问题详解(干货篇)

    appledoc导出iOS代码文档的使用和问题详解(干货篇) 1. 简单说一下背景和自己感受 背景: 项目好像突然黄了,公司让详细写项目代码的注释并且导出文档,弄完之后就要封版. 说实话:听到这个消息 ...

  8. JS中有关对象的继承以及实例化、浅拷贝深拷贝的奥秘

    一.属性的归属问题 JS对象中定义的属性和方法如果不是挂在原型链上的方法和属性(直接通过如类似x的方式进行定义)都只是在该对象上,对原型链上的没有影响.对于所有实例共用的方法可直接定义在原型链上这样实 ...

  9. TIME_WAIT 另一种解决方式 SO_LINGER

         被TIME_WAIT问题烦得不行,又发现了另一种解决方式,SO_LINGER.      对SO_LINGER解释最通用的自然是<UNP>,现摘录如下      SO_LINGE ...

  10. 直接在CMake项目中编译GoogleTest和GoogleMock作为项目的一部分

    直接在CMake项目中编译GoogleTest和GoogleMock作为项目的一部分 本文是关于如何将GoogleTest和GoogleMock在没有预先编译安装在机器的情况下,直接在项目中作为项目的 ...