【洛谷】P1216 数字三角形

import java.io.IOException;
import java.util.Scanner;public class P1216_数字三角形_DP_原版 {public static void main(String[] args) {Scanner sc = new Scanner(System.in);int n = sc.nextInt();int[][] dp = new int[n + 1][n + 1];int t;for (int i = 1; i <= n; i++) {for (int j = 1; j <= i; j++) {t = sc.nextInt();dp[i][j] = Math.max(dp[i - 1][j], dp[i - 1][j - 1]) + t;}}int res = 0;for (int i = 1; i <= n; i++) {res = Math.max(res,dp[n][i]);}System.out.println(res);}
}

先用DP,结果由于Java本身的内存占用大,不能AC:


现在进行输入优化:

来自:数字三角形 Number Triangles(java的MLE解决办法) - 吐司奶猫荷包蛋 - 博客园 (cnblogs.com)

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;public class P1216_数字三角形_DP {public static void main(String[] args) throws IOException {InputReader in = new InputReader(System.in);int n = in.nextInt();int[][] dp = new int[n + 1][n + 1];int t;for (int i = 1; i <= n; i++) {for (int j = 1; j <= i; j++) {t = in.nextInt();dp[i][j] = Math.max(dp[i - 1][j], dp[i - 1][j - 1]) + t;}}int res = 0;for (int i = 1; i <= n; i++) {res = Math.max(res, dp[n][i]);}System.out.println(res);}static class InputReader {BufferedReader br;public InputReader(InputStream stream) {br = new BufferedReader(new InputStreamReader(stream));}public int nextInt() throws IOException {int c = br.read(); // 从输入流中读取一个字符的 ASCII 码,并将其存储在变量c中while (c <= 32) { //跳过输入流中的空白字符c = br.read();}boolean negative = false; // 负号if (c == '-') {negative = true;c = br.read();}int x = 0;while (c > 32) {x = x * 10 + c - '0';c = br.read();}return negative ? -x : x;}public long nextLong() throws IOException {int c = br.read();while (c <= 32) {c = br.read();}boolean negative = false;if (c == '-') {negative = true;c = br.read();}long x = 0;while (c > 32) {x = x * 10 + c - '0';c = br.read();}return negative ? -x : x;}public String next() throws IOException {int c = br.read();while (c <= 32) {c = br.read();}StringBuilder sb = new StringBuilder();while (c > 32) {sb.append((char) c);c = br.read();}return sb.toString();}public double nextDouble() throws IOException {return Double.parseDouble(next());}}
}

快了近2倍不止,而且解决了空间占用

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

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

相关文章

Ollama教程——兼容OpenAI API:高效利用兼容OpenAI的API进行AI项目开发

相关文章: Ollama教程——入门&#xff1a;开启本地大型语言模型开发之旅 Ollama教程——模型&#xff1a;如何将模型高效导入到ollama框架 Ollama教程——兼容OpenAI API&#xff1a;高效利用兼容OpenAI的API进行AI项目开发 Ollama教程——兼容OpenAI API&#xff1a;高效利用…

推荐一个大学生可以参加的榜单赛事|人工智能赛道

【榜单赛事】第十四届全国大学生计算机应用能力与数字素养大赛 - 人工智能产业应用赛道人工智能编程赛项 正在火热报名中 本赛道定位于人工智能产业应用和实践&#xff0c;把人工智能产业真实的技能要求、能力要求体现在竞赛内容设计当中&#xff0c;并在竞赛环节融入实战项目…

专业神秘顾客调查:油漆企业如何有效监测销售门店价格违规情况?

在竞争激烈的油漆市场中&#xff0c;各大品牌为了争夺市场份额&#xff0c;都在寻求更加精准有效的管理方式。然而&#xff0c;销售门店的售价管理却成为了一道难题&#xff0c;令众多品牌头疼不已。为了维护品牌形象&#xff0c;确保市场公平竞争&#xff0c;深圳神秘顾客&…

软考121-上午题-【软件工程】-敏捷方法

一、敏捷方法 敏捷开发的总体目标是通过“尽可能早地、持续地对有价值的软件的交付”使客户满意。通过在软件开发过程中加入灵活性&#xff0c;敏捷方法使用户能够在开发周期的后期增加或改变需求。 敏捷过程的典型方法有很多&#xff0c;每一种方法基于一套原则&#xff0c;这…

阻塞队列和基本实现

1. 什么是阻塞队列 阻塞队列,从名字上看,它首先应该是一个队列,满足先进先出的原则.其次,我们来理解一下"阻塞"这个词.我们之前其实见过这个词,在介绍线程的状态时,我们讲过有一种状态就是阻塞状态.所谓的"阻塞",也就是一种等待,需要其他的线程进行唤醒,在…

跟TED演讲学英文:The next grand challenge for AI by Jim Fan

The next grand challenge for AI Link: https://www.ted.com/talks/jim_fan_the_next_grand_challenge_for_ai? Speaker: Jim Fan Date: October 2023 文章目录 The next grand challenge for AIIntroductionVocabularyTranscriptSummary后记 Introduction Researcher Jim…

Terraform 语法配置

配置语法 Terraform 的配置文件都是以 .tf 为后缀Terraform 支持两种模式 HCL、JSON Provider 插件 providers 地址&#xff1a;Terraform Registry Terraform 通过 provider 管理基础设施&#xff0c;使用 provider 与云供应商 API 进行交互&#xff0c;每个 Provider 都包含…

P1843 奶牛晒衣服

题目背景 熊大妈决定给每个牛宝宝都穿上可爱的婴儿装 。但是由于衣服很湿&#xff0c;为牛宝宝晒衣服就成了很不爽的事情。于是&#xff0c;熊大妈请你&#xff08;奶牛&#xff09;帮助她完成这个重任。 题目描述 一件衣服在自然条件下用一秒的时间可以晒干 a 点湿度。抠门…

多线程的学习

多线程编辑&#xff1a; 可以简单理解进程是一个软件 而线程就是一个软件中多个可以同时运行的功能 实现多线程的第一种方式&#xff1a;使用Thead类我们再自己创造一个类继承于这个类我们在对Thead方法进行重写&#xff0c;注意我们再重写的时候一定要加上Override这行 我犯下…

多线程回答的滚瓜烂熟,面试官问我虚线程了解吗?我说不太了解!

Java虚拟线程&#xff08;Virtual Threads&#xff09;标志着Java在并发编程领域的一次重大飞跃&#xff0c;特别是从Java 21版本开始。这项新技术的引入旨在克服传统多线程和线程池存在的挑战。 多线程和线程池 在Java中&#xff0c;传统的多线程编程依赖于Thread类或实现Ru…

2024 年“认证杯”数学中国数学建模网络挑战赛

题目 C题 云中的海盐 巴黎气候协定提出的目标是&#xff1a;在 2100 年前&#xff0c;把全球平均气温相对于工业 革命以前的气温升幅控制在不超过 2 摄氏度的水平&#xff0c;并为 1.5 摄氏度而努力。 但事实上&#xff0c;许多之前的研究已经指出&#xff0c;全球的碳排放以及…

主从数据同步原理

2.2.主从数据同步原理 2.2.1.全量同步 主从第一次建立连接时&#xff0c;会执行全量同步&#xff0c;将master节点的所有数据都拷贝给slave节点&#xff0c;流程&#xff1a; 这里有一个问题&#xff0c;master如何得知salve是第一次来连接呢&#xff1f;&#xff1f; 有几个…

嵌入式C语言(十四)

在现代操作系统架构中&#xff0c;内核空间和用户空间之间增加了一个中间层&#xff0c;这就是系统调用层。 系统调用层主要有如下作用。 为用户空间程序提供一层硬件抽象接口。这能够让应用程序编程者从学习硬件设备底层编程中解放出来。例如&#xff0c;当需要读写一个文件…

Linux操作系统的学习

Linux系统的目录结构 / 是所有目录的顶点目录结构像一颗倒挂的树 Linux常用命令 常见命令 序号命令对应英文作用1lslist查看当前目录下的内容2pwdprint work directory查看当前所在目录3cd [目录名]change directory切换目录4touch [文件名]touch如果文件不存在&#xff0c;新…

TRX节点部署

安装说明 安装版本&#xff1a;4.7.4 安装目录&#xff1a;/data/docker-compose/trx 配置文件路径&#xff1a;/data/docker-compose/trx/config.conf 节点data数据&#xff1a;/data/docker-compose/trx/output-directory 安装方式&#xff1a;Dockerfiledockerdocker-compos…

数字化采购管理系统有什么作用?

数字化采购管理系统是一种以计算机技术为基础&#xff0c;用于管理和优化采购过程的信息系统&#xff0c;它的作用主要体现在以下几个方面&#xff1a; 1、优化采购流程&#xff1a;数字化采购管理系统可以帮助企业建立和优化采购流程&#xff0c;通过设定采购流程的各个环节和…

6.11物联网RK3399项目开发实录-驱动开发之定时器的使用(wulianjishu666)

嵌入式实战开发例程【珍贵收藏&#xff0c;开发必备】&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1tkDBNH9R3iAaHOG1Zj9q1Q?pwdt41u 定时器使用 前言 RK3399有 12 个 Timers (timer0-timer11)&#xff0c;有 12 个 Secure Timers(stimer0~stimer11) 和 2 个 …

鸿蒙实战开发-如何实现标准化数据定义与描述的功能。

介绍 本示例主要使用ohos.data.uniformTypeDescriptor 展示了标准化数据定义与描述的功能&#xff0c;在新增预置媒体文件后&#xff0c;对媒体文件的utd标准类型获取、utd类型归属类型查询、获取文件对应的utd类型的默认图标、支持自定义数据类型等功能。 实现过程中还使用到…

编译安装nginx

nginx版本 安装组件 yum -y install openssl-devel pcre-devel zlib-devel ./configure --with-http_ssl_module && make && make installln -s /usr/local/nginx/sbin/nginx /usr/bin/nginx

【C++算法模板】背包九讲(上):01背包、完全背包、多重背包

文章目录 1&#xff09;01背包1&#xff1a;二维数组2&#xff1a;一维数组 2&#xff09;完全背包1&#xff1a;朴素做法2&#xff1a;公式优化3&#xff1a;再优化一维数组 3&#xff09;多重背包1&#xff1a;朴素做法2&#xff1a;二进制优化3&#xff1a;单调队列优化 1&a…