扑克牌最优组合算法题(动态规划+备忘录+快排)

news2025/1/7 9:18:08

 题目如下

题目:
设一副包含点数从A到K,四种花色的52张牌, 将 三张及以上同点数不同花色的牌组 或者三张以及上的同花顺称为 `组合`,
求出给定一副20张以内的牌中,所能形成的最优的组合列表(最优即组合点数累加最大)
代码要运行正确而且要做输入处理,输出格式要按要求输出

实现代码:使用nodejs运行的,版本16.8.0

const { exit } = require('process')
var shuffle = require('shuffle-array')

//定义54张牌
color = ['红心','方块','梅花','黑桃']
num = ['1','2','3','4','5','6','7','8','9','10','11','12','13']
cards = []
cards_num = 20
// colors = []

//相同点数的牌
tong = []
//顺子
shunzi = []


//一副牌
for (i of color) {
    for (el of num) {
        cards.push(i + el)
    }       
}
    
console.log("初始化扑克牌, 共 " + cards.length + " 张")
console.log("打乱牌")
shuffle(cards)

console.log("取" + cards_num + "张")
cards = cards.slice(0,cards_num)
// console.log(cards)
cards = kuaipai(cards)
console.log(cards)

tong = calTong(cards)
console.log("大小相同的牌")
console.log(tong)

shunzi = calShunZi(cards)
console.log("所有顺子")
console.log(shunzi)

maxComb()

//快速排序
function kuaipai(cards)
{
    if (cards.length <= 1) {
        return cards
    }

    var left = [] , right = []
    var cards0 = parseInt(cards[0].substr(2))
    for (i=1;i<cards.length;i++) {
        if (parseInt(cards[i].substr(2)) < cards0) {
            left.push(cards[i])
        } else {
            right.push(cards[i])
        }
    }
    left = kuaipai(left)
    right = kuaipai(right)
    left.push(cards[0])
    return left.concat(right)
}

//计算相同牌
function calTong(cards)
{
    data = []
    for (i=0;i<cards.length;i++) {
        let j = parseInt(cards[i].substr(2))
        if (data[j] == undefined) {
            data[j] = []
        }
        data[j].push(cards[i])
    }

    tong = []
    for (item of data) {
        if (item &amp;&amp; item.length >= 3) {
            tong.push(item)
        }
    }
    return tong
}

//计算顺子
function calShunZi(cards)
{
    //找到所有长度大于等于3的同花顺
    data = []
    i = 0
    j = 1
    len = 1
    color = cards[i].substr(0, 2)
    num = parseInt(cards[i].substr(2))
    cur = [cards[i]]
    while (i < cards.length)
    {
        //花色相同且值连续
        if (cards[j].substr(0, 2) == color &amp;&amp; (parseInt(cards[j].substr(2)) - num) == len) {
            cur.push(cards[j])
            j++
            len++
            if (len >= 3) {
                //记录
                data.push(Object.assign([], cur))
            }
        } else if ((parseInt(cards[j].substr(2)) - num) > len) {
            //值发生跳跃改变i指针
            i++
            len = 1
            color = cards[i].substr(0, 2)
            num = parseInt(cards[i].substr(2))
            j = i + 1
            cur = [cards[i]]
        } else {
            j++
        }

        if (j == cards.length) {
            i++
            j = i + 1
            cur = [cards[i]]
            if (j >= cards.length) {
                break
            }
            len = 1
            color = cards[i].substr(0, 2)
            num = parseInt(cards[i].substr(2))
        }
    }

    return data
}

//是否交集
function jiaoji(a, b)
{
    for (i of a) {
        if (b.includes(i)) {
            return true
        }
    }
    return false
}

//计算最优组合
function maxComb()
{
    var zuhe = shunzi
    
    //列出所有情况
    for (t of tong) {
        zuhe.push(t)
        if (t.length > 3) { //4张相同牌对应四种情况
            for(let i=0;i<4;i++) {
                let tmp = [];
                for(let j=0;j<4;j++) {
                    if (j != i) {
                        tmp.push(t[j])
                    }
                }
                zuhe.push(tmp)
            }
        }
    }

    console.log("最后的组合")
    console.log(zuhe)

    //循环计算
    let i = 0
    data = []
    max_num = 0;
    good_zuhe = [];
    beiwang = []
    // numd = 0
    while (i < zuhe.length)
    {
        let result = getZuHe([i], zuhe)
        let cur_num = 0;
        for (j of result) {
            for (k of zuhe[j]) {
                cur_num += parseInt(k.substr(2))
            }
        }
        if (cur_num > max_num) {
            max_num = cur_num
            good_zuhe = result
        }
        i++
    }

    // console.log("进入函数" + numd + "次")
    console.log("最优组合是", good_zuhe, "大小为 " + max_num)
}

