- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
《数据结构》实验和课程设计报告
姓名:周环
学号:1043041010
学院:计算机学院
班级:一班
专家系统应用——动物游戏
设计目的和内容
设计目的:通过本次试验进一步掌握二叉树的链式存储结构以及对二叉树的遍历,查找,插入,删除等基本操作
设计内容
= 1 \* GB2 ⑴程序的用户作为玩家的角色,计算机是猜家的角色
= 2 \* GB2 ⑵程序保存了一个基本问题的知识,每一个问题让他减少考虑中的动物数。当程序减少它的考虑到仅一只动物,它就猜这个动物。假如猜者是对的,程序赢了。否则,程序问玩家他或她想的动物的名字。然后问如何区分新的动物和所猜的动物。之后保存这个问题并且存储这个新的动物在下一次玩的游戏的基本知识中
判断是否为问题进入右子树进入左子数输入回答计算机提问初始化决策树开始二.算法的基本思想
判断是否为问题
进入右子树
进入左子数
输入回答
计算机提问
初始化决策树
开始
NY判断回答内容
N
Y
判断回答内容
Y
Y
N
N
= 1 \* GB3 ①
YN存储新内容到知识库输出计算机赢输出人赢结束判断是否正确得出结论 = 1 \* GB3 ①
Y
N
存储新内容到知识库
输出计算机赢
输出人赢
结束
判断是否正确
得出结论
测试数据
源程序主要代码
主函数
int main(void){
GameOfAnimal animal;
animal.Run();
}
动物游戏类
class GameOfAnimal
{
private:
//动物游戏类的数据成员:
BinaryTreeString * pDTree; //决策树
//辅助函数:
void WriteHelp(BinTreeNodeString* root,ofstream outFile)
//写决策树信息
bool IsQuestion(String strSentence); //是否为疑问句
public:
//公有函数
GameOfAnimal();
virtual ~GameOfAnimal();
void Run();
};
类函数实现
void GameOfAnimal::Run()
//操作结果:运行动物游戏
{
coutWelcome to the anmimal game!!!endl;
do
{
coutThink of an animal and I will try to guess.endlp;
BinTreeNodeString*p=pDTree-GetRoot(); //根节点开始进行处理
String strELem=p-data; //决策树元素
while(IsQuestion(strELem))
{//疑问句,为决策树分支节点
coutstrELem;
coutPlease answer;
if (UserSaysYes()) p=p-leftChild;
else p=p-rightChild;
strElem=P-data;
}
coutThe animal you are thinking of now isstrElem?endl;
if(UserSaysYes())
{//肯定回答
coutThe computer is so clever!endl;
}
else
{//否定回答
coutThe computer is wrong!endl;
coutSo,what is the animal in your mind?endl;
Sring strNewAnimal,strOldAnimal=strElem; //动物名词
cinstrNewAnimal;
cinPlease input a question,and the true answer is strNewAnimal
,the wrong answer is strOldAnimalendl;
cinstrElem;
p-data=strElem;
P-leftChild=new BinTreeNodeString(strNewAnimal);
P-rightChild=new BinTreeNodeString(strOldAnimal);
}
coutDo you want to have a try again? Please answer.;
}while(UserSaysYes());
}
void G
您可能关注的文档
最近下载
- 品管基础知识培训课件.pptx VIP
- 人教版数学小学三年级上册《口算乘法》说课稿.doc VIP
- 2019冀教版高中英语必修二单词表.docx VIP
- (高清版)C-H-T 8024-2011 机载激光雷达数据获取技术规范.pdf VIP
- 工厂有关员工权益保护的四个政策(反骚扰、虐待、强迫、歧视).doc VIP
- 2025年河北机关事业单位工人技能等级考试(仓库保管员·中级)历年参考题库含答案详解.docx VIP
- 全国化工大赛-恒逸石化杯-中石化茂名分公司乙烯厂建造年产4.9万吨的醋酸乙烯酯3-反应器的选型与设计说明书.docx VIP
- 干部履历表填写范本(中共中央组织部1999年).doc VIP
- 2025陕西公需课党的二十届三中全会精神解读与高质量发展答案.docx VIP
- 正交曲线壳体物理方程.ppt VIP
原创力文档


文档评论(0)