数据结构与算法分析-C语言描述学习笔记-至第一章

2021/11/15

缘起

今日起,学习数据结构与算法分析-C语言描述一书,此书作者为马克·艾伦·维斯(Mark Allen Weiss),由于个人水平有限,只能以类似于句读的方式对书中内容进行分析。之前,在下从未进行过有关类似数据结构与算法的系统学习。若在学习过程中,吾未能坚持,中途放弃,则希望后学引以为戒。切莫夸下海口,可尽早改行以免耽误终身。至于我,则会在试错和试探自己毅力的道路上继续前行,为各位预备改行的同僚打上一剂强心针。在此,以我面前的台灯和水杯作为见证。

----------------------分割线----------------------------以下为笔记内容-------------------------------------------------

出版者的话

本人认真阅读了出版者的话,对其中的相关内容进行了必要的思考,对其中的一些内容也有一些自己的思考。下面我将以段落的方式对其中的内容进行分析。
第一段
关键字:文艺复兴 自然科学 学术 美国信息技术
关键含义:其实意思比较浅显,对此我就不对内容进行详细分析了,这段主要告诉各位,世界上信息技术最好的是美国,作者用了独领风骚一词来形容。既然美国在这方面比较优秀,肯定有不少Classic教材,这第一段为后面详述翻译这一伟大的事业做了铺垫。
第二段
关键字:全球信息化 计算机产业 接轨
关键含义:此段核心概念为接轨,与国际接轨,可以看出作者的用心良苦。不过,仍旧有不少学校不愿意接轨。而且还要以一般的教学水平作为基础进行建轨,实在是勇气可嘉。令人敬佩。
剩余段落
剩余段落主要用来论述此套丛书的优秀与为什么值得一买和值得一看。内容简单,便不在赘述。

译者序

不知不觉就到了译者序,必须感谢译者,为我们这些英语水平一般,对原著只能瞻仰的学生提供学习的机会。熟话说,读一本好的书就是和大师对话,而译者就是我们和大师的桥梁。所以,这里以我的英语水平实在是没有资格对本书的翻译进行评价,只能报以感谢。在此感谢冯先生的工作。
主要内容
译者在序言中对本书的内容进行了一个简要的概括。本书主要围绕数据结构和算法分析来进行书写。我觉得本书的特点恰恰在于算法分析,对数据结构的实现进行算法分析,即给出数学上的直观,对于我们理解数据结构很是有帮助,但是学起来也不容易,这也是本书的难点所在、
值得注意的是,译者提到了本书涉及到的代码可以从互联网中下载到,但是遗憾的是我并没有在中译本中找到下载的地址。为此我决定去英文版中寻找一下。(饿了,吃饭)
网址并未找到,找到了一本习题解答。阿里云盘

我用阿里云盘分享了「Mark Allen Weiss - Algor...ley) - libgen.lc.pdf」,你可以不限速下载🚀
复制这段内容打开「阿里云盘」App 即可获取
链接:https://www.aliyundrive.com/s/R53Au4rHxX6

前言

前言主要分为目的,方法,内容概述等方面
作者在目的中告诉我们算法分析在当今社会的重要性,并嘱咐我们要多做练习。剩下的内容主要是说起来简单做起来难的东西,在此不做分析。

第1章 引论

在第一章中的主要内容是书的目的,离散数学和程序设计。离散数学之前本人并未接触过,作者纯粹是为难人,为了更好的贯彻落实本书的学习思想,我决定开始学习离散数学。

  1. 选择教材
    学习离散数学得选择一本好教材,经过再三比对,我决定选择《离散数学及其应用》这本书,由于囊中羞涩,所以我决定看英文原版,并配以有道词典。巧的很,离散数学的作者和C与指针的作者同名。
  2. 暂时没想好

引论有三个重点,即运行性能的重要性,本书中涉及到的数学知识,还有递归。
作者上来便抛出一个问题,即有N个数,确定其第k个最大者。作者将类似问题称为选择问题。

  1. 解释:此问题为排序问题,即第k大数是多少。
  2. 思路一:先排序在取值
  3. 思路二:先读k个元素,进行递减排序,那么当前读入的数据中,k位置的一定为第k大,然后将剩下的数据放到数组中,如果这个数据比k位的数据小,则忽略,否则将数据按照递减排序的方式放到数组正确位置,并将最后一个元素删除。

对于两种思路,明显思路二效率更高。下面我将对两种思路进行分别实现。
思路一
这里我会用冒泡排序法进行递减排序,为了保证解决的专业性,我将参考一些书籍对冒泡排序进行介绍。
Bubble Sort:冒泡排序,Bubble为气泡的意思。

  1. 遍历文件
  2. 交换相邻的两个元素,以符合排序的要求。
  3. 特点是实现容易,缺点为执行速度慢
    在这里插入图片描述
    这是冒泡排序的过程,画圆圈的字母表示在一次排序中作为右值和它左边的元素进行比较的元素
#include <stdio.h>
#include <stdlib.h>
typedef int Item;
#define key(A) (A)
#define less(A, B) (key(A) < key(B))
  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

LogosGe

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值