//递归选组合
//带备忘录
function getZuHe(choiced, data)
{
    // numd++
    let cur = []
    for (choice of choiced) {
        cur = cur.concat(data[choice])
    }
    let i = 0
    while(i < data.length) {
        if (choiced.indexOf(i) != -1) {
            i++
            continue
        }
        if (jiaoji(cur, data[i]) == false) {
            if (beiwang.indexOf(kuaipai_num(choiced.concat([i])).join(',')) >= 0) {
                i++
                continue;
            }
            return getZuHe(choiced.concat([i]), data)
        }
        i++
    }

    //排序后放入备忘录
    beiwang.push(kuaipai_num(choiced).join(','))
    return choiced
}

//快排数字
function kuaipai_num(arr)
{
    if (arr.length <= 1) {
        return arr
    }

    var left = [] , right = []
    var arr0 = arr[0]
    for (i=1;i<arr.length;i++) {
        if (arr[i] < arr0) {
            left.push(arr[i])
        } else {
            right.push(arr[i])
        }
    }
    left = kuaipai_num(left)
    right = kuaipai_num(right)
    left.push(arr[0])
    return left.concat(right)
}

 最终运行结果如下:

有兴趣的小伙伴可以给出更好的建议和方法

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/699662.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Uncaught TypeError: Illegal invocation

使用console.time报错 console.time将在当前对象(即支持)的上下文中执行&#xff0c;发现一些老的chrome版本中&#xff0c;上下文可能有问题. 解决&#xff1a; 可以使用 console.time.call(window,1111)

关于Easy Mesh

随着网络技术的高速发展&#xff0c;家庭宽带进入了千兆时代&#xff0c;AR&#xff0c;VR&#xff0c;8K影视等高品质产品和智能家居正以前所未有的速度进入寻常百姓家&#xff0c;由于网络覆盖的问题&#xff0c;给WIFI网络应用带来了更大的考验。 WIFI网络覆盖一般是有四种方…

git下载总是报错:身份认证失败的解决办法

在利用git命令下载代码时&#xff0c;提示输入用户名和密码&#xff0c;但是总是显示身份认证失败&#xff0c;在修改密码后仍然没有解决。于是&#xff0c;换了一种方式&#xff0c;采用SSH。 首先在本地生成ssh-key 在虚拟机中执行命令 ssh-keygen -t rsa -C "github…

不再手动PS,教你如何快速删除图片文字!

可以让你快速从照片中提取和复制任何对象的应用。它可以让你轻松地将照片中的物品、人物、动物、文字等放到其他应用中&#xff0c;比如Photoshop、PowerPoint、Word等。ClipDrop还有一个很有用的功能&#xff0c;就是可以去除照片中的文字&#xff0c;让你得到一个干净的背景。…

【MySQL】MySQL数据库基础

目录 一、数据库概念 二、数据库基本使用 1、链接服务器 2、服务器管理 3、使用案例 3.1、创建数据库 3.2、使用数据库 4、服务器&#xff0c;数据库&#xff0c;表关系 三、MySQL架构 四、SQL分类 五、存储引擎 1、存储引擎概念 2、查看存储引擎 3、存储引擎对比…

【强化学习】常用算法之一 “A3C”

作者主页&#xff1a;爱笑的男孩。的博客_CSDN博客-深度学习,活动,python领域博主爱笑的男孩。擅长深度学习,活动,python,等方面的知识,爱笑的男孩。关注算法,python,计算机视觉,图像处理,深度学习,pytorch,神经网络,opencv领域.https://blog.csdn.net/Code_and516?typeblog个…

前端JS一维数组转树状数组并获取当前节点的所有父级名称或id

