博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Leetcode | Binary Tree Zigzag Level Order Traversal
阅读量:6279 次
发布时间:2019-06-22

本文共 1284 字,大约阅读时间需要 4 分钟。

Given a binary tree, return the zigzag level order traversal of its nodes' values. (ie, from left to right, then right to left for the next level and alternate between).

For example:

Given binary tree {3,9,20,#,#,15,7},
3
/ \
9 20
/ \
15 7
return its zigzag level order traversal as:
[
[3],
[20,9],
[15,7]
]

1 class Solution { 2 public: 3     void reverse(vector
&arr) { 4 for (int i = 0, j = arr.size() - 1; i < j; i++, j--) swap(arr[i], arr[j]); 5 } 6 7 vector
> zigzagLevelOrder(TreeNode *root) { 8 vector
> ans; 9 if (root == NULL) return ans;10 vector
> layers(2);11 vector
tmp;12 int cur = 0, next = 1;13 layers[cur].push_back(root);14 15 while (!layers[cur].empty()) {16 layers[next].clear();17 tmp.clear();18 for (auto node : layers[cur]) {19 if (node->left) layers[next].push_back(node->left);20 if (node->right) layers[next].push_back(node->right);21 tmp.push_back(node->val);22 }23 if (cur == 1) reverse(tmp);24 ans.push_back(tmp);25 cur = !cur, next = !next;26 }27 28 return ans;29 }30 };

 

转载于:https://www.cnblogs.com/linyx/p/4041405.html

你可能感兴趣的文章
数据库
查看>>
Vue------第二天(计算属性、侦听器、绑定Class、绑定Style)
查看>>
dojo.mixin(混合进)、dojo.extend、dojo.declare
查看>>
Python 数据类型
查看>>
iOS--环信集成并修改头像和昵称(需要自己的服务器)
查看>>
PHP版微信权限验证配置,音频文件下载,FFmpeg转码,上传OSS和删除转存服务器本地文件...
查看>>
教程前言 - 回归宣言
查看>>
PHP 7.1是否支持操作符重载?
查看>>
Vue.js 中v-for和v-if一起使用,来判断select中的option为选中项
查看>>
Java中AES加密解密以及签名校验
查看>>
定义内部类 继承 AsyncTask 来实现异步网络请求
查看>>
VC中怎么读取.txt文件
查看>>
如何清理mac系统垃圾
查看>>
企业中最佳虚拟机软件应用程序—Parallels Deskto
查看>>
Nginx配置文件详细说明
查看>>
怎么用Navicat Premium图标编辑器创建表
查看>>
Spring配置文件(2)配置方式
查看>>
MariaDB/Mysql 批量插入 批量更新
查看>>
ItelliJ IDEA开发工具使用—创建一个web项目
查看>>
solr-4.10.4部署到tomcat6
查看>>