博客
关于我
Objective-C实现binary tree traversal二叉树遍历算法(附完整源码)
阅读量:793 次
发布时间:2023-02-17

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

Objective-C?????????

???????

?Objective-C?????????????TreeNode???????????????

@interface TreeNode : NSObject@property (nonatomic, strong) NSNumber *value;@property (nonatomic, strong) TreeNode *left;@property (nonatomic, strong) TreeNode *right;@end

???????

?????Preorder Traversal?

???????????????????????????????????

- (void)preorderTraversal:(TreeNode *)node {    if (node == nil) return;        // ????    NSLog(@"?????%d", node.value);        // ?????    if (node.left) {        [self preorderTraversal:node.left];    }        // ?????    if (node.right) {        [self preorderTraversal:node.right];    }}
?????Inorder Traversal?

?????????????????????????????????

- (void)inorderTraversal:(TreeNode *)node {    if (node == nil) return;        // ?????    if (node.left) {        [self inorderTraversal:node.left];    }        // ????    NSLog(@"?????%d", node.value);        // ?????    if (node.right) {        [self inorderTraversal:node.right];    }}
?????Postorder Traversal?

??????????????????????????????????

- (void)postorderTraversal:(TreeNode *)node {    if (node == nil) return;        // ?????    if (node.left) {        [self postorderTraversal:node.left];    }        // ?????    if (node.right) {        [self postorderTraversal:node.right];    }        // ????    NSLog(@"?????%d", node.value);}

????

????????????????????????????????

#import 
@interface TreeNode : NSObject@property (nonatomic, strong) NSNumber *value;@property (nonatomic, strong) TreeNode *left;@property (nonatomic, strong) TreeNode *right;@end@interface BinaryTreeTraversal : NSObject- (void)preorderTraversal:(TreeNode *)node;- (void)inorderTraversal:(TreeNode *)node;- (void)postorderTraversal:(TreeNode *)node;@end@implementation BinaryTreeTraversal- (void)preorderTraversal:(TreeNode *)node { if (node == nil) return; NSLog(@"?????%d", node.value); if (node.left) { [self preorderTraversal:node.left]; } if (node.right) { [self preorderTraversal:node.right]; }}- (void)inorderTraversal:(TreeNode *)node { if (node == nil) return; if (node.left) { [self inorderTraversal:node.left]; } NSLog(@"?????%d", node.value); if (node.right) { [self inorderTraversal:node.right]; }}- (void)postorderTraversal:(TreeNode *)node { if (node == nil) return; if (node.left) { [self postorderTraversal:node.left]; } if (node.right) { [self postorderTraversal:node.right]; } NSLog(@"?????%d", node.value);}@end

????????

?????????????????????????????????????????????

  • ?????????????????????????????????
  • ???????????????????????????????????
  • ??????????????????????????????????????

??????????????????????????????

转载地址:http://mdnfk.baihongyu.com/

你可能感兴趣的文章
node.js 配置首页打开页面
查看>>
node.js+react写的一个登录注册 demo测试
查看>>
Node.js中环境变量process.env详解
查看>>
Node.js安装与配置指南:轻松启航您的JavaScript服务器之旅
查看>>
Node.js的循环与异步问题
查看>>
Nodejs express 获取url参数,post参数的三种方式
查看>>
nodejs libararies
查看>>
nodejs npm常用命令
查看>>
NodeJS 导入导出模块的方法( 代码演示 )
查看>>
nodejs 的 Buffer 详解
查看>>
nodejs 读取xlsx文件内容
查看>>
nodejs 运行CMD命令
查看>>
nodejs-mime类型
查看>>
NodeJS、NPM安装配置步骤(windows版本)
查看>>
nodejs中Express 路由统一设置缓存的小技巧
查看>>
nodejs包管理工具对比:npm、Yarn、cnpm、npx
查看>>
NodeJs单元测试之 API性能测试
查看>>
nodejs图片转换字节保存
查看>>
nodejs字符与字节之间的转换
查看>>
NodeJs学习笔记001--npm换源
查看>>