在电脑玩家跟牌和出牌之前首先对电脑玩家的牌进行拆分:

根据文档需求(见本博客“斗地主规则“)拆分牌按以下顺序,先分析炸弹---飞机---连对---连牌--三带,对子,单张。请看如下代码:

void GameScene::FenChaiNpcPai(Player* npc){
    /************************************************************************/
    /* 1.首先分析出来牌的类型(如:四张,三张,两张,一张)                                              */
    /************************************************************************/
    std::vector<PaiXing> vec;
    PaiXing xing;
    CCArray* arr = CCArray::create();//临时数组
    arr->addobjectsFromArray(npc->getArrPk());
    //提取双鬼
    Poker* pk = (Poker *)arr->objectAtIndex(0);
    Poker* pk1 = (Poker *)arr->objectAtIndex(1);
    if(pk->getHuaSe() == Gui && pk1->getHuaSe() == Gui){
        xing.type = BOMB_CARD;
        xing.vec.push_back(pk);
        xing.vec.push_back(pk1);
        arr->removeObject(pk);
        arr->removeObject(pk1);
        vec.push_back(xing);
    }
    //分析牌型
    for(int i=0; i<arr->count();)
    {
        pk = (Poker*)arr->objectAtIndex(i);
        xing.vec.clear();//清除数组
        //找出与pk相同的牌
        for (int j=i; j<arr->count(); ++j)
        {
            pk1 = (Poker*)arr->objectAtIndex(j);
            if(pk->getNum() == pk1->getNum())
            {
                ++i;
                xing.vec.push_back(pk1);
            }
            else
            {
                break;
            }
        }
        if(xing.vec.size() == 4)
            xing.type = BOMB_CARD;
        if(xing.vec.size() == 3)
            xing.type = THREE_CARD;
        if(xing.vec.size() == 2)
            xing.type = DOUBLE_CARD;
        if(xing.vec.size() == 1)
            xing.type = SINGLE_CARD;
        vec.push_back(xing);
    }
    /************************************************************************/
    /* 2.按优先级(先分析炸弹---飞机---连对---连牌--三带,对子,单张)提取牌型并保存用于出牌或跟牌                               */
    /************************************************************************/
    //提取炸弹
    for(std::vector<PaiXing>::iterator iter = vec.begin(); iter != vec.end(); )
    {
        if(iter->type == BOMB_CARD)
        {
            xing.type = BOMB_CARD;
            xing.vec.clear();
            xing.vec = iter->vec;
            npc->m_vecPX.push_back(xing);//把牌型保存到用户数组中
            iter = vec.erase(iter);
        }
        else
        {
            ++iter;
        }
    }
    //提取飞机
    TiQuFeiJi(npc,THREE_CARD,vec);
    //提取连对
    TiQuLianDui(npc,vec);
    //提取连牌
    TiQuLianPai(npc,vec);
    //剩余的是三带,对子,单张 全部加入npc牌型中
    for(std::vector<PaiXing>::iterator iter = vec.begin(); iter != vec.end();)
    {
        npc->m_vecPX.push_back(*iter);
        iter = vec.erase(iter);
    }
    //排序
    stable_sort(npc->m_vecPX.begin(),npc->m_vecPX.end(),isShorter1);
}
最后按每个牌型的值从小到大进行排序。

提取飞机代码:

