Acwing---1212.地宫取宝

news2024/11/24 3:16:17

地宫取宝

  • 1.题目
  • 2.基本思想
  • 3.代码实现

1.题目

X 国王有一个地宫宝库,是 n×m 个格子的矩阵,每个格子放一件宝贝,每个宝贝贴着价值标签。

地宫的入口在左上角,出口在右下角。

小明被带到地宫的入口,国王要求他只能向右或向下行走。

走过某个格子时,如果那个格子中的宝贝价值比小明手中任意宝贝价值都大,小明就可以拿起它(当然,也可以不拿)。

当小明走到出口时,如果他手中的宝贝恰好是 k k k 件,则这些宝贝就可以送给小明。

请你帮小明算一算,在给定的局面下,他有多少种不同的行动方案能获得这 k k k 件宝贝

输入格式
第一行 3 个整数, n , m , k n,m,k n,m,k,含义见题目描述。

接下来 n 行,每行有 m m m 个整数 C i Ci Ci 用来描述宝库矩阵每个格子的宝贝价值

输出格式
输出一个整数,表示正好取 k k k 个宝贝的行动方案数。

该数字可能很大,输出它对 1000000007 1000000007 1000000007 取模的结果。

数据范围
1 ≤ n , m ≤ 50 , 1≤n,m≤50, 1n,m50,
1 ≤ k ≤ 12 , 1≤k≤12, 1k12,
0 ≤ C i ≤ 12 0≤Ci≤12 0Ci12

输入样例1:

2 2 2
1 2
2 1

输出样例1:

2

输入样例2:

2 3 2
1 2 3
2 1 5

输出样例2:

14

2.基本思想

动态规划
1.状态表示:

1.1集合: f [ i ] [ j ] [ k ] [ c ] f[i][j][k][c] f[i][j][k][c]:所有从起点走到 ( i , j ) (i,j) ij且已经取了 k k k 件物品且最后一件物品是 c c c的合法的方案集合.
1.2属性:count

2.状态计算
在这里插入图片描述

Tips:

  • 1.因为这道题的所有物品价值范围是0…12,可以把他们全部都递增,范围就变成了1…13,因为我们记录的是方案数,只关心各个物品之间的大小关系,具体数值不影响答案,但是这样的做法可以把0作为一个特殊边界来处理 (即当起点(1,1)不取时)
  • 2.缝合怪
    本题目结合:摘花生(所有最最后一步从上往下走的走法 / / /所有最后一步从左往右走的走法)+ 最长上升子序列+01背包(取 / / /不取)

3.代码实现

public class _1212地宫取宝 {
    static Scanner sc = new Scanner(System.in);
    static int MOD = 1000000007;

    public static void main(String[] args) {
        int n = sc.nextInt();//行
        int m = sc.nextInt();//列
        int k = sc.nextInt();//件数
        int w[][] = new int[n+1][m+1];//价值
        int dp[][][][] = new int[55][55][13][14];   //个数:0~12 价值-1~12 此处-1为了方便初始化起点(1,1)处选择不取时
        for (int i = 1; i <= n; i++) {
            for (int j = 1; j <= m; j++) {
                w[i][j] = sc.nextInt();
                w[i][j]++;//偏移量+1 价值-1~12 变为 0~13
            }
        }
        //两个边界初始化
        // 在起点 (1, 1) 处如果拿也只能拿 a[i][j] 这个物品,只有一种方案
        // 如果不拿,那就是 0 个物品,也是一个方案数由于物品价值已经增加了一个偏移量,现在价值的范围是 [1, 13]
        // 所以价值为 0 并不代表物品的价值,而是一个边界点
        dp[1][1][1][w[1][1]] = 1;//第一个 取
        dp[1][1][0][0] = 1;//不取

        //循环所有状态
        for (int i = 1; i <= n; i++) {
            for (int j = 1; j <= m; j++) {
                if (i == 1 && j == 1) continue;//起点已经做过
                for (int u = 0; u <= k; u++) {
                    for (int v = 0; v <= 13; v++) {
                        // 不取物品
                        dp[i][j][u][v] = (dp[i][j][u][v]+dp[i-1][j][u][v])%MOD;
                        dp[i][j][u][v] = (dp[i][j][u][v]+dp[i][j-1][u][v])%MOD;//不能直接三个数 相加10^8+10^8+10^8可能会爆int(2.1*10^8)
                        //取
                        if (u>0 && v==w[i][j]){
                            for (int s = 0; s < v; s++) {//枚举c‘
                                dp[i][j][u][v]=(dp[i][j][u][v]+dp[i-1][j][u-1][s])%MOD;
                                dp[i][j][u][v]=(dp[i][j][u][v]+dp[i][j-1][u-1][s])%MOD;
                            }
                        }
                    }
                }
            }
        }
        int res=0;
        for (int i = 0; i <=13 ; i++)
            res=(res+dp[n][m][k][i])%MOD;
        System.out.println(res);
    }
}

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

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

