HDU1427速算24點(dfs)
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<queue>
#include<stack>
#include<vector>
using namespace std;
int a[10];
bool dfs(int x)
{
if(x==3)
{
if(24==a[x])
return true;
else
return false;
}
int i,j;
for(i=x;i<4;i++)
{
for(j=i+1;j<4;j++)
{
int cc=a[i];
int dd=a[j];
a[i]=a[x];
a[j]=cc+dd;
if(dfs(x+1))
return true;
a[j]=cc*dd;
if(dfs(x+1))
return true;
a[j]=cc-dd;
if(dfs(x+1))
return true;
a[j]=dd-cc;
if(dfs(x+1))
return true;
if(dd!=0&&cc%dd==0)
{
a[j]=cc/dd;
if(dfs(x+1))
return true;
}
if(cc!=0&&dd%cc==0)
{
a[j]=dd/cc;
if(dfs(x+1))
return true;
}
a[i]=cc;
a[j]=dd;
}
}
return false;
}
int Change(char* ch)
{
if(ch[0]=='A')
return 1;
else if(ch[0]=='J')
return 11;
else if(ch[0]=='Q')
return 12;
else if(ch[0]=='K')
return 13;
else if(strlen(ch)==2)
return 10;
else
return ch[0]-'0';
}
int main()
{
char c[10];
while (~scanf("%s",c))
{
a[0]=Change(c);
for(int i=1;i<4;i++)
{
scanf("%s",c);
a[i]=Change(c);
}
if(dfs(0))
printf("Yes\n");
else
printf("No\n");
memset(a, 0, sizeof(a));
}
return 0;
}
相關文章
- HDU 1427-速算24點(DFS)
- 撲克牌速算24 -窮舉(JavaScript)JavaScript
- leetcode 679. 24 Game(遊戲24點)LeetCodeGAM遊戲
- dfs列印有向圖的起點到終點路徑
- DFS
- 24點 Pascal大暴力程式
- 每天進步一點點 2020/09/24
- DFS樹
- dfs序
- dfs技巧
- JS實現24點遊戲JS遊戲
- Python實現24點遊戲Python遊戲
- Tempter of the Bone(DFS)
- 深搜dfs
- iOS 小遊戲專案——數字速算升級版iOS遊戲
- 你來寫,“Calca”來快速算出計算結果
- Python秒算24點,行還是不行?Python
- 24-分析要點:怎麼辦(2)
- Prime Ring Problem (dfs)
- DAG bfs + dfs 126,
- 樹的DFS序
- LightOJ1074 Extended Traffic【SPFA+DFS 標記負環的結點】
- DFS演算法原理演算法
- 圖的dfs_euler
- DFS序例題+感受
- DFS入門筆記筆記
- DFS(深度優先搜尋)
- 【題目整理】dfs入門
- 9*9的數獨(dfs)
- DFS剪枝最佳化策略
- 關於元素排列的DFS
- DFS實現拓撲排序排序
- P1219 八皇后(dfs)
- bzoj4500: 矩陣(dfs)矩陣
- PHP歷理 做一個計算24點的功能PHP
- 求樹的直徑(BFS/DFS)
- dfs的return時機問題
- 聊聊演算法——BFS和DFS演算法