欢迎来到天天文库
浏览记录
ID:15786199
大小:213.50 KB
页数:48页
时间:2018-08-05
《常用算法设计方法(c语言)》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、常用算法设计方法1一、迭代法1二、穷举搜索法2三、递推法6四、递归7五、回溯法15六、贪婪法28七、分治法33八、动态规划法3947常用算法设计方法要使计算机能完成人们预定的工作,首先必须为如何完成预定的工作设计一个算法,然后再根据算法编写程序。计算机程序要对问题的每个对象和处理规则给出正确详尽的描述,其中程序的数据结构和变量用来描述问题的对象,程序结构、函数和语句用来描述问题的算法。算法数据结构是程序的两个重要方面。算法是问题求解过程的精确描述,一个算法由有限条可完全机械地执行的、有确定结果的指令组成。指令正确地描述了要完成的任务
2、和它们被执行的顺序。计算机按算法指令所描述的顺序执行算法的指令能在有限的步骤内终止,或终止于给出问题的解,或终止于指出问题对此输入数据无解。通常求解一个问题可能会有多种算法可供选择,选择的主要标准是算法的正确性和可靠性,简单性和易理解性。其次是算法所需要的存储空间少和执行更快等。算法设计是一件非常困难的工作,经常采用的算法设计技术主要有迭代法、穷举搜索法、递推法、贪婪法、回溯法、分治法、动态规划法等等。另外,为了更简洁的形式设计和藐视算法,在算法设计时又常常采用递归技术,用递归描述算法。一、迭代法迭代法是用于求方程或方程组近似根的一
3、种常用的算法设计方法。设方程为f(x)=0,用某种数学方法导出等价的形式x=g(x),然后按以下步骤执行:选一个方程的近似根,赋给变量x0;将x0的值保存于变量x1,然后计算g(x1),并将结果存于变量x0;当x0与x1的差的绝对值还小于指定的精度要求时,重复步骤(2)的计算。若方程有根,并且用上述方法计算出来的近似根序列收敛,则按上述方法求得的x0就认为是方程的根。上述算法用C程序的形式表示为:【算法】迭代法求方程的根{x0=初始近似根;do{x1=x0;x0=g(x1);/*按特定的方程计算新的近似根*/}while(fabs(
4、x0-x1)>Epsilon);printf(“方程的近似根是%f”,x0);}迭代算法也常用于求方程组的根,令47X=(x0,x1,…,xn-1)设方程组为:xi=gi(X)(I=0,1,…,n-1)则求方程组根的迭代算法可描述如下:【算法】迭代法求方程组的根{for(i=0;idelta)d
5、elta=fabs(y[i]-x[i]);}while(delta>Epsilon);for(i=0;i6、顺序进行逐一枚举和检验,并从中找出那些符合要求的候选解作为问题的解。【问题】将A、B、C、D、E、F这六个变量排成如图所示的三角形,这六个变量分别取[1,6]上的整数,且均不相同。求使三角形三条边上的变量之和相等的全部解。如图就是一个解。程序引入变量a、b、c、d、e、f,并让它们分别顺序取1至6的证书,在它们互不相同的条件下,测试由它们排成的如图所示的三角形三条边上的变量之和是否相等,如相等即为一种满足要求的排列,把它们输出。当这些变量取尽所有的组合后,程序就可得到全部可能的解。细节见下面的程序。47【程序1】#include7、tdio.h>voidmain(){inta,b,c,d,e,f;for(a=1;a<=6;a++)for(b=1;b<=6;b++){if(b==a)continue;for(c=1;c<=6;c++){if(c==a)8、9、(c==b)continue;for(d=1;d<=6;d++){if(d==a)10、11、(d==b)12、13、(d==c)continue;for(e=1;e<=6;e++){if(e==a)14、15、(e==b)16、17、(e==c)18、19、(e==d)continue;f=21-(a+b+c+d+e);if((a+b+c==c+d20、+e))&&(a+b+c==e+f+a)){printf(“%6d,a);printf(“%4d%4d”,b,f);printf(“%2d%4d%4d”,c,d,e);scanf(“%*c”);}}}}}}按穷举法编写的程序通常不能适
6、顺序进行逐一枚举和检验,并从中找出那些符合要求的候选解作为问题的解。【问题】将A、B、C、D、E、F这六个变量排成如图所示的三角形,这六个变量分别取[1,6]上的整数,且均不相同。求使三角形三条边上的变量之和相等的全部解。如图就是一个解。程序引入变量a、b、c、d、e、f,并让它们分别顺序取1至6的证书,在它们互不相同的条件下,测试由它们排成的如图所示的三角形三条边上的变量之和是否相等,如相等即为一种满足要求的排列,把它们输出。当这些变量取尽所有的组合后,程序就可得到全部可能的解。细节见下面的程序。47【程序1】#include
7、tdio.h>voidmain(){inta,b,c,d,e,f;for(a=1;a<=6;a++)for(b=1;b<=6;b++){if(b==a)continue;for(c=1;c<=6;c++){if(c==a)
8、
9、(c==b)continue;for(d=1;d<=6;d++){if(d==a)
10、
11、(d==b)
12、
13、(d==c)continue;for(e=1;e<=6;e++){if(e==a)
14、
15、(e==b)
16、
17、(e==c)
18、
19、(e==d)continue;f=21-(a+b+c+d+e);if((a+b+c==c+d
20、+e))&&(a+b+c==e+f+a)){printf(“%6d,a);printf(“%4d%4d”,b,f);printf(“%2d%4d%4d”,c,d,e);scanf(“%*c”);}}}}}}按穷举法编写的程序通常不能适
此文档下载收益归作者所有