注意一维数组里面必须要有属性跟父级关联 test(){const list2 [{id: 1,pid: 0,name: 湖南},{id: 2,pid: 1,name: 长沙},{id: 3,pid: 2,name: 雨花区},];// 参数一:需要转树状数组的数组// 参数二:父id// 参数三:当前递归的父级节点name// 参数三:当前递归的父级节点idconst ar…

移远通信再推模组新品,全新5G智能模组SG530C-CN智创全景智慧生活

6月28日&#xff0c;在2023 MWC上海展会首日&#xff0c;移远通信再次宣布推出模组新品。 此次推出的全新5G智能模组SG530C-CN在连接能力、算力、多媒体性能与成本效益等层面都呈现较高水平。该模组将在智慧零售、车载后装、娱乐/直播、手持终端、工业AI等行业与应用场景上大有…

大数据需要一场硬件革命

光子盒研究院 计算领域的进步往往集中在软件上&#xff1a;华丽的应用程序和软件可以跟踪人和生态系统的健康状况、分析大数据&#xff0c;并在智力竞赛中击败人类冠军。与此同时&#xff0c;对支撑所有这些创新的硬件进行全面改革的努力相对来说&#xff0c;略显小众。 自2020…

如何实现MySQL的读写分离?

其实很简单&#xff0c;就是基于主从复制架构&#xff0c;简单来说&#xff0c;就搞一个主库&#xff0c;挂多个从库&#xff0c;然后我们就单 单只是写主库&#xff0c;然后主库会自动把数据给同步到从库上去。 MySQL主从复制原理的是啥&#xff1f; 主库将变更写入 binlog …

架构图的实现过程

项目需求架构图 实现代码 index.vue <template><!-- 外层div --><div class"topu-container" :style"{ minWidth: ${functionDomainList.length * 330}px }"><!-- 头部显示 --><div class"topu-heard"><!-- …

vue3高德地图点击标点

1.首先如果没有key的话需要在高德开发平台申请key。 2.安装 npm i amap/amap-jsapi-loader --save cnpm i amap/amap-jsapi-loader --save3.容器&#xff1a; <template><div><div class"info"><h4>获取地图级别与中心点坐标</h4>&l…

git常用命令之Cherry-pick

8. Cherry-pick 8.1 基本用法 命令作用延展阅读git cherry-pick 125a1d将提交125a1d应用于当前分支. 在当前分支会产生一个新的提交.链接git cherry-pick bugfix将分支bugfix应用于当前分支. 在当前分支会产生一个新的提交. 场景1&#xff1a;提交125a1d应用到master分支 命…

玖章算术与百度智能云达成合作,「NineData SQL 开发」成为百度智能云主推的数据库工具

2023 年 6 月 19 日&#xff0c;玖章算术&#xff08;浙江&#xff09;科技有限公司旗下的多云数据管理平台 NineData 正式入驻百度智能云市场&#xff0c;双方的深度技术融合将为客户提供智能高效、安全可靠的数据库开发服务。通过适配百度智能云数据库&#xff0c;NineData 为…

计算机网络中的安全

计算机网络中的安全 1 什么是网络安全2 加密的方式——机密性2.1 对称密钥加密2.2 公开密钥加密 3 报文鉴别码——报文完整性4 数字签名——报文完整性、端点鉴别4.1 数字签名技术的基础4.2 公钥认证 5 案例——设计安全电子邮件系统 《计算机网络—自顶向下方法》&#xff08;…

Postman中读取外部文件

目录 前言&#xff1a; 一、postman中读取外部文件的格式 二、Postman中如何导入文件 三、在Postman读取导入的数据文件 前言&#xff1a; 在Postman中&#xff0c;您可以使用"数据文件"功能来读取外部文件&#xff0c;如CSV、JSON或Excel文件。这使得在测试中使用…

如何应用Nginx Rewrit实现网页跳转

目录 一、Nginx Rewrite 二、Rewrite功能 Rewrite跳转场景 Rewrite跳转实现 Nginx 跳转 pcre支持 重写模块 Rewrite实际场景 Rewrite命令/语法格式 flag标记说明 location分类 location优先级 rewrite和location相比 三、跳转案例 实现域名跳转 第一步 修改指…

一文详解gRPC框架

目录 RPC框架简介 简介 各种序列化协议优缺点 gRPC调用模式 gRPC跟ProtocolBuffers的关系 ProtocolBuffers协议 gRPC桩代码生成 gRPC线程模型 gRPC分层 gRPC开发经验 官网及快速开始 常见状态码 适用场景 适用 不适用 手写简易RPC框架 Dubbo学习笔记 一文详解…

【python】数据表转csv

文章目录 1 基本结构1.1 数据1.2 数据结构 2 代码3 tip 1 基本结构 1.1 数据 1.2 数据结构 2 代码 代码&#xff1a; import mysql.connector import csvdef getPerson():# 数据库初始化cnx mysql.connector.connect(userroot, passwordroot, databasetest)cursor cnx.cur…

IDEA启动tomcat控制台中文乱码问题

IntelliJ IDEA是很多程序员必备且在业界被公认为最好的Java开发工具&#xff0c;有很多小伙伴在安装完IDEA并且tomcat之后&#xff0c;启动tomcat会出现控制台中文乱码问题&#xff0c;如下图所示&#xff1a; 具体解决步骤&#xff1a; 一、修改当前 Web 项目 Tomcat Server…