第十一周作业

本周作业头

这个作业属于哪个课程 C语言程序设计II
这个作业要求在哪里 https://edu.cnblogs.com/campus/zswxy/software-engineering-class2-2018/homework/3201
我在这个课程的目标是 学会用递归函数这种技巧性强的函数解决问题
这个作业在哪个具体方面帮助我实现目标 题目汉诺塔问题的运用
参考文献 c语言程序设计(第3版)

选择题

7-1 汉诺塔问题* (10 分)


汉诺塔是一个源于印度古老传说的益智玩具。据说大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘,大梵天命令僧侣把圆盘移到另一根柱子上,并且规定:在小圆盘上不能放大圆盘,每次只能移动一个圆盘。当所有圆盘都移到另一根柱子上时,世界就会毁灭。
请编写程序,输入汉诺塔圆片的数量,输出移动汉诺塔的步骤。

输入格式

圆盘数 起始柱 目的柱 过度柱

输出格式

移动汉诺塔的步骤
每行显示一步操作,具体格式为:
盘片号: 起始柱 -> 目的柱
其中盘片号从 1 开始由小到大顺序编号。

输入样例

3
a c b

输出样例

2: a -> b
1: c -> b
3: a -> c
1: b -> a
2: b -> c
1: a -> c

实验代码:

#include<stdio.h>
void hano(int n,char x,char y,char z);
int main ()
{
    int n;
    char x,y,z;
    scanf("%d\n",&n);
    scanf("%c %c %c ",&x,&y,&z);
    hano(n,x,y,z);
}
void hano(int n,char x,char y,char z)
{
    if(n==1)
    {
        printf("%d: %c -> %c\n",n,x,y);
    }
    else
    {
        hano(n-1,x,z,y);
        printf("%d: %c -> %c\n",n,x,y);
        hano(n-1,z,y,x);
    }
}

设计思路:

遇到的问题及解决方法

没有

实验截图

7-2 估值一亿的AI核心代码 (20 分)

以上图片来自新浪微博。
本题要求你实现一个稍微更值钱一点的 AI 英文问答程序,规则是:
无论用户说什么,首先把对方说的话在一行中原样打印出来;
消除原文中多余空格:把相邻单词间的多个空格换成 1 个空格,把行首尾的空格全部删掉,把标点符号前面的空格删掉;
把原文中所有大写英文字母变成小写,除了 I;
把原文中所有独立的 can you、could you 对应地换成 I can、I could—— 这里“独立”是指被空格或标点符号分隔开的单词;
把原文中所有独立的 I 和 me 换成 you;
把原文中所有的问号 ? 换成惊叹号 !;
在一行中输出替换后的句子作为 AI 的回答。

输入格式:

输入首先在第一行给出不超过 10 的正整数 N,随后 N 行,每行给出一句不超过 1000 个字符的、以回车结尾的用户的对话,对话为非空字符串,仅包括字母、数字、空格、可见的半角标点符号。

输出格式:

按题面要求输出,每个 AI 的回答前要加上 AI: 和一个空格。

输入样例:

6
Hello ?
 Good to chat   with you
can   you speak Chinese?
Really?
Could you show me 5
What Is this prime? I,don 't know

输出样例:

Hello ?
AI: hello!
 Good to chat   with you
AI: good to chat with you
can   you speak Chinese?
AI: I can speak chinese!
Really?
AI: really!
Could you show me 5
AI: I could show you 5
What Is this prime? I,don 't know
AI: what Is this prime! you,don't know

实验代码:

来源:百度

7-3 ***八皇后问题 (20 分)

在国际象棋中,皇后是最厉害的棋子,可以横走、直走,还可以斜走。棋手马克斯·贝瑟尔 1848 年提出著名的八皇后问题:即在 8 × 8 的棋盘上摆放八个皇后,使其不能互相攻击 —— 即任意两个皇后都不能处于同一行、同一列或同一条斜线上。
现在我们把棋盘扩展到 n × n 的棋盘上摆放 n 个皇后,请问该怎么摆?请编写程序,输入正整数 n,输出全部摆法(棋盘格子空白处显示句点“.”,皇后处显示字母“Q”,每两格之间空一格)。

输入格式

正整数 n (0 < n ≤ 12)

输出格式

若问题有解,则输出全部摆法(两种摆法之间空一行),否则输出 None。
要求:试探的顺序逐行从左往右的顺序进行,请参看输出样例2。

输入样例1

3

输出样例1

None

输入样例2

6

输出样例2

. Q . . . .
. . . Q . .
. . . . . Q
Q . . . . .
. . Q . . .
. . . . Q .

. . Q . . .
. . . . . Q
. Q . . . .
. . . . Q .
Q . . . . .
. . . Q . .

. . . Q . .
Q . . . . .
. . . . Q .
. Q . . . .
. . . . . Q
. . Q . . .

. . . . Q .
. . Q . . .
Q . . . . .
. . . . . Q
. . . Q . .
. Q . . . .

实验代码

来源 搜狗引擎
完全看不了

思路

这周的题目偏难,所以不是很能够下手、

学习进度条

周/日期 这周所花的时间 代码行 学到的知识点简介 目前比较迷惑的问题
2/25-3/3 三天 45 数组的认识及用法 数组长度的理解
3/4-3/10 四天 38 文件的处理问题 文件指针的用法
3/11-3/16 三天 52 二维数组的使用及文件插入 二维数组的用法、上三角的判断及文件的处理
3/17-3/24 三天 102 用一维数组和二维数组编程 冒泡算法的运用
3/25-3/29 三天 66 学会规范的画流程图,认识了字符串 进制之间的转换的代码
4/1-4/5 三天 78 理解变量,内存和地址之间的关系
4/8-4/12 三天 154 数组名作为函数参数的用法 如何运用在字符串中
4/15-4/19 两天 123 学会用指针实现内存动态分布 不是很清楚怎样使用动态分配
4/20-4/26 三天 77 结构数组,结构变量以及结构指针的运用 无类型名定义有点不清楚
4/30-5-2 两天 0 回答
5/4-5/10 三天 23 递归函数的运用 汉诺塔问题

学习总结

这次的课程我觉得有点难,自己不怎么明白。

编程总结

没有一起编程所以没有总结

折线图

时间 代码行数 博客字数
第一周 45 427
第二周 38 316
第三周 52 696
第四周 102 1117
第五周 66 1842
第六周 78 1193
第七周 154 1713
第八周 123 1712
第九周 77 1830
第十周 0 1257
第十一周 23 1909
posted @ 2019-05-10 19:06  丁震  阅读(127)  评论(0编辑  收藏  举报