- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
Original Problem: Problem 1 (INOI 2015)
有两个数组A[1..N]
和 B[1..N]
一个操作SSum
在它们上定义为
SSum[i,j]
= A[i] + A[j] + B[t (where t = i+1, i+2, ..., j-1)]
什么时候i < j
SSum[i,j]
= A[i] + A[j] + B[t (where t = 1, 2, ..., j-1, i+1, i+2, ..., N)]
什么时候i > j
SSum[i,i]
= A[i]
挑战在于找到 SSum 的最大可能值。
我有一个基于计算 B
的前缀和的 O(n^2) 解决方案
#include <iostream>
#include <utility>
int main(){
int N;
std::cin >> N;
int *a = new int[N+1];
long long int *bPrefixSums = new long long int[N+1];
for (int iii=1; iii<=N; iii++) //1-based arrays to prevent confusion
std::cin >> a[iii];
bPrefixSums[0] = 0;
for (int b,iii=1; iii<=N; iii++){
std::cin >> b;
bPrefixSums[iii] = bPrefixSums[iii-1] + b;
}
long long int SSum, SSumMax=-(1<<10);
for (int i=1; i <= N; i++)
for (int j=1; j <= N; j++){
if (i<j)
SSum = a[i] + a[j] + (bPrefixSums[j-1] - bPrefixSums[i]);
else if (i==j)
SSum = a[i];
else
SSum = a[i] + a[j] + ((bPrefixSums[N] - bPrefixSums[i]) + bPrefixSums[j-1]);
SSumMax = std::max(SSum, SSumMax);
}
std::cout << SSumMax;
return 0;
}
对于 10^6 左右的较大 N 值,程序无法在 3 秒内完成任务。
最佳答案
由于我没有获得足够的代表来添加评论,所以我将在此答案中只写下想法。
这个问题真的很好,我实际上是被这个启发了link .感谢@superty。
我们可以把这个问题分开来考虑,换句话说,分为三种情况:i == j
, i < j
, i > j
.而我们只需要找到最大的结果。
考虑 i == j
: 最大的结果应该是a[i],在O(n)的时间复杂度内很容易找到答案。
考虑 i < j
:这与经典的最大和问题非常相似,并且对于每个 j
我们只需要找到 i
在左边,设法使结果最大。
首先考虑经典问题,如果我们被要求获得数组 a 的最大部分和,我们计算 a 的前缀和以获得 O(n) 复杂度。现在在这个问题上,几乎是一样的。
你可以看到这里(i < j
),我们有SSum[i,j] = A[i] + A[j] + B[t (where t = i+1, i+2, ..., j-1)] = (B[1] + B[2] + ... + B[j - 1] + A[j]) - (B[1] + B[2] + ... B[i] - A[i])
, 当 j
时第一项保持不变当 i
时,第二项保持不变。保持不变。所以现在的解决方案很清楚,你得到两个“前缀和”并找到最小的 prefix_sum_2[i]
对于每个 prefix_sum_1[j]
.
考虑 i > j
: 与此非常相似 discussion在 SO 上(但这个讨论没有多大帮助)。
类似地,我们得到SSum[i,j] = A[i] + A[j] + B[t (where t = 1, 2, ..., j-1, i+1, i+2, ..., N)] = (B[1] + B[2] + ... + B[j - 1] + A[j]) + (A[i] + B[i + 1] + ... + B[n - 1] + B[n])
.现在你需要得到数组的前缀和和后缀和(我们需要 prefix_sum[i] = a[i] + prefix_sum[i - 1] - a[i - 1]
和后缀类似),并得到另外两个数组,比如 ans_left[i]
作为the maximum value of the first term for all j <= i
和 ans_right[j]
作为the maximum value of the second term for i >= j
, 所以这个条件下的答案是所有 (ans_left[i] + ans_right[i + 1])
中的最大值
最后,原始问题所需的最大结果是这三个子案例答案的最大值。
很明显总的复杂度是O(n)。
关于arrays - 来自两个不同数组的最大切片和,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34679461/
简而言之: 我怎样才能切片?也就是说,能够指定我想从多个索引(例如 y = x[(2, 5, 11)] )中提取,而不仅仅是单个索引(例如 y = x[2] )。 简单示例 : 说我有这个数据: d
是否可以在 F# 中对 Array2D 进行切片? 说,let tmp =Array2D.init 100 100 (fun x y -> x * 100 + y) 如何从 tmp 中检索某些列或某些
例如,我希望文本仅显示“此处”,但它不起作用。文本经常变化,但我需要的单词保持在固定位置。我想访问该词。 我做错了什么? function myFunction() { var x = doc
当尝试使用spring的分页或切片来迭代非常大的mongodb集合时,程序运行正常,但在某些时候下一页/切片为空,并且在调试时出现“包含未知实例的页面/切片”消息. 这是代码示例: do { Pa
有人能给我一个关于如何分割 ListView 的例子吗?我正在使用 SimpleCursorAdapter 在 ListView 中显示数据.. 我的代码是这样的。 private WordDbAda
这个问题在这里已经有了答案: C++ slicing causing leak / undefined behavior / crash (3 个答案) 关闭 8 年前。 如果我有如下代码: cla
这个问题在这里已经有了答案: Understanding slicing (38 个答案) 关闭 5 年前。 我目前有 500 行数据。我想使用前五十行,然后跳过 50 行,依此类推。我该如何继续这
为什么对一行或一列进行切片会产生“无量纲数组”?例如: import numpy as np arr = np.zeros((10,10)) print arr.shape # (10, 10) 但是
我有以下 pandas 数据框: Shortcut_Dimension_4_Code Stage_Code 10225003 2 8225003
如何通过数组为 ruby 中的散列创建切片,如下所示: info = { :key1 => "Lorem", :key2 => "something...", :key3 => "
这个问题在这里已经有了答案: regex to get all text outside of brackets (4 个答案) 关闭 5 年前。 我正在编写的这个程序接收到一个大小不同的字符串,其
我尝试使用 tf.Tensor.getitem 对张量进行切片功能如下: indices = [0, 5] data[:,:,indices] 但是我得到以下错误: TypeError: can on
这个问题在这里已经有了答案: Can I create a "view" on a Python list? (10 个答案) 关闭 7 年前。 有没有一种方法可以在 Python 3 中创建序列的
我想弄清楚如何从多维数组中获取单个维度(为了论证,假设它是二维的),我有一个多维数组: double[,] d = new double[,] { { 1, 2, 3, 4, 5 }, { 5, 4,
我有一个 std::vector。我想创建代表该 vector 切片的迭代器。我该怎么做?在伪 C++ 中: class InterestingType; void doSomething(slice
写在前面 前面的文章介绍了Go的一些基本类型,本文开始涉及Go的一些容器类型,它们都是可以包含多个元素的数据结构,如数组、切片、map 数组 数组是具有相同类型且长度固定的一组元素集合,定义的格式:v
给定一个 numpy 数组和一个 __getitem__ 类型的索引,是否有一种惯用的方法来获取数组的相应切片,总是返回一个数组而不是标量? 有效索引的示例包括:int、slice、省略号或上述的元组
我创建了一个继承自 pandas.DataFrame 的类。在此类中添加了元数据(不是添加到列中,而是添加到类实例中): class MeasurementPoint(pandas.DataFrame
我想在空间上剪切视频以生成 N x M 个文件。 例如,我想把 test.video 拆分成 NxM 的瓦片? Video tiles 最佳答案 您可以使用 ffmpeg 及其 crop filter
这是一个示例代码。比如我想拉德国 在页面加载时切片。在这段代码中,它拉取第一个切片。 无功图; var 传说; var chartData = [{ 国家:“立陶宛”, 值:260}, { 国家:“爱
我是一名优秀的程序员,十分优秀!