力扣网C语言编程题:接雨水(动态规划实现)

一. 简介

本文记录力扣网上的逻辑编程题,涉及数组方面的,这里记录一下 C语言实现和Python实现。

二. 力扣网C语言编程题:接雨水

题目:接雨水

给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。

示例 2:
输入:height = [4,2,0,3,2,5]
输出:9

提示:
    n == height.length
    1 <= n <= 2 * 104
    0 <= height[i] <= 105

初步思路:

暴力解法是最直观的方法,它直接按照问题的定义来计算每个位置能够接多少水。

从左到右遍历数组元素,计算每个柱子的接水量,然后,不断累加即可。但是问题的关键是如何计算每个柱子能接的雨水量?

通过柱型图观察可知,只有低洼的位置才会接到雨水。具体意思就是,某个元素 nums[i]的左侧与右侧所有元素只要高于其本身就可接到雨水。

核心原理:

雨水能被接住的条件是:左右两侧存在比当前位置更高的墙

每个位置能接的雨水量 = min (左侧最高墙高度,右侧最高墙高度) - 当前墙高度(若结果为负则取 0,其中左侧指的是某个元素的左侧所有元素值最大的元素)。

解题思路一:(暴力解法)

暴力解法,从左向右边遍历数组元素,逐个依次计算每个元素所能接的雨水量,同时不断累加即可。

遍历数组,假如计算 nums[i]元素的接雨水量:

首先,计算 nums[i]左边所有元素中值最大的元素,计算 nums[i]右边所有元素中值最大的元素。

然后,使用公式计算 nums[i]能接到的雨水量:min(左边最大元素值,右边最大元素值)-nums[i];

总结:n个元素都要进行一轮这样的计算,时间复杂度为O(n*n),空间复杂度为O(1)。这样时间复杂度太高,超过时间限制,需要进行进一步优化以减少时间复杂度。

解题思路二:(动态规划)

暴力解法中,每次要计算某个元素的左边所有元素的最大值和右边所有元素的最大值。可以用两个数组,分别统计出来每个元素的左边中值最大的元素与右边中值最大的元素(也就是提前统计好),最后,统计所有元素的接水量。

具体方法:

1. 分配两个数组left_buf,right_buf,分别统计每个元素的左边中值最大的元素与右边中值最大的元素;

2. 遍历数组,统计每个元素左边所有元素中最大值,并记录到数组left_buf中(从左向右);

3. 遍历数组,统计每个元素右边所有元素中最大值,并记录到数组right_buf中(从右向右);

4. 计算所有元素的接水量,left_buf数组与 right_buf数组对应比较,求对应位置最小值。使用公式计算每个位置上的接水量:min(left_buf[i], right_buf[i]) - height[i],并不断累加。

C语言实现如下:

#include <stdio.h>
#include <stdlib.h>//动态规划
int trap(int *height, int heightSize) {if((height == NULL) || (heightSize < 2)) {return 0;}int i = 0;int receive_water = 0;int* left_max = (int*)calloc(heightSize, sizeof(int));int* right_max = (int*)calloc(heightSize, sizeof(int));//统计所有元素左侧的最大值left_max[0] = height[0];for(i = 1; i < heightSize; i++) {left_max[i] = fmax(left_max[i-1], height[i]);}//统计所有元素右侧的最大值right_max[heightSize-1] = height[heightSize-1];for(i = heightSize-2; i >=0; i--) {right_max[i] = fmax(right_max[i+1], height[i]);}// 计算接的雨水量for(i = 1; i < (heightSize-1); i++) {receive_water += fmin(left_max[i], right_max[i]) - height[i];}free(left_max);left_max = NULL;free(right_max);right_max = NULL;return receive_water;
}

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

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

相关文章

关于ubuntu环境下vscode进行debug的随笔