相关文章

SAP入门技术分享三:模块化程序

模块化程序1.子程序概要2.子程序定义3.子程序参数&#xff08;1&#xff09;传递参数的方法&#xff08;2&#xff09;定义参数类型&#xff08;3&#xff09;参数与结构体&#xff08;4&#xff09;参数与内表4.调用子程序&#xff08;1&#xff09;调用程序内部子程序&#x…

Android APP 缓存路径

Context.getCacheDir():这个缓存路径打印出来的是&#xff1a;data / data / (APPID ) / cacheAndroid系统中的清除APP缓存清除的就是这个路径: 随着用户手动清空缓存或者APP的卸载&#xff0c;这个路径的缓存也会被删除。请注意&#xff1a;在这个缓存路径上读写是不需要请求文…

Qt扫盲-信号槽理论总结

信号槽理论总结一、概述二、信号槽三、信号四、槽函数五、小例子六、 信号槽的默认参数七、高级使用八、 在Qt 里使用第三方的信号槽一、概述 信号和槽用于对象之间的通信。信号和槽机制是Qt的一个核心特性&#xff0c;也是与其他框架所提供的特性最大不同的部分。Qt的元对象系…

win10跨网段文件共享

win10跨网段文件共享问题描述问题分析网络可达性防火墙权限问题操作网络拓扑示意图操作步骤问题描述 平常&#xff0c;我们经常用的是同一局域网下的网络共享&#xff0c;这在windows上很容易操作。现在&#xff0c;两台PC主机不在同一子网&#xff0c;该如何共享&#xff1f;…

【C/C++】静态顺序表详解(附完整源码)

本章内容 1.什么是线性表 2.什么是顺序表 3.静态顺序表结构的定义 4.静态顺序表的函数接口实现 5.静态顺序表的问题及思考 1.什么是线性表 线性表&#xff08;linear list&#xff09;是n个具有相同特性的数据元素的有限序列。 线性表是一种在实际中广泛使用的数据结构&…

开源飞控初探(四)ArduPilot::Copter固件源码分析

2022.5.7&#xff0c;基于v4.0.5的分析。官网文档没及时更新&#xff0c;本文对当前版本源码的描述可能和官网不一样。1、无人机全栈分层结构图2、Flight Code固件部分上图中的Flight Code层&#xff0c;分为5个部分&#xff1a;车机层。一份代码通过编译配置&#xff0c;可以支…

行转列,动态列枚举分组

【问题】Hi All,Thanks for the wonderful support the community gets from this forum.I am trying to accomplish this in MongoDB. Didn’t think it could get this complicated. thought the problem was interesting to solve.I am trying to get a count of students b…

【库函数】-还在为操作字符串而烦恼,一篇带你解决这样的烦恼,这里详细介绍关于字符串操作的各个库函数,以及模拟实现

&#x1f387;作者&#xff1a;小树苗渴望变成参天大树 &#x1f389;作者宣言&#xff1a;认真写好每一篇博客 &#x1f4a5;作者gitee:link 如 果 你 喜 欢 作 者 的 文 章 &#xff0c;就 给 作 者 点 点 关 注 吧&#xff01; 字符函数和字符串函数&#x1f4a6;前言&…

python函数定义中的/和*的作用

python函数定义中的/和*的作用 特殊参数https://docs.python.org/zh-cn/3/tutorial/controlflow.html#special-parameters 函数定义中的单独出现的/和*的作用 / 和 * 是可选的。 /用来指明他前面的函数形参必须使用位置参数。 *用来指明他后面的函数形参必须为关键字参数的…

儿童感染新冠后怎么用药?什么情况需要就医?

儿童感染新冠病毒的症状&#xff0c;病程有哪些特点&#xff1f;退烧药怎么选&#xff0c;怎么吃&#xff1f;孩子有什么症状需要立即就医&#xff1f;...01儿童感染新冠病毒的症状&#xff0c;病程有哪些特点&#xff1f;王泉&#xff1a;儿童是新冠病毒的易感人群。新冠病毒感…

Unity C#热更新框架ILRuntime接入

简介 ILRuntime项目为基于C#的平台&#xff08;例如Unity&#xff09;提供了一个纯C#实现&#xff0c;快速、方便且可靠的IL运行时&#xff0c;使得能够在不支持JIT的硬件环境&#xff08;如iOS&#xff09;能够实现代码的热更新 官方教程 https://ourpalm.github.io/ILRunt…

揭开 TLS 握手的神秘面纱:它是什么以及它是如何工作的

传输层安全性 (TLS) 旨在为网络通信增加安全性。 就是浏览互联网时HTTP和HTTPS的区别。 使用 TLS 为客户端和服务器增加了额外的工作&#xff0c;但它有其好处&#xff0c;包括&#xff1a; 机密性&#xff1a;TLS 将流量包装在加密隧道中。 这使得窃听者不可能在到达目的地的…

[Swift]UIView抖动动画

以拨打视频电话时的拨打按钮抖动为例 import UIKitclass PACallPrepareAlertView: UIView {IBOutlet weak var callIV: UIImageView!private var isLeave: Bool falsedeinit {isLeave true}override func awakeFromNib() {super.awakeFromNib()shakeAction()}private func s…

套接字编程之接口

套接字编程之接口学习套接字之前你需要知道的套接字编程套接字TCP协议和UDP协议区别UDP协议的编写UDP通信两端流程具体操作接口介绍创建套接字为套接字绑定地址信息发送数据接收数据关闭套接字字节序相关接口&#x1f4cc;————本章重点————&#x1f4cc; &#x1f517;…

【Ansible】ansible 变量

ansible 变量 文章目录ansible 变量一、Ansible 变量介绍二、变量命名规则三、变量类型1.全局变量2.剧本变量3.资产变量4.Facts 变量5.注册变量6.变量优先级一、Ansible 变量介绍 在 PlayBook 一节中&#xff0c;将 PlayBook 类比成了 linux 中的shell。那么它作为一门 ansibl…

搜索引擎收录查询,是什么影响了网站被搜索引擎收录

搜索引擎收录是指程序通过辨别把网站内容进行收录&#xff0c;同时会对这些内容进行价值以及其他方面的辨别。 我们想要知道网站有没有被搜索引擎收录&#xff0c;可以借助iis7seo批量查来查询网站有没有被搜索引擎收录。打开iis7seo批量查&#xff0c;添加需要查询的网站网址&…

计算结构体,位段,联合体(共用体)的大小

目录 一、计算结构体的大小 1.1 结构体的计算并不是简单的类型加运算 1.2 内存对齐 1.2.1 内存对齐规则 1.2.2 图解内存对齐 二、计算位段的大小 2.1位段是什么 2.2 位段的内存分配 三、计算联合体的大小 3.1 什么是联合体 3.2 联合体的内存分配 END. 一、计算结构…

Consensus Algorithm -- Raft

The Raft Consensus Algorithm Go 实现&#xff1a;etcd/raft、dragonboat Rust 实现&#xff1a;TiKV C 实现 &#xff1a;nebula-graph-storage、 RethinkDB、logcabin 拜占庭将军问题 拜占庭将军问题&#xff08;Byzantine failures&#xff09;&#xff0c;是由莱斯利兰…

绝绝子!这些技巧真方便

技巧一&#xff1a;快速切换窗口 如果你还在使用桌面底部“任务栏”切换软件窗口&#xff0c;不妨试试这个“快速切换窗口”快捷键&#xff0c;仅需按住【Alt】键不放&#xff0c;并连续点按【tab】键即可实现窗口的快速切换&#xff0c;果真只有亲自上手体验才知道有多香&…

NLP中的对话机器人——问答机器人的应用场景

引言 本文是七月在线《NLP中的对话机器人》的视频笔记&#xff0c;主要介绍FAQ问答型聊天机器人的实现。 讲得还不错&#xff0c;关键是只要1分钱 FAQ问答机器人 FAQ就是一些常见问题与回答&#xff0c;比如https://letsencrypt.org/docs/faq/。 但是我们要做的不是一问一答…