C语言入门必做习题100例(四)
C语言程序设计经典100例(全)

103f程序1】【题目:有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?1.程序分析:可填在百位、十位、个位的数字都是1、2、3、4。
组成所有的排列后再去掉不满足条件的排列。
2.程序源代码:main(){int i,j,k;printf("\n");for(i=1;i<5;i++) /*以下为三重循环*/for(j=1;j<5;j++)for (k=1;k<5;k++){if (i!=k&&i!=j&&j!=k) /*确保i、j、k三位互不相同*/printf("%d,%d,%d\n",i,j,k);}}==============================================================【程序2】题目:企业发放的奖金根据利润提成。
利润(I)低于或等于10万元时,奖金可提10%;利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可可提成7.5%;20万到40万之间时,高于20万元的部分,可提成5%;40万到60万之间时高于40万元的部分,可提成3%;60万到100万之间时,高于60万元的部分,可提成1.5%,高于100万元时,超过100万元的部分按1%提成,从键盘输入当月利润I,求应发放奖金总数?1.程序分析:请利用数轴来分界,定位。
注意定义时需把奖金定义成长整型。
2.程序源代码:main(){long int i;int bonus1,bonus2,bonus4,bonus6,bonus10,bonus;scanf("%ld",&i);bonus1=100000*0.1;bonus2=bonus1+100000*0.75;bonus4=bonus2+200000*0.5;bonus6=bonus4+200000*0.3;bonus10=bonus6+400000*0.15;if(i<=100000)bonus=i*0.1;else if(i<=200000)bonus=bonus1+(i-100000)*0.075;else if(i<=400000)bonus=bonus2+(i-200000)*0.05;else if(i<=600000)bonus=bonus4+(i-400000)*0.03;else if(i<=1000000)bonus=bonus6+(i-600000)*0.015;elsebonus=bonus10+(i-1000000)*0.01;printf("bonus=%d",bonus);}==============================================================【程序3】题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?1.程序分析:在10万以内判断,先将该数加上100后再开方,再将该数加上268后再开方,如果开方后的结果满足如下条件,即是结果。
C语言必考100题

C语⾔必考100题1.按下述格式,从键盘输⼊⼀个整数加法表达式:操作数1+操作数2,然后计算并输出表达式的计算结果,形式如下:操作数1+操作数2=计算结果。
2.输⼊两个整形数并打印,如果⽤户不慎输⼊了⾮法字符,那么程序提⽰“输⼊数据类型错误”。
3.已知三⾓形的三边长a,b,c,要求编写程序,从键盘输⼊a,b,c的值,计算并输出三⾓形的⾯积(注意不存在的情况)。
4.编程从键盘输⼊圆的半径r,计算并输出圆的周长和⾯积。
5.任意从键盘输⼊⼀个三位整数,要求正确分离它的个位,⼗位和百位数,并分别在屏幕上输出。
6.写⼀个函数实现统计⼀个输⼊的整形数的位数。
7.编程计算⽅程ax*x+bx+c=0的根,a,b,c由键盘输⼊,只是⽤主函数来实现。
8.编写三个函数,分别在b*b-4*a*c⼤于0、⼩于0、等于0时进⾏调⽤,并输出结果,在主函数中读⼊a、b、c的值。
9.从键盘输⼊你和你朋友的年龄,变成判断谁的年龄⼤,并打印最⼤者的年龄。
10.从键盘输⼊⼀个年份,判断该年是否是闰年,并输出结果。
11.判断某⼈是否属于肥胖体型。
根据⾝⾼与体重因素,医务⼯作者经⼴泛的调查分析给出了以下按“体指数”对肥胖程度的划分:体指数t=w/h*h(w为体重,单位为kg,h为⾝⾼,单位为m)。
当t<18时,为低体重;当t介于18和25之间时,为正常体重;当t介于25和27之间时,为超重体重;当t≧27时,为肥胖。
编程从键盘输⼊你的⾝⾼h和体重w,根据上式,判断体重类型。
12.利⽤switch语句将百分制成绩转化为五分制成绩。
13.利⽤switch语句将五分制成绩转换成对应分数范围并输出。
14.编程设计⼀个简单的计算器程序,要求根据⽤户从键盘输⼊的表达式:操作数1 运算符op 操作数2 计算表达式的值,指定的运算符为加减乘除。
15.利⽤时间函数编写⼀个猜数程序。
16.编程实现计算n的阶乘。
17.利⽤函数递归实现计算n!。
18.利⽤π/4=1-1/3+1/5-1/7……计算π的值直到最后⼀项的绝对值⼩于0.0001为⽌,要求统计总共累加了多少项。
C语言入门必做习题100例(四)

