【笔记】选择题笔记+数据结构笔记

文章目录

连通分量是极大连通子图

一个连通图的生成树是一个极小连通子图

无向图的邻接表中,第i个顶点的度为第i个链表中的结点数

邻接表和邻接矩阵对不同的操作各有优势。

最短路径算法:

  1. 单源最短路径
    已知图G=(V,E),我们希望找出从某给定的源结点S∈V到V中每个节点的最短路径
    Dijkstra算法复杂度 O ( n 2 ) O(n^2) O(n2)
  2. 全源最短路径
    任意两个节点之间的最短路径
    Floyd算法复杂度 O ( n 3 ) O(n^3) O(n3)

最小生成树Prim算法和Kruskal算法【O(mlogm)】
相关阅读资料

Prim算法通常以邻接矩阵作为储存结构。

时间复杂度在对数级别的时候,底数数字的改变对于整个时间复杂度没有影响

静态链表方便经常插入和删除

二叉排序树的中序序列才是有序的

二叉排序树左子树上的值均大于根节点的值,右子树的值均小于根节点的值【不仅仅是左孩子和右孩子】

新插入的关键字总是作为叶节点插入,叶节点不一定总是处于最底层

二叉排序树只有删除的是叶节点才能得到与原来一样的二叉排序树

2014 41

二叉树的带权路径长度(WPL)是二叉树中所有叶结点的带权路径长度之和。给定一棵二叉树T,采用二叉链表存储,结点结构为:

其中叶结点的weight域保存该结点的非负权值。设root为指向T的根结点的指针,请设计求T的WPL的算法,要求:(1)给出算法的基本设计思想; (2)使用C或C++语言,给出二叉树结点的数据类型定义; (3)根据设计思想,采用C或C++语言描述算法,关键之处给出注释。

方法一先序遍历

解决方法:考查二叉树的带权路径长度,二叉树的带权路径长度为每个叶子结点的深度与权值之积的总和,可以使用先序遍历或层次遍历解决问题。

(1)算法的基本设计思想基于先序递归遍历的算法思想是用一个static变量记录wpl,把每个结点的深度作为递归函数的一个参数传递,算法步骤如下:若该结点是叶子结点,那么变量wpl加上该结点的深度与权值之积,若该结点非叶子结点,那么若左子树不为空,对左子树调用递归算法,若右子树不为空,对右子树调用递归算法,深度参数均为本结点的深度参数加一;最后返回计算出的wpl即可。

(2)二叉树结点的数据类型定义如下:

c++ 复制代码
#include<stdio.h>
#include<stdlib.h>

typedef struct BiTiNode
{
int weight;
struct BiTiNode *lchild,*rchild;
}BiTiNode,*BiTree;
/**
二叉树数据结构定义
**/
int WPL(BiTree root){
	return wpl_PreOrder(root,1);
}
int wpl_PreOrder(BiTree root,int deep){
	static int wpl=0;
	//静态变量存储wpl 静态局部变量
	//作用域为这个函数
	
	//若为叶子结点
	if(root->left==NULL&& root->right==NULL)
	wpl+=deep*root->data;

	//若左子树不空,对左子树递归遍历
	if(root->left!=NULL)
		wpl_PreOrder(root->left,deep+1);
	
	//若右子树不空,对右子树进行递归遍历
	if(root->right!=NULL){
		wpl_PreOrder(root->right,deep+1);
	}
	return wpl;
}

在先序遍历的算法中,static 是一个静态变量,只在首次调用函数时声明wpl并赋值为0,以后的递归调用并不会使得wpl为0。考虑到历年真题算法答案通常都直接仅仅由一个函数构成,所以参考答案使用static而不是全局变量。

方法二

(1)算法的基本设计思想基于层次遍历的算法思想是使用队列进行层次遍历,并记录当前的层数,当遍历到叶子结点时,累计wpl;当遍历到非叶子结点时对该结点的把该结点的子树加入队列;当某结点为该层的最后一个结点时,层数自增1; 队列空时遍历结束,返回wpl。

(2)二叉树结点的数据类型定义

c++ 复制代码
int wpl_LevelOrder(BiTree root){
	BiTree q[MaxSize];
	int end1,end2;
	//end1 头指针,end2尾指针
	end1=end2=0;
	//头指针指向队头元素,尾指针指向队尾的后要给元素
	int wpl=0,deep=1;
	//初始化wpl和深度
	BiTree lastNode;
	//lastNode用来记录当前层的最后一个结点
	BiTree newlastNode;
	//newlastNode用来记录下一层的最后一个结点
	lastNode=root;
	//lastNode初始化为根结点
	newlastNode=NULL;
	//newlastNode初始化为空
	q[end2++]=root;
	///根节点入队
	while(end1!=end2){
		//层次遍历
		//若队列不空则循环
		BiTree t = q[end1++];
		//拿出队列中的头一个元素
		if(t->lchild==NULL&&t->rchild==NULL)
		wpl+=deep*t->weight;
		//若为叶子节点,统计wpl
		
		if(t->lchild!=NULL)
		{
		//若非叶子节点把左节点入队
			q[end2++] = t->lchild;
			newlastNode = t->lchild;
		}//并设下一层的最后一个结点为该结点的左节点
		if(t->rchild!=NULL)
		{
			q[end2++]=t->rchild;
			newlastNode=t->rchild;
		}
		if(t==lastNode){
		//结点为本层最后一个结点。更新lastNode;
			lastNode=newlastNode;
			deep+=1;
		}
		
	}
return wpl;
}

相关推荐
北京理工大学软件工程4 分钟前
代码随想录-C-笔记
笔记
小白探索世界欧耶!~36 分钟前
用iframe实现单个系统页面在多个系统中复用
开发语言·前端·javascript·vue.js·经验分享·笔记·iframe
Frank_refuel1 小时前
C++之内存管理
java·数据结构·c++
551只玄猫1 小时前
新编大学德语1第三版笔记 第3课Studentenleben
笔记·德语·外语·德语a1·德语笔记·自学德语·新编大学德语
菜鸟233号2 小时前
力扣343 整数拆分 java实现
java·数据结构·算法·leetcode
yuanmenghao2 小时前
自动驾驶中间件iceoryx - 内存与 Chunk 管理(三)
数据结构·c++·算法·链表·中间件·自动驾驶
老朋友此林2 小时前
React Hook原理速通笔记1(useEffect 原理、使用踩坑、渲染周期、依赖项)
javascript·笔记·react.js
茶猫_2 小时前
C++学习记录-旧题新做-链表求和
数据结构·c++·学习·算法·leetcode·链表
yuniko-n2 小时前
【牛客面试 TOP 101】链表篇(一)
数据结构·算法·链表·面试·职场和发展
王老师青少年编程2 小时前
信奥赛C++提高组csp-s之并查集(案例实践)1
数据结构·c++·并查集·csp·信奥赛·csp-s·提高组