ImageVerifierCode 换一换
格式:DOCX , 页数:33 ,大小:57.26KB ,
资源ID:7273414      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/7273414.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(c语言经典例题.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

c语言经典例题.docx

1、c语言经典例题在一个88国际象棋盘上,有8个皇后,每个皇后占一格;要求皇后间不会出现相互“攻击”的现象,即不能有两个皇后处在同一行、同一列或同一对角线上。问共有多少种不同的方法。*问题分析与算法设计这是一个古老的具有代表性的问题,用计算机求解时的算法也很多,这里仅介绍一种。采用一维数组来进行处理。数组的下标i表示棋盘上的第i列,ai的值表示皇后在第i列所放的位置。如:a1=5,表示在棋盘的第一例的第五行放一个皇后。程序中首先假定a1=1,表示第一个皇后放在棋盘的第一列的第一行的位置上,然后试探第二列中皇后可能的位置,找到合适的位置后,再处理后续的各列,这样通过各列的反复试探,可以最终找出皇后的

2、全部摆放方法。程序采用回溯法,算法的细节参看程序。*程序说明与注释#include#define NUM 8 /*定义数组的大小*/int aNUM+1;int main()int i,k,flag,not_finish=1,count=0;i=1; /*正在处理的元素下标,表示前i-1个元素已符合要求,正在处理第i个元素*/a1=1; /*为数组的第一个元素赋初值*/printf(The possible configuration of 8 queens are:n);while(not_finish) /*not_finish=1:处理尚未结束*/while(not_finish&i=N

3、UM) /*处理尚未结束且还没处理到第NUM个元素*/for(flag=1,k=1;flag&ki;k+) /*判断是否有多个皇后在同一行*/if(ak=ai)flag=0;for(k=1;flag&k1&ai=NUM)ai=1; /*当ai为NUM时将ai的值置1*/else if(i=1&ai=NUM)not_finish=0; /*当第一位的值达到NUM时结束*/else ai+; /*将ai的值取下一个值*/else if(ai=NUM) ai=1;else ai+; /*将ai的值取下一个值*/else if(+i=NUM)if(ai-1=NUM) ai=1; /*若前一个元素的值为

4、NUM则ai=1*/else ai=ai-1+1; /*否则元素的值为前一个元素的下一个值*/if(not_finish)+count;printf(count-1)%3? %2d: : n%2d: ,count);for(k=1;k=NUM;k+) /*输出结果*/printf( %d,ak);if(aNUM-1=m=n0)求出满足以下方程的正整数数列 i1,i2,.,in,使得:i1+i1+.+in=m,且i1=i2.=in。例如:当n=4, m=8时,将得到如下5 个数列:5 1 1 1 4 2 1 1 3 3 1 1 3 2 2 1 2 2 2 2*问题分析与算法设计可将原题抽象为:将

5、M分解为N个整数,且N个整数的和为M,i1=i2=.=in。分解整数的方法很低多,由于题目中有i1=i2=.=in,提示我们可先确定最右边in元素的值为1,然后按照条件使前一个元素的值一定大于等于当前元素的值,不断地向前推就可以解决问题。下面的程序允许用户选定M和N,输出满足条件的所有数列。*程序说明与注释#include#define NUM 10 /*允许分解的最大元素数量*/int iNUM; /*记录分解出的数值的数组*/int main()int sum,n,total,k,flag,count=0;printf(Please enter requried terms(=10):);

6、scanf(%d,&n);printf( their sum:);scanf(%d,&total);sum=0; /*当前从后向前k个元素的和*/k=n; /*从后向前正在处理的元素下标*/in=1; /*将最后一个元素的值置为1作为初始值*/printf(There are following possible series:n);while(1)if(sum+iktotal) /*若后k位的和小于指定的total*/if(ktotal|k!=1) /*若和已超过total或不是第一个元素*/ sum-=i+k; flag=0; /*k向后回退一个元素*/else flag=1; /*sum

7、+ik=total&k=1 则设置flag标记*/if(flag)printf(%d:,+count);for(flag=1;flagn) /*k向后回退一个元素后判断是否已退出最后一个元素*/break;sum-=ik;ik+; /*试验下一个分解*/*运行结果Please enter requried terms(=10):4their sum:8There are following possible series:1: 51112: 42113: 33114: 32215: 2222 在选美大奖赛的半决胜赛现场,有一批选手参加比赛,比赛的规则是最后得分越高,名次越低。当半决决赛结束时,

8、要在现场按照选手的出场顺序宣布最后得分和最后名次,获得相同分数的选手具有相同的名次,名次连续编号,不用考虑同名次的选手人数。在选美大奖赛的半决胜赛现场,有一批选手参加比赛,比赛的规则是最后得分越高,名次越低。当半决决赛结束时,要在现场按照选手的出场顺序宣布最后得分和最后名次,获得相同分数的选手具有相同的名次,名次连续编号,不用考虑同名次的选手人数。例如:选手序号: 1,2,3,4,5,6,7选手得分: 5,3,4,7,3,5,6则输出名次为: 3,1,2,5,1,3,4请编程帮助大奖赛组委会完成半决赛的评分和排名工作。*问题分析与算法设计问题用程序设计语言加以表达的话,即为:将数组A中的整数从

