数据结构暨若干经典问题和算法.doc

数据结构暨若干经典问题和算法.doc

ID:57911213

大小:122.00 KB

页数:33页

时间:2020-04-03

数据结构暨若干经典问题和算法.doc_第1页
数据结构暨若干经典问题和算法.doc_第2页
数据结构暨若干经典问题和算法.doc_第3页
数据结构暨若干经典问题和算法.doc_第4页
数据结构暨若干经典问题和算法.doc_第5页
资源描述:

《数据结构暨若干经典问题和算法.doc》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、一、迭代法      迭代法是用于求方程或方程组近似根的一种常用的算法设计方法。设方程为f(x)=0,用某种数学方法导出等价的形式x=g(x),然后按以下步骤执行: (1)   选一个方程的近似根,赋给变量x0; (2)   将x0的值保存于变量x1,然后计算g(x1),并将结果存于变量x0; (3)   当x0与x1的差的绝对值还小于指定的精度要求时,重复步骤(2)的计算。 若方程有根,并且用上述方法计算出来的近似根序列收敛,则按上述方法求得的x0就认为是方程的根。上述算法用C程序的形式表示为: 【算法】迭代法求方程的根 {    x0=初始近似根;    do 

2、{       x1=x0;       x0=g(x1);   /*按特定的方程计算新的近似根*/       } while ( fabs(x0-x1)>Epsilon);    printf(“方程的近似根是%f”,x0); } 迭代算法也常用于求方程组的根,令       X=(x0,x1,…,xn-1) 设方程组为:       xi=gi(X)      (I=0,1,…,n-1) 则求方程组根的迭代算法可描述如下: 【算法】迭代法求方程组的根    {    for (i=0;i

3、do {          for (i=0;idelta)      delta=fabs(y[i]-x[i]);          } while (delta>Epsilon);       for (i=0;i

4、量x[%d]的近似根是 %f”,I,x[i]);       printf(“”);    }    具体使用迭代法求根时应注意以下两种可能发生的情况: (1)   如果方程无解,算法求出的近似根序列就不会收敛,迭代过程会变成死循环,因此在使用迭代算法前应先考察方程是否有解,并在程序中对迭代的次数给予限制; (2)   方程虽然有解,但迭代公式选择不当,或迭代的初始近似根选择不合理,也会导致迭代失败。 二、穷举搜索法      穷举搜索法是对可能是解的众多候选解按某种顺序进行逐一枚举和检验,并从众找出那些符合要求的候选解作为问题的解。 【问题】   将A、B、C

5、、D、E、F这六个变量排成如图所示的三角形,这六个变量分别取[1,6]上的整数,且均不相同。求使三角形三条边上的变量之和相等的全部解。如图就是一个解。 程序引入变量a、b、c、d、e、f,并让它们分别顺序取1至6的证书,在它们互不相同的条件下,测试由它们排成的如图所示的三角形三条边上的变量之和是否相等,如相等即为一种满足要求的排列,把它们输出。当这些变量取尽所有的组合后,程序就可得到全部可能的解。细节见下面的程序。 【程序1】 # include  void main() {   int a,b,c,d,e,f;    for (a=1;a<=6;

6、a++)          for (b=1;b<=6;b++)      {          if (b==a)      continue;          for (c=1;c<=6;c++)      {             if (c==a)

7、

8、(c==b)   continue;             for (d=1;d<=6;d++)      {                if (d==a)

9、

10、(d==b)

11、

12、(d==c)    continue; for (e=1;e<=6;e++)      {    if (e==a)

13、

14、(e=

15、=b)

16、

17、(e==c)

18、

19、(e==d)    continue; f=21-(a+b+c+d+e); if ((a+b+c==c+d+e))&&(a+b+c==e+f+a))   { printf(“%6d,a);    printf(“%4d%4d”,b,f);    printf(“%2d%4d%4d”,c,d,e);    scanf(“%*c”); }                   }                }             }          }       } 按穷举法编写的程序通常不能适应变化的情况。如问题改成有9个变量排

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。