数据结构与算法设计
㈠ 数据结构和算法有什么关系数据结构就是算法吗
首先你要弄清楚数据结构是什么?数据结构呢其实就是一种存储数据之间的逻辑结构:比如我们学过的线性结构:顺序表啦,链表啦;层次结构:树啦。合适的数据结构可以带来更高的运行效率和存储效率,与相应解决实际问题算法的适应性也就越高,这也就是为什么一些算法指定了数据存储必须以某种特定的数据结才行。一般都是根据合适的数据结构来设计算法,而不是根据算法来设计数据结构。
算法和数据结构往往是互不分开的。离开了算法,数据结构就显得毫无意义,而没有了数据结构算法就没有实现的条件。良好的数据结构思想就是一种高效的算法,但是数据结构不等于算法。只有当数据结构用于处理某个特定问题类型的时候,数据结构才会体现为算法。要想细致的了解,就要多看书,因为这东西毕竟发展了那么多年,一两句话是说不清楚的。想知道更多的数据结构与算法知识吗?可以去了解一下小码哥李明杰。
㈡ 我们为什么要学数据结构与算法,设计模式
数据结构是非常重要的 ,举个例子,如果要在一堆数中查找一个数,挨个遍历查询,是非常有失效率的,使用平衡树或者哈希表,则能高效查询,尤其是数据量极大时,譬如几十万到多少亿的数据量,将会有极其明显的效率差距。可能高效的程序只需要1ms,暴力查找要几小时
类似的例子还有很多,算法也是如此
而设计模式,只有做大型工程才有用,能够更合理的组织代码,便于开发和维护,小程序是体现不出来什么作用的
㈢ 求好书推荐!! c语言, 数据结构 和 算法设计等 (分后补!)
额,跟你这么说吧,我看过的c语言里边比较适合学习的有三本:谭浩强的那本c语言,比较适合入门,如果你有点基础可以看看《c语言程序设计》和《c程序设计语言》这两本都是机械工业出版社出版的外国经典书,看的顺序最好按我给你说的。c程序设计语言是C语言之父写的,谁看谁知道,什么叫做经典。
数据结构方面也可以看看机械工业出版社出版的大理石纹封面系列的翻译的外国经典的书,名字好像是《数据结构》、《数据结构与算法》(c语言版),如果学校里学了严蔚敏的也可以在好好研究下她老人家的,也比较不错。
想学算法的话,就看《算法导论》依然是机械工业出版社出版的大理石纹封面,很给力。另外我的经历告诉我,看书学技术尽量看国外的经典的书,风趣有味,谁看谁知道。希望对你有帮助哈。像c++的话人民邮电出版社出版的有几本不错的。
㈣ 必须先学C语言再学数据结构与算法设计吗
是的,如果连基础的C语言语法都不会,那你怎么去实现你要学习的算法呢?
㈤ 什么叫做“对数据结构和算法设计具有深刻的理解”
显然要出题让你写个算法
㈥ 比较数据模型数据结构和算法设计课程中的"数据结构"的异同
c语言数据类型一般说的是基本数据类型,像整形、浮点型、字符型等,这些都是最基本的数据类型。数据结构的概念就比较上层了,比如堆、栈、链表、队列等,这些数据结构都有一定的特点,比如队列就是先进先出的模型。比如我要设计一个服务器,一秒
㈦ 数据结构与算法
赤水残阳 的说法有问题,什么叫学好数据结构?你能用数据结构的知识实现STL库、Boost库、解决实际编程问题。
①要学好数据结构,至少要学好一门计算机语言。
②所以如果你的计算机语言是C++,那么不学好C++,数据结构绝对无法学好(铁定)。
③为什么?
计算机开发领域专业核心课程就几门:数据结构、操作系统原理、数据库系统原理、汇编语言程序设计。
而数据结构是这另外几门核心课程的基础。
数据结构最终是为了实现,如果你不边学边实验C++代码,那么学起来就如走马观花,无法从细节上庖丁解牛。
到时候,数据结构会出很多编程要求,假设一个人指针没学好,单向链表、双向链表、二叉树、图都没法编程。
不过,就算你C++之前没怎么投入时间,放假半个月到一个月集中精力投入时间,也是可以弥补的,甚至比你们班大多数做得更好:不断编程实践。
㈧ 《算法设计与分析》是学什么的和《数据结构》一样吗谢谢!
三者都不一样
通俗点说,算法就是解决问题的方法,因为和计算密切相关,所以不交方法,叫算法
数据结构是数据的组织方式。
算法通过操作和处理数据来解决问题,所以算法和数据结构是不分家的!
而计算方法是另一门课程。基本上是存数学的东西,看这里http://ke..com/view/754503.htm?fr=ala0_1_1
㈨ 算法和数据结构有什么区别
一、指代不同
1、算法:是指解题方案的准确而完整的描述,是一系列解决问题的清晰指令。
2、数据结构:指相互之间存在一种或多种特定关系的数据元素的集合。
二、目的不同
1、算法:指令描述的是一个计算,当其运行时能从一个初始状态和(可能为空的)初始输入开始,经过一系列有限而清晰定义的状态,最终产生输出并停止于一个终态。
2、数据结构:研究的是数据的逻辑结构和数据的物理结构之间的相互关系,并对这种结构定义相适应的运算,设计出相应的算法,并确保经过这些运算以后所得到的新结构仍保持原来的结构类型。
三、特点不同
1、算法:算法中执行的任何计算步骤都是可以被分解为基本的可执行的操作步骤,即每个计算步骤都可以在有限时间内完成。
2、数据结构:核心技术是分解与抽象。通过分解可以划分出数据的3个层次;再通过抽象,舍弃数据元素的具体内容,就得到逻辑结构。