微软100题第4题

转载自:http://blog.csdn.net/luxiaoxun/article/details/7537605

主要技术含量在于vector的使用(可变尺寸数组)和栈的概念。

题目:输入一个整数和一棵二元树。从树的根结点开始往下访问一直到叶结点所经过的所有结点形成一条路径。打印出和与输入整数相等的所有路径。
例如输入整数22和如下二元树
                                            10
                                            /   \
                                           5   12
                                         /   \   
                                       4     7  
则打印出两条路径:10, 12和10, 5, 7。

分析:这是百度的一道笔试题,考查对树这种基本数据结构以及递归函数的理解。
当访问到某一结点时,把该结点添加到路径上,并累加当前结点的值。如果当前结点为叶结点并且当前路径的和刚好等于输入的整数,则当前的路径符合要求,把它打印出来。如果当前结点不是叶结点,则继续访问它的子结点。当前结点访问结束后,递归函数将自动回到父结点。因此我们在函数退出之前要在路径上删除当前结点并减去当前结点的值,以确保返回父结点时路径刚好是根结点到父结点的路径。我们不难看出保存路径的数据结构实际上是一个栈结构,因为路径要与递归调用状态一致,而递归调用本质就是一个压栈和出栈的过程。

参考代码:

[cpp] view plaincopy
  1. #include <iostream>  
  2. #include <vector>  
  3. using namespace std;  
  4.   
  5. struct Node  
  6. {  
  7.     int value;  
  8.     Node* left;  
  9.     Node* right;  
  10.     Node(){left=NULL;right=NULL;}  
  11.     Node(int v){value=v;left=NULL;right=NULL;}  
  12. };  
  13.   
  14. void findpath(Node* root,vector<int>& nodes,int sum)  
  15. {  
  16.     if(root == NULL) return;  
  17.     nodes.push_back(root->value);  
  18.     if(root->left == NULL && root->right == NULL)  
  19.     {  
  20.         if(root->value == sum)  
  21.         {  
  22.             for(int i=0;i<nodes.size();i++)  
  23.                 cout<<nodes[i]<<" ";  
  24.             cout<<endl;  
  25.         }  
  26.     }  
  27.     else  
  28.     {  
  29.         if(root->left != NULL)  
  30.         {  
  31.             findpath(root->left,nodes,sum-root->value);  
  32.         }  
  33.         if(root->right != NULL)  
  34.         {  
  35.             findpath(root->right,nodes,sum-root->value);  
  36.         }  
  37.     }  
  38.     nodes.pop_back();  
  39. }  
  40.   
  41. int main()  
  42. {  
  43.     Node *tmp ;  
  44.     Node* root = new Node(10);  
  45.     tmp = new Node(5);  
  46.     root->left = tmp ;  
  47.     tmp = new Node(12);  
  48.     root->right = tmp;  
  49.     tmp = new Node(4);  
  50.     root->left->left = tmp;  
  51.     tmp = new Node(7);  
  52.     root->left->right = tmp;  
  53.     vector<int> v;  
  54.     findpath(root,v,22);   
  55.     return 0;  

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/313333.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

相同类方法之间调用,注解失效的问题

问题&#xff1a; 在Spring管理的项目中&#xff0c;方法A使用了Transactional注解&#xff0c;试图实现事务性。但当同一个class中的方法B调用方法A时&#xff0c;会发现方法A中的异常不再导致回滚&#xff0c;也即事务失效了。 原因&#xff1a; Transactional是Spring提供…

[ASP.NET Core 3框架揭秘] 依赖注入:依赖注入模式

IoC主要体现了这样一种设计思想&#xff1a;通过将一组通用流程的控制权从应用转移到框架之中以实现对流程的复用&#xff0c;并按照“好莱坞法则”实现应用程序的代码与框架之间的交互。我们可以采用若干设计模式以不同的方式实现IoC&#xff0c;比如我们在前面介绍的模板方法…

微软100题第5题

转载自&#xff1a;http://blog.csdn.net/littlestream9527/article/details/8104731 http://blog.csdn.net/v_july_v/article/details/6370650 http://blog.csdn.net/insistgogo/article/details/7689297 下面&#xff0c;我试图用最清晰易懂&#xff0c;最易令人理解的思维…

大样本统计

题目描述 我们对 0 到 255 之间的整数进行采样&#xff0c;并将结果存储在数组 count 中&#xff1a;count[k] 就是整数 k 的采样个数。 我们以 浮点数 数组的形式&#xff0c;分别返回样本的最小值、最大值、平均值、中位数和众数。其中&#xff0c;众数是保证唯一的。 我们…

北京Dotnet分享会 || 精英论坛第三期

编者按&#xff1a;没有一成不变的定律&#xff0c;没有长久不衰的流行&#xff0c;更没有一劳永逸的侥幸&#xff0c;只有自己刻苦努力、脚踏实地、兢兢业业的学习和工作&#xff0c;才会成为这个社会永远不会被淘汰的中流砥柱。一、昨夜西风凋碧树昨夜西风凋碧树&#xff0c;…

一些技术方案

延迟队列&#xff1a; https://juejin.im/post/5b5e52ecf265da0f716c3203

Matlab生成棋盘格点图

转自zhouyelihua**http://blog.csdn.net/zhouyelihua/article/details/46674191** 在摄像机标定过程中常常需要打印棋盘格程序&#xff0c;还有就是在投影仪标定当中常常需要投射和投影仪相同分辨率的 <code class"language--matlab hljs matlab has-numbering" s…

微软开源微服务运行时Dapr,赋能云原生应用开发

Dapr 是一个可移植的、由事件驱动的 Serverless 运行时&#xff0c;用于跨云和边缘构建分布式应用程序。10月9日&#xff0c;正式以 MIT 协议开源。Dapr 使开发人员能够轻松地构建弹性、无状态和有状态的微服务&#xff0c;让它们在云和边缘位置上运行&#xff0c;并包含了开发…

缺失的第一个正数

题目描述 给定一个未排序的整数数组&#xff0c;找出其中没有出现的最小的正整数。 示例 1: 输入: [1,2,0] 输出: 3示例 2: 输入: [3,4,-1,1] 输出: 2示例 3: 输入: [7,8,9,11,12] 输出: 1说明: 你的算法的时间复杂度应为O(n)&#xff0c;并且只能使用常数级别的空间。 …

最大堆和最小堆

堆和栈的区别&#xff1a;一、堆栈空间分配区别&#xff1a;1、栈&#xff08;操作系统&#xff09;&#xff1a;由操作系统自动分配释放 &#xff0c;存放函数的参数值&#xff0c;局部变量的值等。其操作方式类似于数据结构中的栈&#xff1b;2、堆&#xff08;操作系统&…

认知的高度 = 人生的高度

大家好&#xff0c;我是Z哥。我们每个人&#xff0c;每天要和很多不同的人打交道。我相信下面的场景每个程序员都有遇到过&#xff0c;业务方在某个模块下新提出了一个功能&#xff0c;但是你希望做新功能之前先把这个模块的低质量代码重构一下。但是&#xff0c;不管你怎么摆事…

快乐数

题目描述 编写一个算法来判断一个数是不是“快乐数”。 一个“快乐数”定义为&#xff1a;对于一个正整数&#xff0c;每一次将该数替换为它每个位置上的数字的平方和&#xff0c;然后重复这个过程直到这个数变为 1&#xff0c;也可能是无限循环但始终变不到 1。如果可以变为…

Pthread

转自&#xff1a;http://blog.chinaunix.net/uid-21084809-id-2215376.html Outline - 1.线程特点 - 2.pthread创建 - 3.pthread终止 - 4.mutex互斥量使用框架 - 5.cond条件变量 - 6.综合实例 1. 线程特点 线程拥有自己独立的栈、调度优先级和策略、信号屏蔽字&#xff08;…

移除链表元素

题目描述 删除链表中等于给定值 val 的所有节点。 示例: 输入: 1->2->6->3->4->5->6, val 6 输出: 1->2->3->4->5解法 使用哑结点&#xff0c;只需要变更next指针即可。 /*** Definition for singly-linked list.* public class ListNode …

VSCode开发.NETCore项目入门(1)设置中文语言环境

安装VSCode最新地址&#xff1a;https://code.visualstudio.com/&#xff0c;下载后安装即可配置语言环境打开安装好的VSCode软件&#xff0c;可以看到刚刚安装的VSCode软件默认使用的是英文语言环境&#xff0c;如下图&#xff1a;使用快捷键【CtrlShiftP】来配置&#xff0c;…

char *c = abc和char c[]=abc

转自&#xff1a;http://blog.csdn.net/wallwind/article/details/7210474 char *c "abc"和char c[]"abc",前者改变其内 容程序是会崩溃的&#xff0c;而后者完全正确。 程序演示&#xff1a; 测试环境Devc 代码 运行结果 2293628 4199056 abc 2293624 22…

同构字符串

题目描述 给定两个字符串 s 和 t&#xff0c;判断它们是否是同构的。 如果 s 中的字符可以被替换得到 t &#xff0c;那么这两个字符串是同构的。 所有出现的字符都必须用另一个字符替换&#xff0c;同时保留字符的顺序。两个字符不能映射到同一个字符上&#xff0c;但字符可…

微软100题第11题

参照&#xff1a;http://blog.csdn.net/caryaliu/article/details/8107089 参照&#xff1a;http://blog.csdn.net/lalor/article/details/7626678 把二叉树看成一个图&#xff0c;父子节点之间的连线看成是双向的&#xff0c;我们姑且定义"距离"为两个节点之间的个…

.NET Core 3.0】框架之十三 || 部署攻略

本文有配套视频&#xff1a;https://www.bilibili.com/video/av58096866/?p9一、部署1、WIN_独立部署感谢群里&#xff08;白云&#xff09;小伙伴&#xff0c;博主 小淋科技 提出的方案(需要 netcore2.1 )&#xff0c;我竟然忽略了&#xff0c;该打该打&#xff0c;官档都读…

Python import以及os模块

转自&#xff1a;http://jianpx.iteye.com/blog/486466 http://blog.chinaunix.net/uid-27838438-id-4087978.html Import: 1. import 实际上是python虚拟机把当前的globals()和locals()传进__builtins__.__import__内置函数了&#xff0c;所以实际上干活的是那个__import__函…