void GameScene::TiQuFeiJi(Player* npc,CARD_TYPE type,std::vector<PaiXing> &vec){
    Poker * pk = NULL;
    PaiXing xing;
    for (std::vector<PaiXing>::iterator iter=vec.begin(); iter != vec.end();)
    {
        if(pk == NULL && iter+1 == vec.end())
            break;
        if(pk == NULL && iter->type == type && (iter+1)->type == type)
        {
            Poker* pk1 = iter->vec.front();
            Poker* pk2 = (iter+1)->vec.front();
            if(pk1->getNum()-1 == pk2->getNum())
            {
                pk = pk2;
                xing.type = AIRCRAFT_CARD;
                xing.vec.clear();
                xing.vec = iter->vec;
                iter = vec.erase(iter);
                xing.vec.insert(xing.vec.end(),iter->vec.begin(),iter->vec.end());
                iter = vec.erase(iter);
            }
        }
        if(pk != NULL)
        {
            if(iter == vec.end())
            {
                npc->m_vecPX.push_back(xing);
                break;
            }
            
            Poker* pk1 = iter->vec.front();
            if(iter->type == type && pk->getNum()-1 == pk1->getNum())
            {
                pk = pk1;
                xing.vec.insert(xing.vec.end(),iter->vec.end());
                iter = vec.erase(iter);
                if(iter == vec.end())
                {
                    npc->m_vecPX.push_back(xing);
                    break;
                }
            }
            else
            {
                npc->m_vecPX.push_back(xing);
                pk = NULL;
            }
        }
        else
        {
            ++iter;
        }
    }
}
提取连对 代码:
void GameScene::TiQuLianDui(Player* npc,std::vector<PaiXing> &vec){
    std::vector<PaiXing> vecTem;//临时数组
    std::vector<PaiXing> vecFan;//存放要重新返还vec里的牌
    Poker* pk = NULL;
    for(std::vector<PaiXing>::iterator iter = vec.begin(); iter != vec.end();)
    {
        //将相连的牌加入临时数组中
        Poker* pk1 = iter->vec.front();
        if((iter->type == THREE_CARD || iter->type == DOUBLE_CARD) && (pk == NULL || (pk->getNum()-1 == pk1->getNum() && pk->getNum() < Er)))
        {
            pk = pk1;
            vecTem.push_back(*iter);
            iter = vec.erase(iter);
        }
        else
        {
            if(pk == NULL)
                ++iter;
            pk = NULL;
            if(vecTem.size() >= 3)
            {
                PaiXing xing;
                xing.type = COMPANY_CARD;
                for (int i=0; i<vecTem.size(); ++i)
                {
                    if(vecTem[i].type == THREE_CARD)
                    {
                        //将多余的一张保存返回数组vecFan中
                        PaiXing xing1;
                        xing1.type = SINGLE_CARD;
                        xing1.vec.push_back(vecTem[i].vec.back());
                        vecTem[i].vec.pop_back();
                        vecFan.push_back(xing1);
                        //将剩余两张保存xing中
                        xing.vec.insert(xing.vec.end(),vecTem[i].vec.begin(),vecTem[i].vec.end());
                    }
                    if(vecTem[i].type == DOUBLE_CARD)
                    {
                        xing.vec.insert(xing.vec.end(),vecTem[i].vec.end());
                    }
                }
                vecTem.clear();
                npc->m_vecPX.push_back(xing);
            }
            else if(!vecTem.empty())
            {
                vecFan.insert(vecFan.end(),vecTem.begin(),vecTem.end());
                vecTem.clear();
            }
        }
    }
    if(!vecTem.empty())
    {
        if(vecTem.size() >= 3)
        {
            PaiXing xing;
            xing.type = COMPANY_CARD;
            for (int i=0; i<vecTem.size(); ++i)
            {
                if(vecTem[i].type == THREE_CARD)
                {
                    //将多余的一张保存返回数组vecFan中
                    PaiXing xing1;
                    xing1.type = SINGLE_CARD;
                    xing1.vec.push_back(vecTem[i].vec.back());
                    vecTem[i].vec.pop_back();
                    vecFan.push_back(xing1);
                    //将剩余两张保存xing中
                    xing.vec.insert(xing.vec.end(),vecTem[i].vec.end());
                }
                if(vecTem[i].type == DOUBLE_CARD)
                {
                    xing.vec.insert(xing.vec.end(),vecTem[i].vec.end());
                }
            }
            vecTem.clear();
            npc->m_vecPX.push_back(xing);
        }
        else if(!vecTem.empty())
        {
            vecFan.insert(vecFan.end(),vecTem.end());
            vecTem.clear();
        }
    }
    //将vecFan返回到vec数组中并从大到小排序
    if(!vecFan.empty())
    {
        vec.insert(vec.end(),vecFan.begin(),vecFan.end());
        stable_sort(vec.begin(),vec.end(),isDaDaoXiao);
    }
}
提取连牌 代码:
void GameScene::TiQuLianPai(Player* npc,std::vector<PaiXing> &vec){
    std::vector<PaiXing> vecTem;//临时数组
    std::vector<PaiXing> vecFan;//存放要重新返还vec里的牌
    Poker* pk = NULL;
    for(std::vector<PaiXing>::iterator iter = vec.begin(); iter != vec.end();)
    {
        //将相连的牌加入临时数组中
        Poker* pk1 = iter->vec.front();
        if((iter->type == THREE_CARD || iter->type == DOUBLE_CARD || iter->type == SINGLE_CARD) && (pk == NULL || (pk->getNum()-1 == pk1->getNum() && pk->getNum() < Er)))
        {
            pk = pk1;
            vecTem.push_back(*iter);
            iter = vec.erase(iter);
        }
        else
        {
            if(pk == NULL)
                ++iter;
            pk = NULL;
            if(vecTem.size() >= 5)
            {
                PaiXing xing;
                xing.type = CONNECT_CARD;
                for (int i=0; i<vecTem.size(); ++i)
                {
                    if(vecTem[i].type == THREE_CARD)
                    {
                        //将多余的两张保存返回数组vecFan中
                        PaiXing xing1;
                        xing1.type = DOUBLE_CARD;
                        xing1.vec.push_back(vecTem[i].vec.back());
                        vecTem[i].vec.pop_back();
                        xing1.vec.push_back(vecTem[i].vec.back());
                        vecTem[i].vec.pop_back();
                        vecFan.push_back(xing1);
                        //将剩余一张保存xing中
                        xing.vec.insert(xing.vec.end(),vecTem[i].vec.end());
                    }
                    if(vecTem[i].type == DOUBLE_CARD)
                    {
                        //将多余的一张保存返回数组vecFan中
                        PaiXing xing1;
                        xing1.type = SINGLE_CARD;
                        xing1.vec.push_back(vecTem[i].vec.back());
                        vecTem[i].vec.pop_back();
                        vecFan.push_back(xing1);
                        //将剩余一张保存xing中
                        xing.vec.insert(xing.vec.end(),vecTem[i].vec.end());
                    }
                    if(vecTem[i].type == SINGLE_CARD)
                        xing.vec.push_back(vecTem[i].vec.front());
                }
                vecTem.clear();
                npc->m_vecPX.push_back(xing);
            }
            else if(!vecTem.empty())
            {
                vecFan.insert(vecFan.end(),vecTem.end());
                vecTem.clear();
            }
        }
    }
    if(!vecTem.empty())
    {
        if(vecTem.size() >= 5)
        {
            PaiXing xing;
            xing.type = CONNECT_CARD;
            for (int i=0; i<vecTem.size(); ++i)
            {
                if(vecTem[i].type == THREE_CARD)
                {
                    //将多余的两张保存返回数组vecFan中
                    PaiXing xing1;
                    xing1.type = DOUBLE_CARD;
                    xing1.vec.push_back(vecTem[i].vec.back());
                    vecTem[i].vec.pop_back();
                    xing1.vec.push_back(vecTem[i].vec.back());
                    vecTem[i].vec.pop_back();
                    vecFan.push_back(xing1);
                    //将剩余一张保存xing中
                    xing.vec.insert(xing.vec.end(),vecTem[i].vec.end());
                }
                if(vecTem[i].type == DOUBLE_CARD)
                {
                    //将多余的一张保存返回数组vecFan中
                    PaiXing xing1;
                    xing1.type = SINGLE_CARD;
                    xing1.vec.push_back(vecTem[i].vec.back());
                    vecTem[i].vec.pop_back();
                    vecFan.push_back(xing1);
                    //将剩余一张保存xing中
                    xing.vec.insert(xing.vec.end(),vecTem[i].vec.end());
                }
                if(vecTem[i].type == SINGLE_CARD)
                    xing.vec.push_back(vecTem[i].vec.front());
            }
            vecTem.clear();
            npc->m_vecPX.push_back(xing);
        }
        else if(!vecTem.empty())
        {
            vecFan.insert(vecFan.end(),isShorter1);
    }
}

cocos2dx《单机斗地主》源码解剖之七 对电脑玩家手中的牌进行分拆的更多相关文章

  1. HTML实现代码雨源码及效果示例

    这篇文章主要介绍了HTML实现代码雨源码及效果示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  2. 在编译时编译Xcode中的C类错误:stl vector

    我有一个C类,用gcc和可视化工作室中的寡妇在linux上编译.boid.h:并在boid.cpp中:但是,当我在Xcode中编译此代码时,我收到以下错误:有任何想法吗?我以为你可以使用C/C++代码并在Xcode中编译没有问题?.m文件被视为具有Objective-C扩展名的.c文件..mm文件被视为具有Objective-C扩展名的.cpp文件,那么它被称为Objective-C只需将.m文件重命名为.mm,右键单击或按住Ctrl键并在Xcode中的文件中选择重命名.

  3. 源码推荐:简化Swift编写的iOS动画,iOS Material Design库

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  4. swift皮筋弹动发射飞机ios源码

    这是一个款采用swift实现的皮筋弹动发射飞机游戏源码,游戏源码比较详细,大家可以研究学习一下吧。

  5. swift 写的app 源码,保存一下下

    http://www.topthink.com/topic/3345.htmlhttp://www.csdn.net/article/2015-01-09/2823502-swift-open-source-libs

  6. swift 源码网站 code4app

    http://code4app.com/ios/HTHorizontalSelectionList/54cb2c94933bf0883a8b4583http://123.th7.cn/code/DMPagerViewController_2522.html

  7. OpenStack Swift源码导读:业务整体架构和Proxy进程

    OpenStack的源码分析在网上已经非常多了,针对各个部分的解读亦是非常详尽。其中proxy是前端的业务接入进程。account、container和object目录分别是账户、容器和对象的业务处理逻辑进程。各个业务进程或模块之间的逻辑关系可以参考《OpenstackSwift简介》文中的架构图。在《OpenstackSwift简介》从理论上面介绍了具体的节点寻找过程。

  8. 源码推荐(7.21):顶部滑动菜单FDSlideBar,Swift版无限循环轮播图

    顶部滑动菜单FDSlideBarFDSlideBar是一个顶部滑动菜单,如常见的网易、腾讯新闻等样式。菜单间切换流畅,具有较好的体验性。测试环境:Xcode6.2,iOS6.0以上Swift版无限循环轮播图无限循环轮播图片点击代理可设置图片Url的数组Url和本地图片混合轮播测试环境:Xcode6.2,iOS7.0以上弹幕系统实现--QHDanumuDemo说明:QHDanmu文件夹下是主要的弹幕模块系统,QHDanmuSend文件夹下是简单的发射弹幕的界面。

  9. swift2 运算符函数

    运算符函数前置或后置运算符函数前标注prefix或postfix组合赋值表达式比较运算符自定义运算符在自定义运算符中还可以设定自定义运算符的优先级和结合性,来处理更复杂的任务。

  10. openstack swift和wsgi源码分析1 HTTP请求处理过程

    分析proxy-server代理服务的执行流程,其他的三个主要服务accountserver,containerserver,objectserver执行过程通proxyserver类似。入口函数调用run_wsgi,此函数完成以下工作:下面重点研究下process_request函数是如何把消息转化为HTTP的request对象这一过程。process_request函数,生成HttpProtocol对象,并执行init操作,注意,HttpProtocol对象自身没有init函数,所以会调用父类的父类的

随机推荐

  1. 【cocos2d-x 3.x 学习笔记】对象内存管理

    Cocos2d-x的内存管理cocos2d-x中使用的是上面的引用计数来管理内存,但是又增加了一些自己的特色。cocos2d-x中通过Ref类来实现引用计数,所有需要实现内存自动回收的类都应该继承自Ref类。下面是Ref类的定义:在cocos2d-x中创建对象通常有两种方式:这两中方式的差异可以参见我另一篇博文“对象创建方式讨论”。在cocos2d-x中提倡使用第二种方式,为了避免误用第一种方式,一般将构造函数设为protected或private。参考资料:[1]cocos2d-x高级开发教程2.3节[

  2. 利用cocos2dx 3.2开发消灭星星六如何在cocos2dx中显示中文

    由于编码的不同,在cocos2dx中的Label控件中如果放入中文字,往往会出现乱码。为了方便使用,我把这个从文档中获取中文字的方法放在一个头文件里面Chinese.h这里的tex_vec是cocos2dx提供的一个保存文档内容的一个容器。这里给出ChineseWords,xml的格式再看看ChineseWord的实现Chinese.cpp就这样,以后在需要用到中文字的地方,就先include这个头文件然后调用ChineseWord函数,获取一串中文字符串。

  3. 利用cocos2dx 3.2开发消灭星星七关于星星的算法

    在前面,我们已经在GameLayer中利用随机数初始化了一个StarMatrix,如果还不知道怎么创建星星矩阵请回去看看而且我们也讲了整个游戏的触摸事件的派发了。

  4. cocos2dx3.x 新手打包APK注意事项!

    这个在编译的时候就可以发现了比较好弄这只是我遇到的,其他的以后遇到再补充吧。。。以前被这两个问题坑了好久

  5. 利用cocos2dx 3.2开发消灭星星八游戏的结束判断与数据控制

    如果你看完之前的,那么你基本已经拥有一个消灭星星游戏的雏形。开始把剩下的两两互不相连的星星消去。那么如何判断是GameOver还是进入下一关呢。。其实游戏数据贯穿整个游戏,包括星星消除的时候要加到获得分数上,消去剩下两两不相连的星星的时候的加分政策等,因此如果前面没有做这一块的,最好回去搞一搞。

  6. 利用cocos2dx 3.2开发消灭星星九为游戏添加一些特效

    needClear是一个flag,当游戏判断不能再继续后,这个flag变为true,开始消除剩下的星星clearSumTime是一个累加器ONE_CLEAR_TIME就是每颗星星消除的时间2.连击加分信息一般消除一次星星都会有连击信息和加多少分的信息。其实这些combo标签就是一张图片,也是通过控制其属性或者runAction来实现。源码ComboEffect.hComboEffect.cpp4.消除星星粒子效果消除星星时,为了实现星星爆裂散落的效果,使用了cocos2d提供的粒子特效引擎对于粒子特效不了

  7. 02 Cocos2D-x引擎win7环境搭建及创建项目

    官网有搭建的文章,直接转载记录。环境搭建:本文介绍如何搭建Cocos2d-x3.2版本的开发环境。项目创建:一、通过命令创建项目前面搭建好环境后,怎样创建自己的Cocos2d-x项目呢?先来看看Cocos2d-x3.2的目录吧这就是Cocos2d-x3.2的目录。输入cocosnew项目名–p包名–lcpp–d路径回车就创建成功了例如:成功后,找到这个项目打开proj.win32目录下的Hello.slnF5成功了。

  8. 利用cocos2dx 3.2开发消灭星星十为游戏添加音效项目源码分享

    一个游戏,声音也是非常的重要,其实cocos2dx里面的简单音效引擎的使用是非常简单的。我这里只不过是用一个类对所有的音效进行管理罢了。Audio.hAudio.cpp好了,本系列教程到此结束,第一次写教程如有不对请见谅或指教,谢谢大家。最后附上整个项目的源代码点击打开链接

  9. 03 Helloworld

    程序都有一个入口点,在C++就是main函数了,打开main.cpp,代码如下:123456789101112131415161718#include"main.h"#include"AppDelegate.h"#include"cocos2d.h"USING_NS_CC;intAPIENTRY_tWinMain{UNREFERENCED_ParaMETER;UNREFERENCED_ParaMETER;//createtheapplicationinstanceAppDelegateapp;return

  10. MenuItemImage*图标菜单创建注意事项

    学习cocos2dx,看的是cocos2d-x3.x手游开发实例详解,这本书错误一大把,本着探索求知勇于发现错误改正错误的精神,我跟着书上的例子一起调试,当学习到场景切换这个小节的时候,出了个错误,卡了我好几个小时。

返回
顶部