当前位置: 首页> 游戏> 手游 > Z字形打印二叉树

Z字形打印二叉树

时间:2025/7/8 8:11:40来源:https://blog.csdn.net/Tlwhisper/article/details/139231816 浏览次数:0次

题目链接

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode(int x) : val(x), left(NULL), right(NULL) {}* };*/
class Solution {
public:vector<vector<int>> levelOrder(TreeNode* root) {vector<vector<int>> res;if(!root) return res;int flag = 0;queue<TreeNode*>que;que.push(root);while(!que.empty()){int n = que.size();vector<int>nums;while(n--){auto tem = que.front();que.pop();nums.push_back(tem->val);if(tem->left) que.push(tem->left);if(tem->right) que.push(tem->right);}if(flag % 2 == 1){reverse(nums.begin(),nums.end());}res.push_back(nums);flag++;}return res;}
};

选择排序

#include <iostream>
using namespace std;void selectionSort(int arr[], int n) {for (int i = 0; i < n-1; i++) {int minIndex = i;for (int j = i+1; j < n; j++) {if (arr[j] < arr[minIndex]) {minIndex = j;}}// 交换arr[i]和arr[minIndex]int temp = arr[i];arr[i] = arr[minIndex];arr[minIndex] = temp;}
}int main() {int arr[] = {64, 34, 25, 12, 22, 11, 90};int n = sizeof(arr)/sizeof(arr[0]);selectionSort(arr, n);cout << "Sorted array: \n";for (int i=0; i < n; i++) {cout << arr[i] << " ";}return 0;
}

冒泡排序

#include <iostream>
using namespace std;void bubbleSort(int arr[], int n) {for (int i = 0; i < n-1; i++) {for (int j = 0; j < n-i-1; j++) {if (arr[j] > arr[j+1]) {// 交换arr[j]和arr[j+1]int temp = arr[j];arr[j] = arr[j+1];arr[j+1] = temp;}}}
}int main() {int arr[] = {64, 34, 25, 12, 22, 11, 90};int n = sizeof(arr)/sizeof(arr[0]);bubbleSort(arr, n);cout << "Sorted array: \n";for (int i=0; i < n; i++) {cout << arr[i] << " ";}return 0;
}
关键字:Z字形打印二叉树

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: