【每日一题Day33】LC799香槟塔 | 动态规划

news2025/1/11 17:02:57

香槟塔【LC799】

我们把玻璃杯摆成金字塔的形状,其中 第一层1 个玻璃杯, 第二层2 个,依次类推到第 100 层,每个玻璃杯 (250ml) 将盛有香槟。

从顶层的第一个玻璃杯开始倾倒一些香槟,当顶层的杯子满了,任何溢出的香槟都会立刻等流量的流向左右两侧的玻璃杯。当左右两边的杯子也满了,就会等流量的流向它们左右两边的杯子,依次类推。(当最底层的玻璃杯满了,香槟会流到地板上)

例如,在倾倒一杯香槟后,最顶层的玻璃杯满了。倾倒了两杯香槟后,第二层的两个玻璃杯各自盛放一半的香槟。在倒三杯香槟后,第二层的香槟满了 - 此时总共有三个满的玻璃杯。在倒第四杯后,第三层中间的玻璃杯盛放了一半的香槟,他两边的玻璃杯各自盛放了四分之一的香槟,如下图所示。

img

现在当倾倒了非负整数杯香槟后,返回第 ij 个玻璃杯所盛放的香槟占玻璃杯容积的比例( ij 都从0开始)。

起晚了,周赛只A了一题半,没吃早饭果然脑子动不起来:-|

  • 思路:模拟倒香槟的过程,使用 t a b l e s tables tables数组记录香槟塔每个位置的香槟,第 i + 1 i+1 i+1行的香槟的容量由前一行香槟的容量决定,香槟 t a b l e s [ i ] [ j ] tables[i][j] tables[i][j]可能会对 t a b l e s [ i + 1 ] [ j ] tables[i+1][j] tables[i+1][j] t a b l e s [ i + 1 ] [ j + 1 ] tables[i+1][j+1] tables[i+1][j+1]造成影响

    • 如果 t a b l e s [ i ] [ j ] > 1 tables[i][j]>1 tables[i][j]>1,那么流入下一行的两个玻璃杯的香槟为 ( t a b l e s [ i ] [ j ] − 1 ) / 2 (tables[i][j]-1)/2 (tables[i][j]1)/2
    • 如果 t a b l e s [ i ] [ j ] < = 1 tables[i][j]<=1 tables[i][j]<=1,那么不会对下一行的两个玻璃杯造成影响
  • 动态规划

    1. 确定dp数组(dp table)以及下标的含义

      dp[i][j]:香槟塔第i行第j列玻璃杯中香槟的容量

    2. 确定递推公式

      • 如果第i行第j列玻璃杯存在溢出现象,即 d p [ i ] [ j ] > 1 dp[i][j]>1 dp[i][j]>1,修改下一行对应的两个玻璃杯的香槟量,并将该玻璃杯的香槟量修改为1

        d p [ i + 1 ] [ j ] + = ( d p [ i ] [ j ] − 1 ) / 2 dp[i+1][j] += (dp[i][j] - 1)/2 dp[i+1][j]+=(dp[i][j]1)/2

        d p [ i + 1 ] [ j + 1 ] + = ( d p [ i ] [ j ] − 1 ) / 2 dp[i+1][j+1] += (dp[i][j] - 1)/2 dp[i+1][j+1]+=(dp[i][j]1)/2

      d p [ i ] [ j ] = 1 dp[i][j]=1 dp[i][j]=1

    3. 如何初始化

      • d p [ 0 ] [ 0 ] = p o u r e d dp[0][0]=poured dp[0][0]=poured;
    4. 确定遍历顺序

      由dp公式可知,外层正序遍历行i,内层正序遍历列j

    5. 举例推导dp数组

  • 实现

    class Solution {
        public double champagneTower(int poured, int query_row, int query_glass) {
            double[][] tables = new double[query_row + 10][query_row + 10];
            tables[0][0] = poured;
            for (int i = 0; i <= query_row; i++){
                for (int j = 0; j <= i; j++){
                    if (tables[i][j] > 1){
                        double p = (tables[i][j] - 1) / 2.0;
                        tables[i+1][j] += p;
                        tables[i+1][j+1] += p;
                        tables[i][j] = 1;
                    }
                }
            }
            return tables[query_row][query_glass];
        }
    }
    
    • 复杂度

      • 时间复杂度: O ( n 2 ) O(n^2) O(n2),n为行数
      • 空间复杂度: O ( n 2 ) O(n^2) O(n2)
  • 优化空间复杂度,因dp过程中,只需要记录当前行和后一行的香槟量,因此可以使用2行的dp数组代替

    class Solution {
        public double champagneTower(int poured, int query_row, int query_glass) {
            double[][] tables = new double[2][query_row + 10];
            tables[0][0] = poured;
            for (int i = 0; i <= query_row; i++){
                int cur = i & 1, next = (i + 1) & 1;
                Arrays.fill(tables[next],0);
                for (int j = 0; j <= i; j++){
                    if (tables[cur][j] > 1){
                        double p = (tables[cur][j] - 1) / 2.0;
                        tables[next][j] += p;
                        tables[next][j+1] += p;
                        tables[cur][j] = 1;
                    }
                }
            }
            return tables[query_row & 1][query_glass];
        }
    }
    
    • 复杂度

      • 时间复杂度: O ( n 2 ) O(n^2) O(n2),n为行数
      • 空间复杂度: O ( n ) O(n) O(n)

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

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

