第一章连通性问题-----algorithm in C 读书笔记
首先不得不吐槽一下翻译的质量,霍红卫。。。。你给我站出来,不打死你,只想问你一下,你当年四级过了吗?
- 问题描述
- 输入两个整数,代表两个节点,如果这两个整数没有建立连接(这包括直接连接和通过其他节点连接),那么我们就建立这两个节点之间的连接,否则,继续输入下一个节点
四个逐步改进的算法如下:
- //算法一
- #include <stdio.h>
- #define N 10
- int main(void)
- {
- int id[N];
- int t,i,p,q;
- //一定要初始化啊
- for(i=0;i<N;i++)
- {
- id[i] = i;
- }
- while( scanf("%d%d",&p,&q)==2 )
- {
- if( id[p]==id[q] )
- continue;
- t = id[p];
- for(i=0;i<N;i++)
- {
- if( id[i]==t )
- {
- id[i] = id[q];
- }
- }
- for(i=0;i<N;i++)
- {
- printf("%d\t",id[i]);
- }
- printf("\n");
- }
- return 0;
- }
这四个算法所使用的数据结构都是数组,算法一是把连接(包括直接连接和间接连接)在一起的整数所对应的数组元素都赋值为相同的值。
- //算法二
- #include <stdio.h>
- #define N 10
- int main(void)
- {
- int id[N];
- int i,j,p,q;
- for(i=0;i<N;i++)
- {
- id[i] = i;
- }
- while( scanf("%d%d",&p,&q)==2 )
- {
- //必须使用下面两次循环,否则当心陷入死循环
- for(i=p;id[i]!=i;i=id[i]);
- for(j=q;id[j]!=j;j=id[j]);
- if( i==j )
- continue;
- id[i] = j;
- for(i=0;i<N;i++)
- {
- printf("%d\t",id[i]);
- }
- printf("\n");
- }
- return 0;
- }
算法二采用的数据结构仍然是数组,但是逻辑上确实树的结构。我们首先根据输入的两个整数,分别找到其所在的树的根节点,然后检测两个节点所在的树的根节点是否相同,如果相同,就说明是同一棵树,否则就把这两个根节点连接起来。
- //算法三
- #include <stdio.h>
- #define N 10
- int main(void)
- {
- int id[N],sz[N];
- int p,q,i,j;
- for(i=0;i<N;i++)
- {
- id[i] = i;
- sz[i] = 1;
- }
- while( scanf("%d%d",&p,&q)==2 )
- {
- for(i=p;id[i]!=i;i=id[i]);
- for(j=q;id[j]!=j;j=id[j]);
- if( sz[i]<sz[j] )
- {
- id[i] = j;
- sz[j] += sz[i];
- }
- else
- {
- id[j] = i;
- sz[i] += sz[j];
- }
- printf("i=%d\nj=%d\n",i,j);
- for(i=0;i<N;i++)
- {
- printf("%d\t",sz[i]);
- }
- printf("\n");
- for(i=0;i<N;i++)
- {
- printf("%d\t",id[i]);
- }
- printf("\n");
- }
- return 0;
- }
算法三是在算法二的基础之上改进而来的,但是它添加了一个数据结构,记录以每个节点为根的树中的元素的个数。通过这个数据结构,每次都把小树连接到大树上,防止树的深度过深。
- //算法四
- #include <stdio.h>
- #define N 10
- int main(void)
- {
- int id[N];
- int sz[N];
- int p,q,i,j;
- //初始化
- for(i=0;i<N;i++)
- {
- id[i] = i;
- sz[i] = 1;
- }
- while( scanf("%d%d",&p,&q)==2 )
- {
- for(i=p;id[i]!=i;i=id[i])
- {
- id[i] = id[id[i]];
- }
- for(j=q;id[j]!=j;j=id[j])
- {
- id[j] = id[id[j]];
- }
- if( sz[i]<sz[j] )
- {
- id[i] = j;
- sz[j] += sz[i];
- }
- else
- {
- id[j] = i;
- sz[i] += sz[j];
- }
- printf("i=%d\nj=%d\n",i,j);
- for(i=0;i<N;i++)
- {
- printf("%d\t",sz[i]);
- }
- printf("\n");
- for(i=0;i<N;i++)
- {
- printf("%d\t",id[i]);
- }
- printf("\n");
- }
- return 0;
- }
算法四就是在算法三的基础之上又做了进一步的改进,将树的深度进一步的缩小。
第一章连通性问题-----algorithm in C 读书笔记的更多相关文章
- 《TCP/IP详解卷1:协议》第11章 UDP:用户数据报协议-读书笔记
章节回顾: <TCP/IP详解卷1:协议>第1章 概述-读书笔记 <TCP/IP详解卷1:协议>第2章 链路层-读书笔记 <TCP/IP详解卷1:协议>第3章 IP ...
- 《TCP/IP详解卷1:协议》第5章 RARP:逆地址解析协议-读书笔记
章节回顾: <TCP/IP详解卷1:协议>第1章 概述-读书笔记 <TCP/IP详解卷1:协议>第2章 链路层-读书笔记 <TCP/IP详解卷1:协议>第3章 IP ...
- Java 线程第三版 第一章Thread导论、 第二章Thread的创建与管理读书笔记
第一章 Thread导论 为何要用Thread ? 非堵塞I/O I/O多路技术 轮询(polling) 信号 警告(Alarm)和定时器(Timer) 独立的任务(Ta ...
- 连通性问题--Algorithms IN C读书笔记
近期在看<Algorithms IN C>这本书.刚開始看,读的是英文版的.感觉作者的叙述有点不太easy理解.就找了一本中文版的来看,发现还是看英文版的比較好.先看了第一章的大部分,后面 ...
- Java核心技术卷一基础知识-第3章-Java的基本程序设计结构-读书笔记
第3章 Java的基本程序设计结构 本章内容: 一个简单的Java应用程序 字符串 注释 输入输出 数据类型 控制流 变量 大数值 运算符 数组 本章主要讲述程序设计相关的基本概念(如数据类型.分支以 ...
- Javascript模式(第三章字面量与构造函数)------读书笔记
一 对象字面量 1.1对象字面量的语法 1,对象键值对哈希表,在其他的编程语言中称之为“关联数组”, 2 键值对里面的值,可以是原始类型也可以是其他类型的对象,称之为属性,函数称之为方法 3 自定义对 ...
- 《第一本docker书》第4章 使用docker镜像和仓库 读书笔记
docker最底端是一个引导文件系统,即bootfs. 第二层是root文件系统rootfs,位于引导文件系统之上. 在传统的Linux引导过程中,root文件系统会最先以只读的方式加载,当引导结束并 ...
- 《Java并发编程实战》第九章 图形用户界面应用程序界面 读书笔记
一.为什么GUI是单线程化 传统的GUI应用程序通常都是单线程的. 1. 在代码的各个位置都须要调用poll方法来获得输入事件(这样的方式将给代码带来极大的混乱) 2. 通过一个"主事件循环 ...
- 第11章 UDP:用户数据报协-----读书笔记
1.分片应用程序只关心IP数据报的长度,如果它超过MTU值,那么就要对数据包进行分片. 2.UDP首部字段图: (16位源端口号+16位目端口号+16位UDP长度+16位UDP校验和+数据) 3.UD ...
随机推荐
- P2472 [SCOI2007]蜥蜴(网络最大流)
P2472 [SCOI2007]蜥蜴 题目描述 在一个r行c列的网格地图中有一些高度不同的石柱,一些石柱上站着一些蜥蜴,你的任务是让尽量多的蜥蜴逃到边界外. 每行每列中相邻石柱的距离为1,蜥蜴的跳跃距 ...
- Git项目创建与提交
创建Git密钥: 1.生成密钥: 右键–>Git Bash Here:先输入ssh-keygen –t rsa –C "邮箱地址",注意ssh-keygen之间是没有空格的, ...
- 遍历GroupBox上的所有的textbox
foreach (Control c in groupBox1.Controls) { if (c is TextBox) { //这里写代码逻辑 } } 遍历的时候,需要用Control遍历: 如果 ...
- BZOJ3296: [USACO2011 Open] Learning Languages 并查集
Description 农夫约翰的N(2 <= N<=10,000)头奶牛,编号为1.. N,一共会流利地使用M(1<= M <=30,000)种语言,编号从1 .. M., ...
- cent os下搭建简单的服务器
作为常和网络打交道的程序员,经常会遇到需要服务器的场合,比如搭建一个web服务器,一个代理服务器,又或者一个小型的游戏服务器. 我时常和朋友一起玩一款叫我的世界的游戏,为了能够长期稳定地联机玩,所以特 ...
- MVC ---- 无法将类型"System.Data.EntityState"隐式转换为"System.Data.Entity.EntityState"
1.EF 5.0解决方法 先卸载EF:Uninstall-Package EntityFramework -Force 在安装EF5.0:Install-Package EntityFramework ...
- MVC扩展Url.Action方法解决复杂对象参数问题
1:问题描述 @Url.Action("Index", "Home", new { Key = "Key", Val = new { Nam ...
- 探秘AOP实现原理
可以这么说,AOP是基于动态代理实现的. 那么,这个过程是怎样的? 首先,我们有这样的一个Service类,它是被作为切面的一个类: public class Service implements U ...
- 【Jmeter】Linux(Mac)上使用最新版本Jmeter(5.0)做性能测试
本文我们一起来学习在Linux(Mac)上利用Jmeter进行性能测试并生成测试报告的方法. 环境准备 JDK 访问这个地址 [JDK11.01],根据实际环境下载一个JDK. Jmeter Jmet ...
- Linux服务器上监控网络带宽的18个常用命令和工具
一.如何查看CentOS的网络带宽出口 检查维护系统的时候,经常会要查看服务器的网络端口是多大的,所以需要用到Linux的一个命令. 如何查看CentOS的网络带宽出口多大?可以用下面的命令来查看. ...