《数据结构c语言》重言式判定------参考了别人的代码__精品.doc

《数据结构c语言》重言式判定------参考了别人的代码__精品.doc

  1. 1、本文档共6页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
《数据结构c语言》重言式判定------参考了别人的代码__精品

重言式判定------参考了别人的代码。。 2011-05-11 17:19 122人阅读 评论(0) 收藏 举报 [ 问题描述] 一个逻辑表达式如果对于其变元的任一种取值均为真,则成为重言式;反之,如果对于其变元的任一种取值都为假,则称为矛盾式,然而,更多的情况下,既非重言式,也非矛盾式。试写一个程序,通过真值表判别一个逻辑表达式属于上述哪一类。, ? [ 基本要求] (1 ) 逻辑表达式从终端输入,长度不超过一行。逻辑运算符包括 “ | ” 、 “ & ” 和 “ ~ ” ,分别表示或、与和非,运算优先程度递增,但可有括号改变,即括号内的运算优先。逻辑变元为大写字母。表达式中任何地方都可以含有多个空格符。 (2 )若是重言式或矛盾式,可以只显示 “ True? Forever ” 或 “ False Forever ” ,否则显示 “ Satisfactible ” 以及变量名序列,与用户交互。若用户对表达式变元取定一组值,程序就求出并显示逻辑表达式的值。 [ 测试数据] (1 )(A |~A )&(B|~B ) (2 )(A ~A )&C (3 )A|B|C|D|E |~A [ 实现提示] (1) 识别逻辑表达式的符号形式并建立二叉树可以有两种策略:自底向上的算符优先法和自顶向下分割,先序遍历建立二叉树的方法。 (2) 可设表达式中逻辑变量数不超过20 。真值的产生可以通过在一维数组上维护一个 “ 软计数器 ” 实现,用递归算法实现更简单。 [cpp] view plaincopyprint? #includeiostream 牋 using爊amespace爏td;牋 顶向下分struct?Arr?? {?? ???????char?letter;?? ???????int?weight;?? ???????};?? class?Cys?? {?? ??????public:?? ?????????????Cys();?? ?????????????void?GetTautology();//输入表达式? ?? ?????????????int?_CreateT(int?,int?);//虚拟创建二叉树? ?? ?????????????int?FindMin(int?,int?);//找到weight最小的? ?? ?????????????int?count();??//计算可满足式的值? ?? ?????????????void?_recursion(Arr?*_arr,int?i?);//递归,穷举? ?? ?????????????void?recursion();//使用接口函数? ?? ?????????????void?Print();//输出结果? ?? ?????????????~Cys();//析构释放空间? ?? ??????private:?? ??????????????int?num;?? ??????????????Arr?*array;?? ??????????????Arr?_arr[20];?//存放字母? ?? ??????????????int?_arrNum;??? ??????????????int?trueforever;?? ??????????????int?falseforever;?? ??????};?? ???????? ????Cys::Cys()?? ??????{?? ??????????trueforever=0;?? ??????????falseforever=0;?? ??????????array=new?Arr[20];?? ??????????for(int?i=0;i20;i++){?? ????????????????array[i].weight-1;?? ????????????????array[i].letter=0;?? ????????????????}?? ???????????????_arrNum=0;?? ???????????????num=0;?? ????????????????}?? ?void?Cys::GetTautology()?? ?{?? ??????int?has[27]={0};?? ??????int?weight=0;?? ??????char?ch;?? ????cout请输入一个逻辑表达式,以#结束endl;?? ????while(cinch???ch!=#)??? ????{?? ????????????????????? ?????????????????? ??????????????????if(ch==?)?? ????????????????

文档评论(0)

seunk + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档