C++递归算法实例代码
递归算法,总结起来具有以下几个特点: 特点1 它有一个基本部分,即直接满足条件,输出 1.Question: 本题是用枚举的思路来判断一个规定的逻辑表达式是不是永真式 首先题目意思是最多不会有超过5个逻辑变量,有五种运算
其中 K & 其中的C我们可以利用 !A | B 实现 E利用==实现 本题的主要难点并不在于实现我们的语句计算的方式 难点1: 难点2: 位运算,我们本题如果不利用位运算的话,至少需要写5层循环来模拟我们的变量的所有的情况,这样太低效了,我们将我们的所有的变量封装到一个一个字节的存储器中,每次利用位运算提取相关的位置的数字就好了(虽然我们的表达式并不会运算所有的情况,但是至少不会错) Code: #include"iostream" #include"cstdio" #include"cstdlib" #include"cstring" using namespace std; int pos=0; string data; bool cal(int i) { int t=pos++; switch(data[t]) { case 'p': return (i >> 4)&1; case 'q': return (i >> 3)&1; case 'r': return (i >> 2)&1; case 's': return (i >> 1)&1; case 't': return i&1; case 'K': return cal(i) & cal(i); case 'A': return cal(i) | cal(i); case 'N': return !cal(i); case 'C': return !cal(i) | cal(i); case 'E': return cal(i) == cal(i); } } bool isTautology() { for(int i=0;i<=31;i++) { pos=0; if(cal(i)) continue; else return false; } return true; } int main() { while(cin>>data&&data[0]!='0') { if(isTautology()) cout<<"tautology"<<endl; else cout<<"not"<<endl; } return 0; } 总结 以上就是本文关于C++递归算法实例代码的全部内容,希望对大家有所帮助。欢迎参阅:C++中函数指针详解及代码分享、C/C++ 编译器优化介绍等,有什么问题,可以随时留言,欢迎大家交流讨论。感谢朋友们对本站的支持! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |