首页
题库
公司真题
专项练习
面试题库
在线编程
面试
面试经验
AI 模拟面试
简历
求职
学习
基础学习课
实战项目课
求职辅导课
专栏&文章
竞赛
搜索
我要招人
发布职位
发布职位、邀约牛人
更多企业解决方案
AI面试、笔试、校招、雇品
HR免费试用AI面试
最新面试提效必备
登录
/
注册
牛客1610600号
2017-10-17 12:42
已编辑
北京航空航天大学 算法工程师
关注
已关注
取消关注
面完快手,一道问题求指教
我跪的那道算法题,我跪不瞑目
剑指offer里的:
按之字形顺序打印二叉树
因为原来没刷过这道题,经过思考后,觉得用一个队列和一个栈可以完成
虽然我的答案不对,但是面试官说可以用一个队列就能完成,用空指针判断每行是不是结束。。。。
我到现在还是不明白面试官的想法。。。。。大佬们请指教
提示
全部评论
推荐
最新
楼层
牛客2845888号
北京航空航天大学 算法工程师
写了一个程序,求大神看看 # -*- coding: UTF-8 -*-. class Node(object): """节点类""" def __init__(self, data = -1, lchild = None, rchild = None, isEmpty = 0): self.data = data self.lchild = lchild self.rchild = rchild self.isEmpty = isEmpty class BinaryTree(object): """树类""" def __init__(self): self.root = Node(isEmpty = 1) def add(self, data): """为树增加节点,建立二叉查找树""" node = Node(data) if self.root.isEmpty == 1: self.root = node else: treeNode = self.root while(1): if node.data <= treeNode.data: if treeNode.lchild == None: treeNode.lchild = node break else: treeNode = treeNode.lchild else: if treeNode.rchild == None: treeNode.rchild = node break else: treeNode = treeNode.rchild def printTree(self): """按之字形顺序打印二叉树""" if self.root == None: return myList = [] myList.append(self.root) flagForward = 0# 为0表示下一行逆序打印,为1表示下一行正序打印 numberNow = 1 numberNext = 0 while(1): # 表示在该行查找 if numberNow: # 总是将先放入的先打印出来 node = myList.pop(0) numberNow -= 1 print node.data, # 根据flagForward的值改变左右子树的打印数学 if flagForward: if node.rchild: myList.insert(numberNow, node.rchild) numberNext += 1 if node.lchild: myList.insert(numberNow, node.lchild) numberNext += 1 else: if node.lchild: myList.insert(numberNow, node.lchild) numberNext += 1 if node.rchild: myList.insert(numberNow, node.rchild) numberNext += 1 # 表示该行结束了 else: # 下一行变成该行 if numberNext: numberNow = numberNext numberNext = 0 # 正方向逆序 flagForward = ~flagForward # 表示树结束了 else: break def test(): 'Test the program.' arr = [5, 6, 1, 4, 2, 69, -1, 24] tree = BinaryTree() for item in arr: tree.add(item) # 5 # 1 6 # -1 5 69 # 2 24 print '按之字形顺序打印二叉树:' tree.printTree() if __name__ == "__main__": test()
点赞
回复
分享
发布于 2017-10-29 21:09
你们都有offer,只有我没有offer
某山村小学 Java
肯定是你没有 吃灯泡,吃辣椒那种绝技,
点赞
回复
分享
发布于 2017-09-25 18:12
zohar727
湖南科技大学 前端工程师
是不是要会双击666
点赞
回复
分享
发布于 2017-09-25 18:08
牛客269
字节跳动_字节跳动技术专家
public static void snakePrint(BinaryTreeNode root) { if(root == null) { return; } ArrayDeque<BinaryTreeNode> arrayDeque = new ArrayDeque(); arrayDeque.add(root); boolean flag = true; while(!arrayDeque.isEmpty()) { int size = arrayDeque.size(); if(flag) { for(int i=0;i<size;i++) { System.out.print(arrayDeque.peekFirst().value+" "); BinaryTreeNode tmp = arrayDeque.pollFirst(); if(tmp.left != null) { arrayDeque.addLast(tmp.left); } if(tmp.right != null) { arrayDeque.addLast(tmp.right); } } flag = flag ? false : true; } else { for(int i=0;i<size;i++) { System.out.print(arrayDeque.peekLast().value+" "); BinaryTreeNode tmp = arrayDeque.pollLast(); if(tmp.left != null) { arrayDeque.addLast(tmp.left); } if(tmp.right != null) { arrayDeque.addLast(tmp.right); } } flag = flag ? false : true; } } }
点赞
回复
分享
发布于 2018-06-03 15:05
牛客269
字节跳动_字节跳动技术专家
用一个双端队列,即可解决,设一个标记位,记录上一层的遍历顺序,下一层遍历的时候相反方向遍历即可,同时修改标记位。
点赞
回复
分享
发布于 2018-06-03 15:04
Jeff.D
Владимирский юридический институт 算法工程师
#include<cstdio> #include<cstdlib> #include<cmath> #include<ctime> #include<cstring> #include<cassert> #include<climits> #include<iostream> #include<sstream> #include<vector> #include<set> #include<map> #include<stack> #include<queue> #include<bitset> #include<algorithm> #include<iterator> #include<string> #include<tuple> #include<random> #include <chrono> using namespace std; struct TreeNode { int val; TreeNode* left; TreeNode* right; TreeNode(int x) : val(x), left(NULL), right(NULL) {} }; void zigzag(TreeNode* root) { vector<TreeNode*> pts; if (NULL == root) return; queue<TreeNode*> q; q.push(root); int num1 = 1, num2 = 0; TreeNode* cur = NULL; while (!q.empty()) { cur = q.front(); q.pop(); if (cur->left != NULL) { q.push(cur->left); num2++; } if (cur->right != NULL) { q.push(cur->right); num2++; } pts.push_back(cur); num1--; if (0 == num1) { pts.push_back(NULL); num1 = num2; num2 = 0; } } int n = pts.size(); int rev = 0; int i, j; i = -1; int mid, sum; while (i < n) { j = i + 1; while (j < n && pts[j] != NULL) j++; // reverse if (rev) { mid = i + (j - i) / 2; sum = i + j; for (int x=i+1; x<=mid; x++) swap(pts[x], pts[sum-x]); } rev = !rev; i = j; } for (i=0; i<n; i++) if (pts[i] != NULL) printf(" %d ", pts[i]->val); } int main() { TreeNode* root = new TreeNode(1); root->left = new TreeNode(2); root->right = new TreeNode(3); root->left->left = new TreeNode(4); root->right->left = new TreeNode(5); root->right->right = new TreeNode(6); zigzag(root); return 0; } 用普通的队列加标记即可实现。
点赞
回复
分享
发布于 2018-05-08 22:43
尘归空
华中科技大学 C++
楼主来一发面经~
点赞
回复
分享
发布于 2018-05-03 21:54
牛客2306883号
用doubly linked list实现队列,一个变量存当前层traverse方向,根据方向判断存取node的方向和顺序。。。
点赞
回复
分享
发布于 2018-02-17 12:05
简单的电脑
中国石油大学(北京) Java
关键一个队列不知道什么时候换向折返
点赞
回复
分享
发布于 2017-10-29 20:05
无聊刷刷题
University of Alaska Fairbanks Java
之字形一个队列完成?你倒是叫面试官说说怎么做啊。反正,我是不知道一个队列要怎么打之字形。
点赞
回复
分享
发布于 2017-10-29 18:31
牛客2845888号
北京航空航天大学 算法工程师
意思是上一层和下一层的数要分开,可以用两个变量numPrevious,numNext分别记录上一层和下一层在序列中的个数,numPrevious减1的时候numNext要加上对应的子数的个数,当numPrevious为0的时候表示该行结束了,如果numNext不为0就把numNext赋给numPrevious,如果为0就表示树结束了。
点赞
回复
分享
发布于 2017-10-29 18:05
天行键
华中科技大学 Java
队列可以反向迭代(java api)
点赞
回复
分享
发布于 2017-10-17 11:04
嘻希
宇宙大学 前端工程师
请问快手哪里投递
点赞
回复
分享
发布于 2017-09-29 09:41
我家的狗不咬人
山东大学 运营
你表演的啥绝活呀,兄弟?
点赞
回复
分享
发布于 2017-09-25 18:15
Jungggle
重庆大学 Java
感觉咋样啊
点赞
回复
分享
发布于 2017-09-25 18:15
husama
吉林大学 Java
都问些啥
点赞
回复
分享
发布于 2017-09-25 17:42
光头小强
清华大学 Java
面经呢???23333333333333
点赞
回复
分享
发布于 2017-09-25 17:31
暂无评论,快来抢首评~
相关推荐
01-22 10:36
已编辑
牛客运营
【牛客娘创作大赏】来生成牛客娘表情包,送牛币,送牛客娘周边
活动规则:你可以使用任何AI工具,生成牛客娘表情包,发送你的生成提示词+图片至本贴评论区,并将无水印原图发送至微信群。活动奖励:1、每张 可爱的牛客娘表情包,可获得 10牛币奖励(每人上限100张) ~2、点赞量最高的前xx个评论,送牛客娘马克杯,(每25个评论,赠送一个马克杯,最多赠送20个)牛客娘表情包交流群:生成示例: 这是牛客娘的形象,帮我用牛客娘的形象画一些ACM算法竞赛相关的表情包 需要的表情包有: 摸头 (安慰) 呵呵(冷笑的呵呵) 牛魔 牛啤(左手比大拇指,右手拿着啤酒) 这次一定 比心 不许TD 要给他迎头痛击 设计要求: 1.统一使用萌系风格。 2.表情生动和肢体动作丰富、...
Xuan2333:
没错没错就是我,牛客娘表情包的创作者,大家都可以自用哒awa (第5张“按住牛客娘开始思索”出自我的世界里的机械动力模组,我做这个表情包可是花了我1个多小时的时间啊qwq) 最后附上所有用过的素材图,希望大家喜欢awa
wow 将图片中的人物改成两手托腮,只显示头部照片,眼睛为星星眼,表情开心,并在下方附上文字“wow” Ciallo 将第二张图的人物做出第一张图的姿势并且要在身体各处还有五官和动作完全一致,不要改背景,高分辨率,最佳质量,并在下方加上和图片相符的文字“Ciallo!” 说不出话 生成这个任务面无表情,一脸犹豫,嘴角下垂,双手交叉在胸前,在中间加上一个带有一条斜杠的麦克风的表示闭麦的符号,并且在下面配上文字“说不出话” 按住牛客娘开始思索 将第二张图的人物进行修改,要求是有一只手按在人物的头上,人物的眼神灵动,手略有着急的轻微摆起,头部微微抬起,并将第一张图放在第二张图的下方,高品质,把这张图的下方的黑色部分加上文字“按住牛客娘开始思索”,字体与图片里展示的“牛客娘”这三个字的字体相一致 我也要WA吗 将第一张图的人物的头发,脸部和衣服改成第二张图的人物的,眼睛保持不变,脸上的汗保持不变,头发的长度修改为和图片的一致,脸上不要有红晕,眼睛里不要有高光,眼睛里只要纯灰色
查看图片
点赞
评论
收藏
分享
01-20 09:47
网易游戏_游戏研发工程师(准入职员工)
网易互娱内推,网易互娱内推码
网易**不管问你啥,记住一个话术原则小小的提醒下各位留子:**时不要直来直去有啥说啥;千万得多思考别说太满给自己留个思考或回旋的余地・1、被问 “有没有接触过网易的产品”(哪怕了解不多)别直接说 “没有”(容易显得缺乏兴趣)试试:“之前用过网易云音乐和网易新闻,对产品的界面设计和功能逻辑有过留意。虽然没有深入研究,但能感受到网易产品注重用户体验的特点,入职后会系统学习相关产品知识”・2、被问 “能接受高强度的项目加班吗”别勉强说 “没问题”(后续可能难以承受)试试:“我理解互联网行业项目推进时需要集中精力,在关键节点愿意配合团队加班。但也会注重提升工作效率,合理规划时间,尽量在正常工作时间完成...
点赞
评论
收藏
分享
01-14 14:28
门头沟学院 C++
女朋友拿了字节offer,我反而焦虑
女朋友最近拿到了字节的产品offer,作为男朋友,第一反应当然是替她开心,但开心过后,我自己却陷入了一种莫名的焦虑和失落,这就意味着我们要异地一段时间,而且她工作肯定会接触到很多优秀的人,我有点没安全感。我知道这样想不对,但就是控制不住自己,想听听大家的看法。(我还在找实习)
沉淀小子:
换位思考,你如果后续拿到了很好的offer,你女朋友会不会也担心你,爱到最后全凭良心。
找实习记录
点赞
评论
收藏
分享
01-03 18:14
商洛学院 算法工程师
找寒假实习,薪资没有要求,想学习经验
牛至超人:
您好,京东物流岗了解一下吗?负责精加工食品的端到端传输
点赞
评论
收藏
分享
01-20 10:56
首都经济贸易大学 管理咨询
豆包真正的对手不是DeepSeek,而是千问
AI应用的终极战场正在悄然到来。根据新京报发布的最新榜单,截至2025年11月,中国AI应用月活排名前三为豆包(2.72亿)、DeepSeek(1.63亿)和夸克(9546万),腾讯元宝以5305万位列第四。不过,真正的黑马却是来自阿里巴巴的千问。从2025年11月17日开启公测,上线一周下载量就突破了1000万,12月初月活增速位居全球第一;至12月中旬,月活已从3000万迅速攀升至4000万,短短一个月左右的时间,用户规模实现了数倍的增长。截至2026年1月15日,千问App的月活跃用户已正式突破1亿大关,仅次于豆包和DeepSeek。与此同时,阿里巴巴宣布千问全面接入淘宝、支付宝、高德等...
点赞
评论
收藏
分享
评论
点赞成功,聊一聊 >
点赞
收藏
分享
评论
提到的真题
返回内容
全站热榜
更多
1
...
实习产出怎么包装
2883
2
...
数据库出现慢查询怎么定位?
1627
3
...
29届Java后端
1317
4
...
滴滴lastweek,知无不言
1213
5
...
杭州有赞
900
6
...
麻了,跟不上天赋哥
880
7
...
Java还能入吗
780
8
...
12.30丰疆智能测试面经(base武汉)
770
9
...
校招黑话 萌新扫盲必备
764
10
...
考研失败春招求助
729
创作者周榜
更多
正在热议
更多
#
除了Java,最推荐学什么技术?
#
1749次浏览
55人参与
#
AI时代的工作 VS 传统时代的工作,有哪些不同?
#
2142次浏览
71人参与
#
你的landing期是如何度过的?
#
2208次浏览
42人参与
#
滴滴求职进展汇总
#
299110次浏览
2445人参与
#
秋招报数:你投了多少家公司?
#
148376次浏览
946人参与
#
机械制造面试点评
#
84036次浏览
471人参与
#
你觉得早上几点上班合适?
#
94361次浏览
353人参与
#
机械人与华为的爱恨情仇
#
147235次浏览
1030人参与
#
机械只有转码才有出路吗?
#
159427次浏览
1653人参与
#
我和mentor的爱恨情仇
#
102909次浏览
925人参与
#
你觉得mentor喜欢什么样的实习生
#
45513次浏览
989人参与
#
如何提高实习转正率?
#
80885次浏览
488人参与
#
实习期间如何提升留用概率?
#
231095次浏览
1788人参与
#
你觉得什么岗位会被AI替代
#
35313次浏览
236人参与
#
聊聊你的被动加班经历
#
8529次浏览
101人参与
#
秋招提前批,你开始投了吗
#
705862次浏览
8437人参与
#
面试常问题系列
#
268829次浏览
4687人参与
#
京东求职进展汇总
#
1138690次浏览
8519人参与
#
牛客十周岁生日快乐
#
207863次浏览
1937人参与
#
为了秋招你都做了哪些准备?
#
31503次浏览
532人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务