1. (N阶梵塔) 有K根棒,第一根上放N片大小不等的圆盘,并保持上小下大的顺序。
现将N片圆盘从第1根移至第K根,移动中均保持上小下大的顺序,问最少移几次方得结果,求出移动方案。
2. 某一印刷厂有六项加工任务,对印刷车间和装订车间所需时间见下表(时间单位:天)任务│J1 J2 J3 J4 J5 J6─────┼───────────────印刷车间│31252911装订车间│8109631如何安排加工顺序,使加工时间最少。
3. 将7万元投资到A,B,C三项目上,其利润见下表:投资额(万元)│1234567──────┼────────────────────项A│0.11 0.13 0.15 0.24 0.24 0.30 0.35B│0.12 0.16 0.21 0.25 0.25 0.29 0.34目C│0.08 0.12 0.20 0.26 0.26 0.30 0.35如何分配投资额,使获得的利润最大。
4. 无根树与通常所说的树(有根树)很相似,它包含有节点和枝,但不含有根。
无根树节点之间只有相邻关系。
如图一所示,是一棵有七个节点的无根树,以图一的A为根节点得到图二所示的有根树,以B为根节点得到图三所示的有根树,但从无根树的角度看,图一、二、三是结构相同的无根树,同时无根树的结构与节点的名称无关。
有根树可以用字符串的形式表示,其递归表示方法是:根节点(子树1子树2子树3...)图一,图二的有根树可表示为 A(B(CF(EGD))) 和 B(ACF(EGD))。
由于子树的表示顺序可以不同,所以一棵有根树可以有多种表示方法,如图三又可表示成B(F(EGD)CA) 或 B(ACF(DE(G)) 等。
表示无根树时,可以以它任一节点为根节点,将其看作有根树,从而可以利用有根树的字符串表示形式来表示无根树。
任务一:由键盘读入一个字符串表示的无根树,无根树的各节点的名称用互不相同的大写英文字母表示。
由用户输入一个节点的名称,程序应能够输出一种以该节点为根节点的字符串形式。
C语言经典编程100题

C语⾔经典编程100题⽬录⼀、题⽬【程序1】题⽬:有1、2、3、4个数字,能组成多少个互不相同且⽆重复数字的三位数?都是多少?==============================================================【程序2】题⽬:企业发放的奖⾦根据利润提成。
利润(I)低于或等于10万元时,奖⾦可提10%;利润⾼于10万元,低于20万元时,低于10万元的部分按10%提成,⾼于10万元的部分,可可提成7.5%;20万到40万之间时,⾼于20万元的部分,可提成5%;40万到60万之间时⾼于40万元的部分,可提成3%;60万到100万之间时,⾼于60万元的部分,可提成1.5%,⾼于100万元时,超过100万元的部分按1%提成,从键盘输⼊当⽉利润I,求应发放奖⾦总数?==============================================================【程序3】题⽬:⼀个整数,它加上100后是⼀个完全平⽅数,再加上168⼜是⼀个完全平⽅数,请问该数是多少?==============================================================【程序4】题⽬:输⼊某年某⽉某⽇,判断这⼀天是这⼀年的第⼏天?==============================================================【程序7】题⽬:输出特殊图案,请在c环境中运⾏,看⼀看,Very Beautiful!==============================================================【程序8】题⽬:输出9*9⼝诀。
==============================================================【程序9】题⽬:要求输出国际象棋棋盘。
c语言经典题目100题

1.寻找数组中的最大值和最小值2.寻找数组中的中位数3.查找数组中给定元素的索引4.反转数组5.合并两个升序数组6.移位数组7.查找两个数组的交集8.查找两个数组的并集9.查找两个数组的差集10.寻找数组中的众数11.寻找数组中的缺失元素12.寻找数组中的重复元素13.计算数组的和14.计算数组的平均值15.计算数组的方差16.计算数组的标准差17.比较两个数组是否相等18.复制数组19.排序数组20.搜索数组(线性搜索)21.搜索数组(二分搜索)22.插入元素到数组23.删除元素到数组24.更新数组中的元素25.创建动态数组26.释放动态数组27.字符串复制28.字符串连接29.字符串比较30.字符串搜索31.字符串替换32.字符串分割33.字符串反转34.字符串大小写转换35.字符串修剪36.计算字符串长度37.字符串格式化38.链表创建39.链表插入40.链表删除41.链表搜索42.链表反转43.链表排序44.链表合并45.链表复制46.链表释放47.树创建48.树插入49.树删除50.树搜索51.树反转52.树排序53.树合并54.树复制55.树释放56.堆创建57.堆插入58.堆删除59.堆搜索60.堆反转61.堆排序62.堆合并63.堆复制64.堆释放65.图创建66.图插入67.图删除68.图搜索69.图反转70.图排序71.图合并72.图复制73.图释放74.队列创建75.队列插入76.队列删除77.队列搜索78.队列反转79.队列排序80.队列合并81.队列复制82.队列释放83.栈创建84.栈插入85.栈删除86.栈搜索87.栈反转88.栈排序89.栈合并90.栈复制91.栈释放92.哈希表创建93.哈希表插入94.哈希表删除95.哈希表搜索96.哈希表反转97.哈希表排序98.哈希表合并99.哈希表复制100.哈希表释放。
C语言编程实例100题(带解析适合新手超经典)

C语言程序实例100个(一)【程序1】题目:有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?1.程序分析:可填在百位、十位、个位的数字都是1、2、3、4。
组成所有的排列后再去掉不满足条件的排列。
2.程序源代码:main(){int i,j,k;printf("\n");for(i=1;i<5;i++)/*以下为三重循环*/ for(j=1;j<5;j++)for (k=1;k<5;k++){if (i!=k&&i!=j&&j!=k) /*确保i、j、k三位互不相同*/ printf("%d,%d,%d\n",i,j,k);}}==============================================================【程序2】题目:企业发放的奖金根据利润提成。
利润(I)低于或等于10万元时,奖金可提10%;利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可可提成7.5%;20万到40万之间时,高于20万元的部分,可提成5%;40万到60万之间时高于40万元的部分,可提成3%;60万到100万之间时,高于60万元的部分,可提成1.5%,高于100万元时,超过100万元的部分按1%提成,从键盘输入当月利润I,求应发放奖金总数?1.程序分析:请利用数轴来分界,定位。
注意定义时需把奖金定义成长整型。
2.程序源代码:main(){long int i;int bonus1,bonus2,bonus4,bonus6,bonus10,bonus;scanf("%ld",&i);bonus1=100000*0.1;bonus2=bonus1+100000*0.75;bonus4=bonus2+200000*0.5;bonus6=bonus4+200000*0.3;bonus10=bonus6+400000*0.15;if(i<=100000)bonus=i*0.1;else if(i<=200000)bonus=bonus1+(i-100000)*0.075;bonus=bonus4+(i-400000)*0.03;else if(i<=1000000)bonus=bonus6+(i-600000)*0.015;elsebonus=bonus10+(i-1000000)*0.01;printf("bonus=%d",bonus);}==============================================================【程序3】题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?1.程序分析:在10万以内判断,先将该数加上100后再开方,再将该数加上268后再开方,如果开方后的结果满足如下条件,即是结果。
c语言编程题库100题

c语言编程题库100题C语言是一门广泛应用于计算机领域的高级编程语言。
对于学习者来说,掌握C语言编程是一项必修课程。
为此,我们为大家整理了100道C语言编程题,供大家练练手,锻炼编程能力。
以下是题目列表:##### 基础篇1、编写一个C程序,输出“Hello, World!”。
2、编写一个C程序,输入两个数,求和并输出结果。
3、编写一个C程序,输入三个数,求平均值并输出结果。
4、编写一个C程序,输入三个数,比较大小并输出最大值。
5、编写一个C程序,输入一个数,判断奇偶性并输出结果。
6、编写一个C程序,输入一个数,判断是否为质数并输出结果。
7、编写一个C程序,输入一个数,判断是否为闰年并输出结果。
8、编写一个C程序,输入一个字符,判断是否为字母并输出结果。
9、编写一个C程序,输入一个数,判断是否为回文数并输出结果。
10、编写一个C程序,输入一个年份和月份,输出该年该月的天数。
##### 数组篇11、编写一个C程序,输入一个整数数组,求所有元素之和并输出结果。
12、编写一个C程序,输入一个数组,找出最大值并输出结果。
13、编写一个C程序,输入一个数组,找出最小值并输出结果。
14、编写一个C程序,输入一个数组,计算平均值并输出结果。
15、编写一个C程序,输入一个数组,判断是否为升序或降序排列并输出结果。
16、编写一个C程序,输入一个数组,将数组元素逆序排列并输出结果。
17、编写一个C程序,输入两个数组,将两个数组合并后按照升序或降序排列并输出结果。
18、编写一个C程序,输入一个数组,输出数组中出现次数最多的元素。
19、编写一个C程序,输入一个数组,删除指定位置上的元素并输出结果。
20、编写一个C程序,输入一个数组和一个数,将该数插入到数组中并输出结果。
##### 字符串篇21、编写一个C程序,输入一个字符串,统计字符串中的字符个数并输出结果。
22、编写一个C程序,输入一个字符串,统计字符串中的单词个数并输出结果。
c语言基础100题

c语言基础100题以下是c语言基础100题:1. 编写一个程序,打印“Hello, World!”2. 编写一个程序,读取两个整数并打印它们的和。
3. 编写一个程序,读取一个整数并判断它是奇数还是偶数。
4. 编写一个程序,读取一个整数并判断它是否为质数。
5. 编写一个程序,读取一个整数并计算它的阶乘。
6. 编写一个程序,读取一个整数并打印它的逆序。
7. 编写一个程序,读取一个字符串并打印它的长度。
8. 编写一个程序,读取一个字符串并将其反转。
9. 编写一个程序,读取一个字符串并判断它是否为回文。
10. 编写一个程序,读取一个字符串并统计其中的字符、单词和行数。
11. 编写一个程序,读取一个字符串并将其中的小写字母转换为大写字母。
12. 编写一个程序,读取一个字符串并将其中的大写字母转换为小写字母。
13. 编写一个程序,读取一个字符串并打印其中每个字符的ASCII码。
14. 编写一个程序,读取一个整数并将其转换为二进制、八进制和十六进制。
15. 编写一个程序,读取两个整数并交换它们的值。
16. 编写一个程序,读取两个整数并计算它们的最大公约数和最小公倍数。
17. 编写一个程序,读取一个整数并打印出它的所有因子。
18. 编写一个程序,生成斐波那契数列的前n项。
19. 编写一个程序,读取一个字符串,并打印其中出现最多的字符。
20. 编写一个程序,读取一个字符串,并将其中的空格替换为连字符。
21. 编写一个程序,读取一个字符串并删除其中的重复字符。
22. 编写一个程序,读取一个字符串并判断它是否为合法的URL。
23. 编写一个程序,读取一个字符串并打印出其中的单词个数。
24. 编写一个程序,读取一个字符串并打印出其中的句子个数。
25. 编写一个程序,读取一个整数n并打印出前n个自然数的平方。
26. 编写一个程序,读取一个整数n并打印出前n个自然数的立方。
27. 编写一个程序,读取一个整数n并打印出前n个自然数的和。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
1. (N阶梵塔) 有K根棒,第一根上放N片大小不等的圆盘,并保持上小下大的顺序。
现将N片圆盘从第1根移至第K根,移动中均保持上小下大的顺序,问最少移几次方得结果,求出移动方案。
2. 某一印刷厂有六项加工任务,对印刷车间和装订车间所需时间见下表(时间单位:天)任务│J1 J2 J3 J4 J5 J6─────┼───────────────印刷车间│31252911装订车间│8109631如何安排加工顺序,使加工时间最少。
3. 将7万元投资到A,B,C三项目上,其利润见下表:投资额(万元)│1234567──────┼────────────────────项A│0.11 0.13 0.15 0.24 0.24 0.30 0.35B│0.12 0.16 0.21 0.25 0.25 0.29 0.34目C│0.08 0.12 0.20 0.26 0.26 0.30 0.35如何分配投资额,使获得的利润最大。
4. 无根树与通常所说的树(有根树)很相似,它包含有节点和枝,但不含有根。
无根树节点之间只有相邻关系。
如图一所示,是一棵有七个节点的无根树,以图一的A为根节点得到图二所示的有根树,以B为根节点得到图三所示的有根树,但从无根树的角度看,图一、二、三是结构相同的无根树,同时无根树的结构与节点的名称无关。
有根树可以用字符串的形式表示,其递归表示方法是:根节点(子树1子树2子树3...)图一,图二的有根树可表示为 A(B(CF(EGD))) 和 B(ACF(EGD))。
由于子树的表示顺序可以不同,所以一棵有根树可以有多种表示方法,如图三又可表示成B(F(EGD)CA) 或 B(ACF(DE(G)) 等。
表示无根树时,可以以它任一节点为根节点,将其看作有根树,从而可以利用有根树的字符串表示形式来表示无根树。
任务一:由键盘读入一个字符串表示的无根树,无根树的各节点的名称用互不相同的大写英文字母表示。
由用户输入一个节点的名称,程序应能够输出一种以该节点为根节点的字符串形式。
程序输出无根树的字符串形式时,各个节点的名称无关紧要,所有节点都以P表示,以后的各种输出也采用这种形式。
例如:输入无根树的字符串形式:A(B(CD(EF))),指定根节点为D,程序应能输出P(P(PP)PP),P(PP(PP)P),P(PPP(PP))中的任意一种即可。
任务二:输入两个串表示的无根树,判断其结构是否一样。
注意它与节点名称无关,只考虑结构。
任务三:输入无根树的总枝数N(1<=N<=11),输出所有枝数为N的互不相同的无根树,并记录总数。
以字符串形式输出,例如:N=5 时共有6种不同结构的无根树。
注意:各种树结构的字符串表达形式不唯一。
5. 用N*N(1<=N<=8)的格点阵代表海,其中*号代表岛。
给你一组编码信息,让你重构一张地图。
这组信息是按垂直方向,水平方向岛的情况摘取的。
下例中,每行右边的数字按顺序表示该行中“岛组”的大小,如第一行数字为“12”,表示该行第一“岛组”由一个岛组成,第二“岛组”由两个岛组成,而第四列下面的“23”则表示本列由两个“岛组”组成,第一个“岛组”由两个岛组成,第二个“岛组”由三个岛组成。
任务:编程执行以下步骤,直到给定的输入 (ASCII) 文件中的信息组全部读完为止,步骤如下:(1)从输入文件 (ASCII 文件)中读入下一个信息块,并将它显示在屏幕上。
每个信息块组成为:格点阵大小 (N),以后是行的约束条件(N行的),列的约束条件(N列的), 每行(或每列)的约束条件是一行数字,数字间有空格,最后用0结束。
上面的例子如图所示。
(2)重构这张地图(若有多个解,要逐个构成地图),并显示。
(3)将重构的地图以ASCII文件形式输出。
每岛以*后加一个空格表示;空白处用连续的两个空格表示。
若同一已知条件可画出多张地图,相互间用空行隔开;若一组已知条件画不出地图,用“NOMAP(占一行)表示。
由不同的信息组求得的解用“NEXTPROBLEM”(占一行表示)1<=N<=8.6. 一个餐厅在相继的N天里,第 i 天需要 Ri 块餐巾(i=1,2,...,N)。
餐厅可以从三种途径得到餐巾:(1) 购买新的餐巾,每块需P分;(2) 把用过的餐巾送到快洗部,洗一块需M天,费用需F分(F<P);(3) 把餐巾送到慢洗部,洗一块需N天(N>M),费用需S分(S<F)。
在每天结束时,餐厅必须决定将多少块用过的餐巾送到快洗部,多少块送慢洗部,多少块保存起来延期送洗。
在每天开始时,餐厅必须决定是否购买新餐巾及购买多少,使洗好的和新购的餐巾之和满足当天的需求量Ri,并使N天总的费用最小。
请编程输入总天数,每天所需的餐巾块数以及每块餐巾的新购费用P,快,慢洗费用F,S,和所需天数M,N,输出每天开始时需购新餐巾数,结束时送快,慢洗部和延期送洗的餐巾数。
7. ( 旅行商 ) 一个推销员计划做一次旅行,他必须访问如图所示每个城市。
每两个城市的路径旁标有路径。
要求从城市A出发,访问每个城市一次,且只访问一次,最后返回城市A,求一条距离最短的路线。
8. (tic__tac__toe 游戏) tic__tac__toe 游戏的规则是:从一个空的 (N*N) 的棋盘(例如N=3)开始,甲乙二人轮流将棋子放置在棋盘上未被占据的方格中,例如甲第一个放,他把棋子放在中央的方格里,然后轮到乙放,他把棋子放在第一行中间的方格里。
于是又轮到甲放,......如此进行下去。
判定胜负的方法是:若某一游戏者有N枚棋子占据了一横行,或一竖列,或一对角线,则此人获胜;若直至整个棋盘被占满还没有一方获胜,则为平局。
┏━┯━┯━┓┏━┯━┯━┓┏━┯━┯━┓┃││┃┃││┃┃│O│┃┠─┼─┼─┨┠─┼─┼─┨┠─┼─┼─┨┃││┃┃│X│┃┃│X│┃┠─┼─┼─┨┠─┼─┼─┨┠─┼─┼─┨┃││┃┃││┃┃││┃┗━┷━┷━┛┗━┷━┷━┛┗━┷━┷━┛9. 以字符串形式由键盘输入两个高精度的8进制正整数,串长小于255,以第一个数为被除数,第二个数为除数,进行高精度除法运算,并显示按 8 进制表示的商和余数。
10. ( NOI'94.1_1 ) 键盘输入一个仅由小写字母组成的字符串,输出以该串中任取M个字母的所有排列及排列总数。
11. ( NOI'94.1_2 ) 编程实现两个高精度实数减法,两数分别由键盘输入,均不超过240位。
12. ( NOI'94.1_3 ) 一个实数数列共有N项,已知a(i)=(a(i-1)-a(i+1))/2+d,(1〈i〈N)(N<60) , 键盘输入N,d,a(1),a(n),m,输出 a(m)。
13. ( NOI'94.1_4 ) 键盘输入一个高精度的正整数N,去掉其中任意S个数字后剩下的数字按原左右次序将组成一个新的正整数。
编程对给定的N和S,寻找一种方案使得剩下的数字组成的新数最小。
输出应包括所去掉的数字的位置和组成的新的正整数。
(N不超过240位)14. 在两个文本文件中各存有一个以西文制表符制成的未填入任何表项的表结构,分别称之为表1和表2,要求编程将表1和表2下述规则合并成表3:规则:表1在表2之上,表1和表2的左边框对齐,将表1的最低行与表2的最顶行合并。
例:在你的C盘根目录下有两个文件 t0.1 和 t0.2,分别存放上述的表1和表2,经上述规则合并后得到表3,放在文件中。
三张表见下图:┎─┰─┰─┰─┒┎─┰─┰─┰─┒┃┃┃┃┃┎┰─┰─┒┃┃┃┃┃┠─╂─╂─╂─┨┃┃┃┃┠─╂─╂─╂─┨┃┃┃┃┃┖┸─┸─┚┃┃┃┃┃┖─┸─┸─┸─┚┠┰┸┰┸┰┸─┚┃┃┃┃┖┸─┸─┚表1表2表3编程要求:(1) 程序应能自给定的文件中读入两个源表并显示。
(2) 若源表有错,应能指出其错。
(3) 将表1和表2规则合并成表3,并显示之。
(4) 所有制表符的ASCII码应由选手自己从给出的示例文件中截取。
15. (圆盘问题) 从左向右依次安放 4 根细柱 A,B,C,D. 在 A 上套有 N (N≤20)个直径相同的圆盘, 从下到上依次用连续的小写字母 a,b,c,...编号, 将这些圆盘经过 B, C 单向地移入 D (即不允许从右向左移动). 圆盘可在 B,C 中暂存. 从键盘输入 N, 及前 N 个小写字母的一个排列, 它表示最后在 D 盘上形成的一个从下到上的圆盘序列. 请用文本文件 ANS2.TXT 输出形成这一排列的操作过程.该文件的每一行为一个形如 "k M L" 的字母序列, 其中 k 为圆盘编号, M 为 k盘原先的柱号, L 为新柱号. 或者直接在屏幕上输出"No",表示不能生成这种排列.例: ┃┃┃┃键盘输入: ┃┃┃┃3 d ━╋━┃┃┃acb c ━╋━┃┃┃则一个正确的输出文件 b ━╋━┃┃┃可以是: a ━╋━┃┃┃c A B ━━┻━━━┻━━━┻━━━┻━b A C A B C Da A Db C Dc B D。