什么是算法?什么是程序?这两者之间有什么关系?
算法和程序嘛。
。
。
对过程化程序来说,有个沃思公式:算法+数据结构=程序。
也就是说一个程序主要包含以下两方面的信息:1、对数据的描述。
在程序中要指定用到哪些数据以及这些数据的类型和数据的组织形式。
这就是数据结构(data structure)。
2、对操作的描述。
即要求计算机进行操作的步骤,也就是算法(algorithm)。
算法当然要在有穷步后终止啊,不然计算机受得了吗。
。
。
算法的特性就包含有穷这一条,而且有穷性是指在合理的范围之内,你让一个算法持续几千年,也不合常理。
希望对你有用。
算法和程序设计语言之间的关系
算法和程序设计语言没有必然联系;
就像数据结构这门课,它的算法可以用C语言实现,可以用C++实现,还可以用java实现,还有的书使用pascal实现的!
算法就是一个思想,是你的想法,而程序设计语言则是实现思想的执行者!
零基础怎么学算法与程序设计基础
你好,不知道你的学历现在是什么,一般高中毕业学习C语言是完全没有问题的。
学习顺序一般如下:
1、C语言
入门最好的语言,C在某种意义上可以说是C++的一个子集,所以想学C++,首先也要学好C
教程就是谭浩强的《C程序设计》最经典的
2、数据结构
这门知识也要掌握,非常重要,包含很多重要算法
3、数据库知识
掌握一门数据库,最好学习一下数据库原理,编程离不开数据库的(ess、VFP、MySQL、SQLServer、DB2、Oracle等都是数据库)
4、学一门面向对象的语言
C++(偏重设计系统软件,3D游戏多半也是用它开发出的,最强大的语言)
C#,.NET平台的语言
Java,这也是一种大型多功能语言,如果想做安卓开发就要学它
还有一些Web语言,如PHP、Perl等等
这些语言择一学习就行了,根据自己以后的方向选择
5、软件工程
这个是偏理论性的知识,可以带着看看,掌握软件开发的整个流程
PS:编程学习大致就这些,
算法与程序设计软件在哪下载
就用C语言编写算法就非常不错。
同学们在学C语言的时候大部分时间还是在用Turbo c这样“爷爷辈”的IDE(集成开发环境的缩写,也叫开发工具),真不免让人感觉惊奇,以至于很多同学都说“学习一个学期的C语言就会用printf在黑屏幕上打白字”。
虽然有人说“学习语言不能过度依赖于IDE”,可以对于一个新手来说一个容易上手的IDE将能大大提高学习的效率。
因为咱们将会开C语言实战开发的课程,因此需要为大家准备一个能开发Windows程序的IDE。
我经过约两天的试用、对比为大家选择了合适的开发工具。
目前常用的C语言开发工具有:1、VC6:这个是最经典的一个C/C++开发工具,毕竟是微软的东西,所以非常好用。
不过VC6的主要缺点是体积太大,有的同学是在网吧、学校机房等场合学习编程,如果电脑上没有VC6的话就需要下载(安装包要500MB左右)、安装,非常耗时。
而且VC6和Vista系统、卡巴斯基等软件有冲突,经常崩溃。
毕竟是98年的软件了,微软已经不提供支持了。
2、VC2005/VC2008:也被称为VC7,它是VC6的升级版本,支持新的C/C++语法标准以及新的库文件。
同时VC7继承了VC6的所有优点,而且继承并发扬了VC6体积大的“优点”,一个安装包最小也要1G,完整安装要3G。
3、Dev C++:曾经非常牛气的一个免费的C/C++开发工具,体积非常小,只有9M多一点,代码高亮、自动完成等都做的非常好。
不过Dev C++稳定性不是很好,经常崩溃,而且Dev C++最近一次更新是在2005年,可以看到作者已经放弃了这个软件,因此那些Bug也无法被修改了。
Dev C++有官方中文语言包。
4、Code::Blocks:目前最如日中天的开源且免费的C/C++开发工具,跨平台,可以在Windows/Linux等平台下运行,体积比较小,只有不到20M。
Code::Blocks一直在飞速发展,因此支持最新的C/C++语法和最新的库文件。
因此很多专业开发人员都推荐使用Code::Blocks。
不过Code::Blocks的代码智能提示和自动完成功能做的不是很好,这恰恰是对于初学者来说比较重要的地方。
而且Code::Blocks没有官方中文语言包,满屏幕的英文对于初学者来说难度比较大。
5、C-Free:国产的C/C++开发工具。
体积非常小,只有不到9M。
C-Free的代码智能提示和自动完成、代码高亮以及代码导航等功能做的非常好,可以说是无可挑剔,这对初学者来说是最重要的;C-Free的启动速度也非常快。
国产软件肯定是中文界面了,:)。
初学者的特点是要求软件尽可能的体积小、启动快、BUG少,代码智能提示和自动完成、代码高亮以及代码导航等功能要好,而对是否支持C/C++最新语言规范等则是相对来说比较次要的。
因此这里推荐大家使用C-Free做为开发工具,我们讲课过程中也将使用C-Free做为开发工具。
程序设计语言只是一个工具,只懂得语言的规则并不能保证编制出高质量的程序,程序设计的关键是设计算法。
算法是求解问题的有限步骤,具有有穷性、确定性、可行性、输入与输出五大特征。
求解问题的算法从一般意义上讲可分为输入、处理、输出三个步骤。
算法的评价是以正确作为前题。
在正确的前题下,一个好的算法应易理解,在易理解的基础上力求算法的高效率。
算法可以用自然语言描述,也可以用流程图描述。
从算法的角度看,程序是算法的最终实现,也可以认为是算法的一种描述形式、最终形式。
算法的分析采用自顶向下的分析方法,将大问题分解成子问题,将大目标分解成子目标,最终分解成计算机能处理的一系列步骤。
算法的自然语言描述靠近问题,算法的程序描述靠近机器,算法的流程图描述非常直观。
具体描述参见后面的实例
什么是一种算法和程序
算法(Algorithm)是一系列解决问题的清晰指令,也就是说,能够对一定规范的输入,在有限时间内获得所要求的输出。
如果一个算法有缺陷,或不适合于某个问题,执行这个算法将不会解决这个问题。
不同的算法可能用不同的时间、空间或效率来完成同样的任务。
一个算法的优劣可以用空间复杂度与时间复杂度来衡量。
算法可以理解为有基本运算及规定的运算顺序所构成的完整的解题步骤。
或者看成按照要求设计好的有限的确切的计算序列,并且这样的步骤和序列可以解决一类问题。
一个算法应该具有以下五个重要的特征:
1、有穷性: 一个算法必须保证执行有限步之后结束;
2、确切性: 算法的每一步骤必须有确切的定义;
3、输入:一个算法有0个或多个输入,以刻画运算对象的初始情况,所谓0个输入是指算法本身定除了初始条件;
4、输出:一个算法有一个或多个输出,以反映对输入数据加工后的结果。
没有输出的算法是毫无意义的;
5、可行性: 算法原则上能够精确地运行,而且人们用笔和纸做有限次运算后即可完成。
“程序 = 算法 + 数据结构”
.程序是计算机的一组指令,经过编译和执行才能最终完成程序设计的动作。
程序设计的最终结果是软件。