P1115 最大字段和 动态规划

该博客介绍了一个寻找给定序列中连续子段最大和的问题,使用动态规划方法解决。题目要求处理序列长度不超过200000,元素绝对值不超过10000。在处理含有负数的情况下,若前一位置的子段和小于等于0,则当前位置的最佳选择是自身。博客通过示例和代码解释了解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述

给出一段序列,选出其中连续且非空的一段使得这段和最大。

输入输出格式

输入格式:

输入文件maxsum1.in的第一行是一个正整数N,表示了序列的长度。

第2行包含N个绝对值不大于10000的整数A[i],描述了这段序列。

输出格式:

输入文件maxsum1.out仅包括1个整数,为最大的子段和是多少。子段的最小长度为1。

输入输出样例

输入样例#1:
7
2 -4 3 -1 2 -4 3
输出样例#1:
4




说明

【样例说明】2 -4 3 -1 2 -4 3

【数据规模与约定】

对于40%的数据,有N ≤ 2000。

对于100%的数据,有N ≤ 200000。


水一波动规!~
要求最大连续字段和么,也就是说可以运用“树状数组的思想”?
l~r的子段和=[r]的前缀和-[l-1]的前缀和?是的吧
所以说用树状数组是可以做的吧(暴力枚举左右端点?)打给是的确会超时,反正我没试过。

如果用动规来实现这个思想呢?
对于一个给定的右端点r,为了最大化答案,我们要找到一个l使得了l<=r,使得[l-1]前缀最小;
此处用now来巧妙得维护这个[l-1]前缀和。
使前缀和最小即now最大,且now为正,才会取;
如果now<0显然是不优的。

所以就有了如下的代码:

#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;

int  now,ans,n,a[200010];

int main()
{
    scanf("%d",&n);
    for(int i=1;i<=n;i++)
    {
        scanf("%d",&a[i]);
        now=max(now+a[i],0);
        ans=max(now,ans);
    }
    printf("%d",ans);
}


但是呢,问题又来了!

你惊讶的发现一件事:本题的第二点是过不了的...

因为这个数据点是一串负数...和0取最大当然是不行的

(所以说我就WA啦)


于是乎我们要确定当有负数时该怎么办?

不知为什么我把now换成了数组f...

可以判断一下f[i-1]的值,如果它<=0那么当前点的最优的情况必然是它本身,嗯,没错,所以代码升级了:


#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;

int  now,ans,n,a[200010],f[200010];

int main()
{
    int ans=0x80000000;
    scanf("%d",&n);
    for(int i=1;i<=n;i++)
    {
        scanf("%d",&a[i]);
        if(f[i-1]<=0)
            f[i]=a[i];
        else f[i]=max(f[i-1]+a[i],0);
        ans=max(f[i],ans);
    }
    printf("%d",ans);
}

这就是最终的AC代码了。

(所以说我竟然会改动规的水题了!)

### 回答1: MySQL字段类型长度Java类型有以下对应关系: 1. 字符串类型: - CHAR(n):Java类型为String,长度为n。 - VARCHAR(n):Java类型为String,长度为n。 - TEXT:Java类型为String。 2. 数值类型: - INT:Java类型为int。 - BIGINT:Java类型为long。 - DECIMAL(p, s):Java类型为BigDecimal,其中p表示总位数,s表示小数位数。 3. 日期时间类型: - DATE:Java类型为java.sql.Date。 - TIME:Java类型为java.sql.Time。 - DATETIME:Java类型为java.sql.Timestamp。 4. 布尔类型: - BOOL、BOOLEAN:Java类型为boolean。 5. 二进制类型: - BLOB:Java类型为byte[]。 需要注意的是,Java的数据类型MySQL的字段类型并不完全一致,因此在进行数据类型转换时需要注意类型匹配。在使用JDBC连接MySQL进行数据操作时,可以根据需要使用ResultSet的get方法PreparedStatement的set方法来进行数据类型的转换。同时,在设计数据库表结构时也需要根据实际需求选择合适的MySQL字段类型,以确保数据的存储查询效率,并防止数据溢出或损失。 ### 回答2: MySQL的字段类型长度Java类型对应如下: 1. 字符串类型(VARCHAR、CHAR): - VARCHAR(n) 对应 Java 的 String 类型,表示一个可变长度的字符串,最大长度为 n,例如:VARCHAR(50) 对应 Java 的 String。 - CHAR(n) 对应 Java 的 String 类型,表示一个固定长度的字符串,长度为 n,例如:CHAR(20) 对应 Java 的 String。 2. 数值类型(INT、BIGINT、FLOAT、DOUBLE、DECIMAL): - INT 对应 Java 的 int 类型。 - BIGINT 对应 Java 的 long 类型。 - FLOAT 对应 Java 的 float 类型。 - DOUBLE 对应 Java 的 double 类型。 - DECIMAL(precision, scale) 对应 Java 的 BigDecimal 类型,其中 precision 表示总长度,scale 表示小数点后的位数,例如:DECIMAL(10, 2) 对应 Java 的 BigDecimal。 3. 日期时间类型(DATE、TIME、DATETIME、TIMESTAMP): - DATE 对应 Java 的 LocalDate 类型。 - TIME 对应 Java 的 LocalTime 类型。 - DATETIME TIMESTAMP 都对应 Java 的 LocalDateTime 类型。 4. 布尔类型(BOOLEAN、BIT): - BOOLEAN 对应 Java 的 boolean 类型。 - BIT(n) 对应 Java 的 byte[] 类型。 5. 其他类型: - BLOB 对应 Java 的 byte[] 类型,用于存储二进制数据。 - TEXT 对应 Java 的 String 类型,用于存储大文本数据。 需要注意的是,MySQL的字段类型长度Java类型对应是一种常见的映射方式,但不是唯一的方式。在不同的数据库编程语言中,可能会有一些差异或变化。此外,还可以使用数据库连接工具或框架进行字段类型Java类型的自映射。 ### 回答3: MySQL字段类型的长度Java类型对应关系如下: 1. 数值类型: - TINYINT:Java类型为byte,长度为1字节。 - SMALLINT:Java类型为short,长度为2字节。 - MEDIUMINT:Java类型为int,长度为3字节。 - INT:Java类型为int,长度为4字节。 - BIGINT:Java类型为long,长度为8字节。 - FLOAT:Java类型为float,长度为4字节。 - DOUBLE:Java类型为double,长度为8字节。 - DECIMAL:Java类型为BigDecimal,长度可自定义。 2. 字符串类型: - CHAR:Java类型为String,长度可自定义,最大为255字节。 - VARCHAR:Java类型为String,长度可自定义,最大为65535字节。 - TEXT:Java类型为String,长度可自定义,最大为65535字节。 - BLOB:Java类型为byte[],长度可自定义,最大为65535字节。 3. 日期时间类型: - DATE:Java类型为java.sql.Date,长度为3字节。 - TIME:Java类型为java.sql.Time,长度为3字节。 - DATETIME:Java类型为java.sql.Timestamp,长度为8字节。 - TIMESTAMP:Java类型为java.sql.Timestamp,长度为4字节。 - YEAR:Java类型为java.util.Date,长度为1字节。 4. 其他类型: - BOOLEAN:Java类型为boolean,长度为1字节。 - ENUM:Java类型为String,长度可自定义。 需要注意的是,MySQL的字段类型长度可能会受到存储引擎字符编码的影响,所以实际长度可能有所不同。对于字符串类型,长度指的是字符数,而不是字节数。另外,为了更准确地处理日期时间类型,建议使用对应的Java日期时间类。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值