标题:采用深度优先搜索进行扑克牌的排序
只看楼主
Johnalex
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2015-2-11
结帖率:33.33%
已结贴  问题点数:20 回复次数:1 
采用深度优先搜索进行扑克牌的排序
程序代码:
#include<iostream>
using namespace std;
int count=0; 
int book[5];
char card[5][2]={'2','C','A','D','A','C','J','C','J','H'};
char a[5][2];
void dfs(int step){
    if(step==5){
            count++;
            return ;
    }
    for(int i=0;i<5;i++){
        if(/*a[step][0]!=a[step-1][0]&&*/book[i]==0){//判断条件该牌未被标记且与上一张的牌号不相同,但我不知道应该如何写出这条判断语句,如果我将其注释掉,则输出120,是一个全排列。如果不注释,则输出为0.
            a[step][0]=card[i][0];
            book[i]=1;//将用过的牌标记
            dfs(step+1);
            book[i]=0;//取消标记
        }
    } 
    return ;
}
int main(){
    dfs(0);
    cout<<count<<endl;
    return 0;
}




我未按照题目要求,只是给出了特定的扑克牌进行算法可行性的验证,如第三组数据所示,该程序应输出48.
现在的问题是不知如何进行条件的判断。悉心向各位请教
搜索更多相关主题的帖子: 扑克牌 color 
2015-04-27 19:36
秦时的明月夜
Rank: 7Rank: 7Rank: 7
等 级:贵宾
威 望:13
帖 子:126
专家分:504
注 册:2013-3-12
得分:20 
我感觉好像是setp+2吧…………毕竟是下一张牌……
2015-04-30 17:29



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-444571-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.165517 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved