DFS_3
来源:互联网 发布:生物医药大数据 编辑:程序博客网 时间:2024/05/16 14:31
经典的24点问题,包含了很多细节处理
1. STL中next_permutation全排列,具体用法我忘了,当时是百度的,现在再抄一遍
1:从后向前比较相邻的两个元素,直到前一个元素小于后一个元素,停止
2:如果已经没有了前一个元素,则说明这个排列是递减的,所以这个排列是没有下一个排列的。
所以源代码先升序排序,然后全排列就可以把所以情况都列一遍。
2.除法限制条件较多,要特别处理
3.输入char型并预处理A,J,Q,K,int -‘0’相当于得到数字本身
4.注意加括号的等价方法(当初想了好久)
#include<iostream>#include<cstdio>#include<cstring>#include<cstdlib>#include<algorithm>using namespace std;int flag;int num[4];int cmp(const void *a,const void *b){return *(int *)a-*(int *)b;}/*标记很重要,可以用来作为退出的条件*/void dfs(int sum,int cur,int m)/*分前后两个位置,2*4除法特别处理,dfs位置替换相当于添加括号*/{if(flag)return;if(m==3){if(sum+cur==24||sum-cur==24||sum*cur==24)flag=1;if(cur!=0&&sum%cur==0&&sum/cur==24)flag=1;return;}dfs(sum+cur,num[m+1],m+1); //先计算前一部分dfs(sum-cur,num[m+1],m+1);dfs(sum*cur,num[m+1],m+1);if(cur!=0&&sum%cur==0)dfs(sum/cur,num[m+1],m+1);dfs(sum,cur+num[m+1],m+1); //先计算后一部分,相当于加括号dfs(sum,cur-num[m+1],m+1); dfs(sum,cur*num[m+1],m+1);if(num[m+1]!=0&&cur%num[m+1]==0)dfs(sum,cur/num[m+1],m+1);}int main(){int i;char str[5];while(scanf("%s",str)!=EOF){if(strlen(str)==2)num[0]=10;else{if(str[0]=='A')num[0]=1;else if(str[0]=='J')num[0]=11;else if(str[0]=='Q')num[0]=12;else if(str[0]=='K')num[0]=13;elsenum[0]=str[0]-'0';/*str-'0'相当于把char型的数字转化为int型的数字*/}for(i=1;i<=3;i++){scanf("%s",str);if(strlen(str)==2) num[i]=10; else{ if(str[0]=='A') num[i]=1; else if(str[0]=='J') num[i]=11; else if(str[0]=='Q') num[i]=12; else if(str[0]=='K') num[i]=13; else num[i]=str[0]-'0';}}qsort(num,4,sizeof(num[0]),cmp);//快速排序flag=0;do{dfs(num[0],num[1],1);}while(next_permutation(num,num+4)&&!flag);//全排列if(flag)printf("Yes\n");elseprintf("No\n");}return 0;}
0 0
- DFS_3
- Exception
- 使用Collections.sort对List进行排序
- window.location传递参数
- 搜狗——火眼金睛
- FrameLayout(层布局或者帧布局)的使用
- DFS_3
- C#类修饰符种类及简介
- ORACLE-REGEXP_SUBSTR函数使用方法汇总
- OSX安装Redmine Could not locate Gemfile or .bundle/directory
- 电脑上访问一个网页,整个过程是怎么样的
- poj 3695 && hdu 2461
- linux操作串口的代码,linux串口通信以及串口初始化代码,linux串口读写方法和代码
- 用栈实现Fibnacci递归过程的非递归算法
- 【Android动画】之Tween动画 (渐变、缩放、位移、旋转)