重建二叉树
题目描述
- 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。
C++代码
/**
* 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)
{
int preLen = pre.size();
int vinLen = vin.size();
if(preLen==0 || vinLen==0 || preLen!=vinLen)
{
return NULL;
}
TreeNode *head = new TreeNode(pre[0]);
int index = 0;
vector<int>preLeft,preRight,vinLeft,vinRight;
for(int i = 0;i<vinLen;i++)
{
if(vin[i]==pre[0])
{
index = i;
break;
}
vinLeft.push_back(vin[i]);
}
for(int j = 1;j<=index;j++)
{
preLeft.push_back(pre[j]);
}
for(int k = index+1;k<vinLen;k++)
{
preRight.push_back(pre[k]);
vinRight.push_back(vin[k]);
}
head->left = reConstructBinaryTree(preLeft,vinLeft);
head->right = reConstructBinaryTree(preRight,vinRight);
return head;
}
};
用两个栈实现队列
题目描述
- 用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。
C++代码
class Solution
{
public:
void push(int node)
{
stack1.push(node);
}
int pop()
{
if(stack2.empty())
{
while(!stack1.empty())
{
int data = stack1.top();
stack1.pop();
stack2.push(data);
}
}
int value = stack2.top();
stack2.pop();
return value;
}
private:
stack<int> stack1;
stack<int> stack2;
};
旋转数组的最小数字
题目描述
- 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。 输入一个非减排序的数组的一个旋转,输出旋转数组的最小元素。 例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。 NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。
C++代码
class Solution {
public:
int minNumberInRotateArray(vector<int> rotateArray)
{
if(rotateArray.size()==0)
{
return 0;
}
int start = rotateArray[0];
int len = rotateArray.size();
for(int i = 1;i<len;i++)
{
if(rotateArray[i-1]>rotateArray[i])
{
return rotateArray[i];
}
}
return start;
}
};