CMakeLists.txt的编写 顶层目录的CMakelists.txt 目录&#xff1a;./CMakeLists.txt #./CMakeLists.txt cmake_minimum_required(VERSION 3.10) project(xxx_project_name LANGUAGES CXX) #设置工程名# 设置 C 标准和编译选项 set(CMAKE_CXX_STANDARD 17) set(CMAKE_CXX_ST…

技术演进中的开发沉思-9:window编程系列-内核对象线程同步(下)

今天我们继续走进 Windows 内核的世界&#xff0c;就昨天没说完的内核对象与线程同步内容接着继续&#xff0c;它们就像精密仪器里的齿轮&#xff0c;虽不显眼&#xff0c;却至关重要。 异步设备 I/O 在 Windows 系统中&#xff0c;异步设备 I/O 就像是一场精心编排的接力赛。…

用AI从0开始量化交易-Anaconda环境(env)和缓存(pkg)更改储存位置

之前介绍了Anaconda的安装和环境建立&#xff0c;最近自己的量化交易工具开发的差不多了&#xff0c;却发生了尴尬的问题&#xff0c;C盘被不断增大的conda环境和缓存占据得快满了。 在网上找了些教程&#xff0c;大多是讲迁移的&#xff0c;专门讲改本地改储存位置的比较少&am…

Python爬虫工作基本流程及urllib模块详解

在2025年的数据驱动时代&#xff0c;网络数据成为企业与个人的“金矿”&#xff0c;而Python爬虫则是挖掘这金矿的“利器”&#xff01;无论是抓取电商价格、分析社交媒体趋势&#xff0c;还是构建知识库&#xff0c;Python爬虫都能让你事半功倍。然而&#xff0c;爬虫开发并非…

thinkphp8 模型-一对一,一对多,多对多 学习

thinkphp 命令创建模型&#xff08;和laravel基本一样&#xff09; php think make:model User 在模型里创建字段 protected $table User; protected $pk id; // 定义返回哪些字段 protected $field [id, name]; // 返回字段的类型 protected $schema [id > int] 模…

非线性方程组求解:复杂情况下的数值方法

在科学研究和工程应用中&#xff0c;非线性方程组的求解是一个常见的挑战。尤其当方程组包含复杂函数&#xff08;如特殊函数、积分、微分等&#xff09;&#xff0c;使得雅可比矩阵难以解析求导时&#xff0c;传统的基于解析雅可比矩阵的 Newton-Raphson 方法难以直接应用。本…

边缘计算网关EG8200Mini首发开箱视频丨破解工业互联“协议孤岛”,重塑数据价值核心引擎行业痛点直击|低代码开发

数据采集4G边缘计算网关plc 工业现场设备品牌林立&#xff08;西门子、三菱、欧姆龙等30品牌PLC&#xff09;、协议碎片化&#xff08;Modbus/OPC UA/BACnet等&#xff09;、网络环境复杂&#xff08;户外无光纤、车间电磁干扰&#xff09;——传统网关难以实现多源异构设备统一…

2024-2025下期《网络设备与配置》期末模拟测试