相关文章

springmvc-day01

springmvc-day01 第一节 SpringMVC概述 1. SpringMVC 优势 SpringMVC 是 Spring 为表述层开发提供的一整套完备的解决方案。在表述层框架历经 Strust、WebWork、Strust2 等诸多产品的历代更迭之后&#xff0c;目前业界普遍选择了 SpringMVC 作为 Java EE 项目表述层开发的首…

pytest集成allure报告(allure安装及配置以及如何实现集成)

一、allure安装及环境变量配置 1、先保证本地已装jdk1.8 首先安装JDK1.8&#xff0c;添加到环境变量path。 具体可以查看文章&#xff1a;https://blog.csdn.net/weixin_40608713/article/details/116103153?ops_request_misc%257B%2522request%255Fid%2522%253A%2522166892…

07_通信过程

知识点1【给路由器添加一块网卡】 知识点2【演示浏览器访问web服务器】 知识点2【局域网的划分】&#xff08;补充&#xff09; 知识点3【跨外网的不同局域网通信过程】&#xff08;补充&#xff09; 知识点4【LInux下的防火墙】&#xff08;了解&#xff09; 防火墙的分类…

【虚幻引擎UE】UE4/UE5 GIS相关插件推荐及使用介绍

一、Cesium for Unreal&#xff08;Cesium插件&#xff09; 二、SuperMap Scene SDKs_Unreal Engine&#xff08;超图地图插件&#xff09; 提供了从SuperMap平台或其他开放在线地图访问真实世界地理空间3D数据的功能。 三、Vitruvio CityEngine Plugin&#xff08;CityEngine…

Python图像处理笔记

文章目录一. Pillow处理图片1.1 Pillow安装1.2 Pillow基本使用二. Matplotlib包中的图像模块2.1 简介2.2 API简介三. ndarray图像操作练习3.1 旋转图片3.2 图片打码3.3 图片拼接3.4 图片切割四. 图像灰度化4.1 简介4.2 灰度化方法五. OpenCV使用入门5.1 简介5.2 OpenCV基本使用…

Android TextView富文本SpannableStringBuilder的使用详解

背景&#xff1a; 在android开发过程中&#xff0c;做内容的时候&#xff0c;不仅只有字符&#xff0c;基本都是图文混排&#xff0c;甚至还会对内容中某段文字进行特殊处理&#xff0c;比如&#xff1a;字体加粗、字体变大、改变字体颜色、对某一段文字新增点击事件&#xff…

Redis缓存——快速入门

目录 1、Redis概述 1.1、NoSQL 1.2、缓存的需求 2、Redis简介及安装 2.2、redis的特点 2.3、redis下载 2.4、window安装 2.5、linux安装 3、Redis操作 3.1、多数据库 3.2、选择数据库 3.3、清空数据库 3.4、基本命令 4、五种数据类型 4.1、字符串&#xff08;st…

论文笔记:Ontology-enhanced Prompt-tuning for Few-shot Learning

论文来源&#xff1a;WWW 2022 论文地址&#xff1a;https://arxiv.org/pdf/2201.11332.pdfhttps://arxiv.org/pdf/2201.11332.pdf 论文代码&#xff1a;暂未公开 笔记仅供参考&#xff0c;撰写不易&#xff0c;请勿恶意转载抄袭&#xff01; Abstract 小样本学习旨在基于…

【数据结构】队列

1.啥是队列 2.队列实现 3.Queue接口的介绍以及队列的使用 4.相关队列的例子 &#xff08;1&#xff09;啥是队列 我们之前讲解了栈&#xff0c;栈和队列是有点区别的 我们说过栈是一种先进后出的数据结构&#xff0c;你可以把它想象成羽毛球筒&#xff1b;然而队列属于一种先…

