C++实现从数组到链表,从前序遍历到中序遍历

本文主要介绍了如何使用C++将数组转换为链表,并探讨了在preOrder函数中使用结构体构造函数和New方式创建链表的区别。作者发现直接用构造函数往往仅创建头节点,而New方式可以构造完整链表,邀请读者在评论区分享理解。
摘要由CSDN通过智能技术生成

从数组构造链表的资料比较少,大多数都是直接从控制台输入,故写下此文。重点在preOrder函数。

插入一个preOrder函数里面的一个疑问:直接用结构体的构造函数写的root往往只剩下头节点,而用New的方式却能够构造完整的链表,这是为什么呢?

如果你知道的话,欢迎你在评论区留言 :)

int main(void) {
	vector<int> nums1 = { 1,NULL, 2, 5 };
	vector<int> inorder_result;
	TreeNode *T;
	 
	T = preOrder(nums1, 0);  //构造代码
	cout << "前序列遍历输出: \n";
	preOderread(T); //前序列遍历输出

	cout << "\n 中序列遍历输出: \n";
	inorder_result = inorderTraversal(T); //数组改为中序列遍历的数组
	inOderread(inorder_result);//中序列遍历输出

	destroy(T);
	system("pause");
}

接下来是用到的主要函数文件,头函数在最后的部分

#include<iostream>
#include <vector>
#include "inorderTraversal.h"

using namespace std;
//中序遍历迭代函数
void inorder(TreeNode* root, vector<int> & a)
{
	if (root != N
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值