一、 单选题(每题2分&#xff0c;共60分) RIP协议的默认最大跳数是&#xff08; &#xff09; A. 10 B. 15 C. 20 D. 30以下哪个命令可以用来在交换机上进入全局配置模式&#xff1f;&#xff08; &#xff09; A. 使用enable命令 B. 使用configure terminal命令 C. 使用inte…

虹科案例 | 欣旺达如何实现动力电池测试的长期稳定性+自动化?

新能源汽车产业狂飙突进&#xff0c;动力电池测试正面临前所未有的技术大考。 传统电池测试方案常因数据丢帧、协议适配等问题&#xff0c;导致测试周期延长和交付延期。在这场关乎安全与效率的产业竞速中&#xff0c;高精度数据采集与全球化交付能力&#xff0c;已成为动力电…

第17天:数据库学习笔记1

数据库学习笔记 1 SQL语言介绍 2 数据库的安装 2.1 启动数据库 方式一&#xff1a;net start mysql 方式二&#xff1a;在计算机管理里面手动打开数据库 2.2 登录MySQL 方式一&#xff1a;本地登录 即数据库与客户端在同一台电脑上。 方式二&#xff1a;远程登录 mysq…

ChromaDB完全指南:从核心原理到RAG实战

一、引言:拥抱AI时代的“记忆”变革 在人工智能(AI)浪潮席卷全球的今天,大型语言模型(LLM)以其强大的自然语言处理能力,正在重塑我们与信息的交互方式。然而,LLM并非万能,它们普遍存在知识截止日期、无法访问私有数据等“记忆”短板。为了突破这一瓶颈,向量数据库应…

XCUITest + Swift 详细示例

💖亲爱的技术爱好者们,热烈欢迎来到 Kant2048 的博客!我是 Thomas Kant,很开心能在CSDN上与你们相遇~💖 本博客的精华专栏: 【自动化测试】 【测试经验】 【人工智能】 【Python】

Spring Boot + MyBatis + Redis Vue3 Docker + Kubernetes + Nginx

前言 前些天发现了一个巨牛的人工智能免费学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站 1.1 毕设项目需求分析&#xff08;附需求文档片段&#xff09; 一、项目全景与技术选型 1.1 毕设项目需求分析&#xff08;附需…

【云计算领域数学基础】组合数学优化

一、组合数学优化 1.1、定义与本质特征 1.1.1、组合数学优化的核心原理 ​问题本质与数学工具​ ​组合爆炸问题​&#xff1a;软件输入参数、路径组合随规模指数级增长&#xff0c;如10个二值参数需1024个用例。组合数学通过覆盖数组&#xff08;Covering Array&#xff09;、…

企业文档如何变身AI语料库?无忧文档NLP+OCR技术实战解析

当企业争相采购ChatGPT、文心一言等通用大模型时&#xff0c;却忽略了&#xff1a;企业文档其实是这座数字油田的核心资产。从产品手册、客户案例到会议纪要&#xff0c;企业沉淀的海量文档&#xff0c;这些看似零散的信息&#xff0c;其实正通过AI技术被转化为可复用的“语料库…

掌握Python编程的核心能力,能快速读懂并上手项目开发。

掌握Python编程的核心能力&#xff0c;能快速读懂并上手项目开发。 一套系统且通俗的讲解&#xff0c;理论讲解 实战技巧 代码框架模板&#xff0c;让你能&#xff1a; 看懂Python项目结构 能自己写代码&#xff1a;函数、流程控制、类和模块 能写出一个完整、规范的Pytho…

「Linux文件及目录管理」硬链接与软连接

知识点解析 在Linux系统中,硬链接(Hard Link)和软链接(Symbolic Link,又称软连接)是两种不同的文件链接方式: 1.硬链接(Hard Link): 本质:硬链接是文件的一个别名,与原文件共享相同的inode和磁盘数据块。特点: 数据共享:硬链接与原文件指向同一数据块,修改任…

分清display三个属性

display 三兄弟行为对比表格 属性值是否换行能否设置宽高默认宽度常用标签典型用途block是可以撑满父容器<div>, <p>, <section>页面结构、布局容器inline否不行随内容大小<span>, <a>文字中嵌套、小图标inline-block否可以随内容大小<img&g…

《棒球青训》打造几个国家级运动基地·棒球1号位

Youth Baseball/Softball Base Development Plan | 青少年棒垒球基地建设方案 Core Strategies | 核心战略 Regional Hub Construction | 区域枢纽建设 优先在 长三角/珠三角/成渝经济圈 建设 3大示范性基地 每个基地包含&#xff1a; ▶️ 国际标准青少年赛场&#xff08;…

JavaScript Symbol 属性详解

一、Symbol 的本质与基础 1. Symbol 是什么 JavaScript 的第七种原始数据类型&#xff08;ES6 引入&#xff09;创建唯一的、不可变的标识符主要用途&#xff1a;作为对象的属性键&#xff08;Symbol 属性&#xff09; // 创建 Symbol const id Symbol(id); // id 是描述符…