一文读懂VMware虚拟化技术(含超融合)

1. 概述 1.1 为什么使用虚拟化 基于云服务器业务&#xff0c;很多公司不需要那么强大的服务器&#xff0c;将服务器虚拟化之后分开卖收益更高 比如租房&#xff0c;有一个100平面的房子&#xff0c;整租可以一个月房租8000&#xff0c;划分4个区域分这组&#xff0c;可以每个…

OAuth2.0

OAthu2.0参考链接1 OIDC&#xff08;OpenId Connect&#xff09;身份认证参考链接 一、定义 OAuth2.0是OAuth协议的延续版本&#xff0c;但不向前兼容OAuth 1.0(即完全废止了OAuth1.0)。 OAuth 2.0关注客户端开发者的简易性。要么通过组织在资源拥有者和HTTP服务商之间的被批…

《大数据分析-数据仓库项目实战》--阅读笔记

本文是《大数据分析-数据仓库项目实战》阅读笔记。 内容全部摘抄于本书。 算入门教材、文中有大量软件的安装步骤、对技术细节未过多涉及。 前言描述 大数据时代&#xff0c;需要考虑数据的采集、存储、计算处理等方式。 数据仓库建模方式&#xff1a;确定业务过程、声明粒度…

统计信号处理基础 习题解答6-10

题目&#xff1a; 我们继续习题6.9&#xff0c;考察在有色噪声环境下OOK系统信号选择的问题&#xff0c;令噪声 为零均值的WSS随机过程&#xff0c;ACF为 求PSD&#xff0c;并且对于 画出PSD的图形。和前一个系统一样&#xff0c;对于N50,求产生BLUE最小方差频率。提示&#x…

Espressif-IDE NameError: name ‘websocket‘ is not defined 解决方法

前言 ESP32 具有wifi 与 蓝牙&#xff0c;性价比比较高&#xff0c;一些嵌入式开发中经常用到&#xff0c;最近更新了一下 ESP32的开发环境&#xff0c; ESP32 开发工具下载地址&#xff1a;https://dl.espressif.cn/dl/esp-idf/ 下载文件&#xff1a;espressif-ide-setup-2.7…

HIve数仓新零售项目DWS层的构建(Grouping sets)模型

HIve数仓新零售项目 注&#xff1a;大家觉得博客好的话&#xff0c;别忘了点赞收藏呀&#xff0c;本人每周都会更新关于人工智能和大数据相关的内容&#xff0c;内容多为原创&#xff0c;Python Java Scala SQL 代码&#xff0c;CV NLP 推荐系统等&#xff0c;Spark Flink Kaf…

一文搞懂《前后端动态路由权限》

前言 本文主要针对后台管理系统的权限问题&#xff0c;即不同权限对应着不同的路由&#xff0c;同时侧边栏的路由也需要根据权限的不同异步生成。我们知道&#xff0c;权限那肯定是对应用户的&#xff0c;那么就会涉及到用户登录模块&#xff0c;所以这里也简单说一下实现登录的…

同花顺_代码解析_技术指标_S

本文通过对同花顺中现成代码进行解析&#xff0c;用以了解同花顺相关策略设计的思想 目录 SADL SAR SDLH SG_NDB SG_XDT SG_评分 SGSMX SG量比 SI SKDJ SRDM SRMI STIX SADL 腾落指数 1.ADL与指数顶背离时&#xff0c;指数向下反转机会大&#xff1b; 2.ADL与指…

合成孔径SAR雷达成像成(RDA和CSA)(Matlab代码实现)

&#x1f468;‍&#x1f393;个人主页&#xff1a;研学社的博客 &#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜…

(免费分享)基于springboot博客系统

源码获取&#xff1a;关注文末gongzhonghao&#xff0c;输入015领取下载链接 开发工具&#xff1a;IDEA,数据库mysql 技术&#xff1a;springbootmybatis-plusredis 系统分用户前台和管理后台 前台截图&#xff1a; 后台截图&#xff1a; package com.puboot.…

思泰克在创业板过会:拟募资4亿元,赛富投资、传音控股等为股东

11月18日&#xff0c;深圳证券交易所创业板披露的信息显示&#xff0c;厦门思泰克智能科技股份有限公司&#xff08;下称“思泰克”&#xff09;获得上市委会议通过。据贝多财经了解&#xff0c;思泰克的招股书于2022年5月5日获得创业板受理。 本次冲刺创业板上市&#xff0c;思…