9、小到大进行连续编号,要求不改变数组中元素的顺序,且相同的整数要具有相同的编号。普通的排序方法均要改变数组元素原来的顺序,显然不能满足要求。为此,引入一个专门存放名次的数组,再采用通常的算法:在尚未排出名次的元素中找出最小值,并对具有相同值的元素进行处理,重复这一过程,直到全部元素排好为止。*程序说明与注释#include#define NUM 7 /*定义要处理的人数*/int aNUM+1=0,5,3,4,7,3,5,6; /*为简单直接定义选手的分数*/int mNUM+1,lNUM+1; /*m:已编名次的标记数组 l:记录同名次元素的下标*/int main()int i,smalle

10、st,num,k,j;num=1; /*名次*/for(i=1;i=NUM;i+) /*控制扫描整个数组,每次处理一个名次*/if(mi=0) /*若尚未进行名次处理(即找到第一个尚未处理的元素)*/smallest=ai; /*取第一个未处理的元素作为当前的最小值*/k=1; /*数组l的下标,同名次的人数*/lk=i; /*记录分值为smallest的同名次元素的下标*/for(j=i+1;j=NUM;j+) /*从下一个元素开始对余下的元素进行处理*/if(mj=0) /*若为尚未进行处理的元素*/if(ajsmallest) /*分数小于当前最小值*/smallest=aj; /*则重

11、新设置当覵最小值*/k=0; /*重新设置同名次人数*/l+k=j; /*重新记录同名次元素下标*/else if(aj=smallest) /*若与当前最低分相同*/l+k=j; /*记录同名次的元素下标*/for(j=1;j=num;num+; /*名次加1*/i=0; /*控制重新开始,找下一个没排名次的元素*/printf(Player-No score Rankn);for(j=1;j=NUM;j+) /*控制输出*/printf( %3d %4d %4dn,j,aj,mj);*运行结果Player-No Score Rank1 5 32 3 13 4 25 7 55 3 13 5

12、37 6 4将大于0小于1000的阿拉伯数字转换为罗马数字。题目中给出了阿拉伯数字与罗马数字的对应关系,题中的数字转换实际上就是查表翻译。即将整数的百、十、个位依次从整数中分解出来,查找表中相应的行后输出对应的字符题目中给出了阿拉伯数字与罗马数字的对应关系,题中的数字转换实际上就是查表翻译。即将整数的百、十、个位依次从整数中分解出来,查找表中相应的行后输出对应的字符。*程序与程序设计#includeint main()static char *a10=,I,II,III,IV,V,VI,VII,VIII,IX,X,XX,XXX,XL,L,LX,LXX,LXXX,XCC,C,CC,CCC,CD,

13、D,DC,DCC,DCCC,CM; /*建立对照表*/int n,t,i,m;printf(Please enter number:);scanf(%d,&n); /*输入整数*/printf(%d=,n);for(m=0,i=1000;m=3)。它就是著名的斐波那契数列,该数列的前几为:1,1,2,3,5,8,13,21.斐波那契数列在程序中可以用多种方法进行处理。按照其通项递推公式利用最基本的循环控制就可以实现题目的要求。*程序说明与注释#includeint main()int n,i,un1,un2,un;for(n=2;n3;)printf(Please enter required

14、 number of generation:);scanf(%d,&n);if(n3) printf(n Enter error!n); /*控制输入正确的N值*/un=un2=1;printf(The repid increase of rabbits in first %d generation is as felow:n,n);printf(ltlt);for(i=3;i=n;i+)un1=un2;un2=un;un=un1+un2; /*利用通项公式求解N项的值*/printf(i%10?%dt:%dn,un);printf(n);*运行结果Please enter required

15、number of generation: 20The repid increase of rabbits in first 20 generation is as felow:1 1 2 3 5 8 13 21 34 5589 144 233 377 610 987 1597 2584 4181 6765 约19世纪末,在欧州的商店中出售一种智力玩具,在一块铜板上有三根杆,最左边的杆上自上而下、由小到大顺序串着由64个圆盘构成的塔。目的是将最左边杆上的盘全部移到右边的杆上,条件是一次只能移动一个盘,且不允许大盘放在小盘的上面。这就是著名的汉诺塔问题。 约19世纪末,在欧州的商店中出售一种智力

16、玩具,在一块铜板上有三根杆,最左边的杆上自上而下、由小到大顺序串着由64个圆盘构成的塔。目的是将最左边杆上的盘全部移到右边的杆上,条件是一次只能移动一个盘,且不允许大盘放在小盘的上面。*问题分析与算法设计这是一个著名的问题,几乎所有的教材上都有这个问题。由于条件是一次只能移动一个盘,且不允许大盘放在小盘上面,所以64个盘的移动次数是:18,446,744,073,709,551,615这是一个天文数字,若每一微秒可能计算(并不输出)一次移动,那么也需要几乎一百万年。我们仅能找出问题的解决方法并解决较小N值时的汉诺塔,但很难用计算机解决64层的汉诺塔。分析问题,找出移动盘子的正确算法。首先考虑a

17、杆下面的盘子而非杆上最上面的盘子,于是任务变成了:*将上面的63个盘子移到b杆上;*将a杆上剩下的盘子移到c杆上;*将b杆上的全部盘子移到c杆上。将这个过程继续下去,就是要先完成移动63个盘子、62个盘子、61个盘子.的工作。为了更清楚地描述算法,可以定义一个函数movedisc(n,a,b,c)。该函数的功能是:将N个盘子从A杆上借助C杆移动到B杆上。这样移动N个盘子的工作就可以按照以下过程进行:1) movedisc(n-1,a,c,b);2) 将一个盘子从a移动到b上;3) movedisc(n-1,c,b,a);重复以上过程,直到将全部的盘子移动到位时为止。*程序说明与注释#inclu

18、devoid movedisc(unsigned n,char fromneedle,char toneedle,char usingneedle);int i=0;int main()unsigned n;printf(please enter the number of disc:);scanf(%d,&n); /*输入N值*/printf(tneedle:tat bt cn);movedisc(n,a,c,b); /*从A上借助B将N个盘子移动到C上*/printf(t Total: %dn,i);void movedisc(unsigned n,char fromneedle,char

19、 toneedle,char usingneedle)if(n0)movedisc(n-1,fromneedle,usingneedle,toneedle);/*从fromneedle上借助toneedle将N-1个盘子移动到usingneedle上*/+i;switch(fromneedle) /*将fromneedle 上的一个盘子移到toneedle上*/case a: switch(toneedle)case b: printf(t%d:t%2d.%2dn,i,n,n);break;case c: printf(t%d:t%2d.%2dn,i,n,n);break;break;case

20、 b: switch(toneedle)case a: printf(t%d:t%2d%2dn,i,n,n);break;case c: printf(t%d:t %2d.%2dn,i,n,n);break;break;case c: switch(toneedle)case a: printf(t%d:t%2d.%2dn,i,n,n);break;case b: printf(t%d:t%2d.%2dn,i,n,n);break;break;movedisc(n-1,usingneedle,toneedle,fromneedle);/*从usingneedle上借助fromneedle将N-

21、1个盘子移动到toneedle上*/ 99.超长正整数的加法作者:不详来源:互联网 酷勤网收集2008-04-25摘要酷勤网我们采用一个带有表头结点的环形链来表示一个非负的超大整数,如果从低位开始为每 个数字编号,则第一位到第四位、第五位到第八位.的每四位组成的数字,依次放在链表的第一个、第二个、.结点中,不足4位的最高位存放在链表的最后一个结点中,表头结点的值规定为-1。 请设计一个算法来完成两个超长正整数的加法。*问题分析与算法设计首先要设计一种数据结构来表示一个超长的正整数,然后才能够设计算法。首先我们采用一个带有表头结点的环形链来表示一个非负的超大整数,如果从低位开始为每 个数字编号,

22、则第一位到第四位、第五位到第八位.的每四位组成的数字,依次放在链表的第一个、第二个、.结点中,不足4位的最高位存放在链表的最后一个结点中,表头结点的值规定为-1。例如:大整数“587890987654321”可用如下的带表头结点head的链表表示:按照此数据结构,可以从两个表头结点开始,顺序依次对应相加,求出所需要的进位后代入下面的运算。具体的实现算法请见程序中的注释。*程序说明与注释#include#include#define HUNTHOU 10000typedef struct node int data;struct node *next;NODE; /*定义链表结构*/NODE *

23、insert_after(NODE *u,int num); /*在u结点后插入一个新的NODE,其值为num*/NODE *addint(NODE *p,NODE *q); /*完成加法操作返回指向*p+*q结果的指针*/void printint(NODE *s);NODE *inputint(void);int main()NODE *s1,*s2,*s;NODE *inputint(), *addint(), *insert_after();printf(Enter S1= );s1=inputint(); /*输入被加数*/printf(Enter S2= );s2=inputint

24、(); /*输入加数*/printf( S1=); printint(s1); putchar(n); /*显示被加数*/printf( S2=); printint(s2); putchar(n); /*显示加数*/s=addint(s1,s2); /*求和*/printf(S1+S2=); printint(s); putchar(n); /*输出结果*/NODE *insert_after(NODE *u,int num)NODE *v;v=(NODE *)malloc(sizeof(NODE); /*申请一个NODE*/v-data=num; /*赋值*/u-next=v; /*在u结点后插入一个NODE*/return v;NODE *addint(NODE *p,NODE *q) /*完成加法操作返回指向*p+*q结果的指针*/NODE *pp,*qq,*r,*s,*t;int total,number,carry;pp=p-next

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1