- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我想要一个解决这个问题的方法。
我们有两个整数序列 a[1...n]
和 b[1...n]
。每次我们都可以从 a[1...n]
中选择一个子序列(连续元素),然后将 x
(任意数)添加到所有子序列中。我们的目标是在最少的步骤中,对于每个 i:a[i] = b[i](模块 5)
(5是问题标题中m的例子)
限制:
1 <= n <= 10^6
1 <= a[i],b[i] <= 10^9
例如:
一 = 1 2
b = 3 4
最少:1
有没有可能给我一个解决它的方法?谢谢。
最佳答案
a
和 b
,长度相同 n
。m
; m = 5
在你的例子中。a
的值,使得所有 i 的 (a[i] - b[i]) % m == 0
。x
添加到a[i]
到a[j]
的所有连续元素。 首先,观察到我们可以通过将所有 b
值设置为零并将 a[i]
的每个值调整为 (a[i] - b[i]) % m
.然后我们就忽略b
,我们只考虑a
的取模m
,目标变成“a
中的所有值” code> 必须为零”。例如:
m = 5
a = [1234, 5678, 9012, 3456]
b = [3141, 2718, 1414, 4242]
简化为:
a = [3, 0, 3, 4]
显然,我们可以通过简单地单独更改每个非零值来达到目标。我们可以改进吗?有时。例如,这可以分两步解决:
a = [2, 2, 2, 2, 0, 3]
一个稍微复杂的例子需要四个步骤:
a = [2, 1, 2, 2, 1, 2, 0, 3]
+ 3, 3, 3, 3, 3, 3
a = [0, 4, 0, 0, 4, 0, 0, 3]
do the rest individually
据我所知,每当我们有一系列以相同数字开头和结尾的数字时,将它们全部更改为将端点归零不会受到惩罚:
a = [..., 3, ?, ?, ?, ?, ?, ?, 3, ...]
+ 2, 2, 2, 2, 2, 2, 2, 2
a = [..., 0, ?, ?, ?, ?, ?, ?, 0, ...]
这一步将两个数字归零。中间的数字不会更糟,除非它们全为零,即使那样,总步数也是两种方式。
虽然我无法严格证明它,但这是一个看起来非常理想的算法:
range = entire array
while true:
move endpoints inward to skip zeroes
if endpoints pass each other:
everything is zero, halt
if endpoints have equal value X:
add (5 - X) % m to range, which will zero out endpoints
loop
(endpoints are unequal)
for each endpoint:
identify the "run" of equal numbers R at the endpoint
(might be just one)
skip any zeroes after the run ("after" means "inward")
identify the next number N after the run and zeroes
if N of endpoint x equals R of endpoint y:
zero out the run at endpoint x
this will set up an advantageous equal-endpoint in next step
loop
(neither N equaled opposite R)
zero out whichever run is longer
loop
让我们将其应用于上面的示例数据,看看它是如何工作的。
a = [2, 1, 2, 2, 1, 2, 0, 3]
range = 2 1 2 2 1 2 0 3
no zeroes to skip at ends
unequal endpoints
left run: R = 2, N = 1
right run: R = 3, N = 2
N of right run = R of left run
zero out right run
range = 2 1 2 2 1 2 0 0
steps = 1
loop
range = 2 1 2 2 1 2 0 0
skip zeroes
range = 2 1 2 2 1 2
equal endpoints
add 3 to range
range = 0 4 0 0 4 0
steps = 2
loop
range = 0 4 0 0 4 0
skip zeroes
range = 4 0 0 4
equal endpoints
add 1 to range
range = 0 1 1 0
steps = 3
loop
range = 0 1 1 0
skip zeroes
range = 1 1
equal endpoints
add 4 to range
range = 0 0
steps = 4
loop
range = 0 0
skip zeroes
endpoints passed each other
halt
该算法按照预期采取了 4 个步骤。
关于algorithm - 两个序列和具有相同模块的最小步骤,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51531277/
这是代码片段。 请说出这种用小内存存储大数据的算法是什么。 public static void main(String[] args) { long longValue = 21474836
所以我使用 imap 从 gmail 和 outlook 接收电子邮件。 Gmail 像这样编码 =?UTF-8?B?UmU6IM69zq3OvyDOtc68zrHOuc67IG5ldyBlbWFpb
很久以前就学会了 C 代码;想用 Scheme 尝试一些新的和不同的东西。我正在尝试制作一个接受两个参数并返回两者中较大者的过程,例如 (define (larger x y) (if (> x
Azure 恢复服务保管库有两个备份配置选项 - LRS 与 GRS 这是一个有关 Azure 恢复服务保管库的问题。 当其驻留区域发生故障时,如何处理启用异地冗余的恢复服务保管库?如果未为恢复服务启
说,我有以下实体: @Entity public class A { @Id @GeneratedValue private Long id; @Embedded private
我有下一个问题。 我有下一个标准: criteria.add(Restrictions.in("entity.otherEntity", getOtherEntitiesList())); 如果我的
如果这是任何类型的重复,我会提前申请,但我找不到任何可以解决我的具体问题的内容。 这是我的程序: import java.util.Random; public class CarnivalGame{
我目前正在使用golang创建一个聚合管道,在其中使用“$ or”运算符查询文档。 结果是一堆需要分组的未分组文档,这样我就可以进入下一阶段,找到两个数据集之间的交集。 然后将其用于在单独的集合中进行
是否可以在正则表达式中创建 OR 条件。 我正在尝试查找包含此类模式的文件名列表的匹配项 第一个案例 xxxxx-hello.file 或者案例二 xxxx-hello-unasigned.file
该程序只是在用户输入行数时创建菱形的形状,因此它有 6 个 for 循环; 3 个循环创建第一个三角形,3 个循环创建另一个三角形,通过这 2 个三角形和 6 个循环,我们得到了一个菱形,这是整个程序
我有一个像这样的查询字符串 www.google.com?Department=Education & Finance&Department=Health 我有这些 li 标签,它们的查询字符串是这样
我有一个带有静态构造函数的类,我用它来读取 app.config 值。如何使用不同的配置值对类进行单元测试。我正在考虑在不同的应用程序域中运行每个测试,这样我就可以为每个测试执行静态构造函数 - 但我
我正在寻找一个可以容纳多个键的容器,如果我为其中一个键值输入保留值(例如 0),它会被视为“或”搜索。 map, int > myContainer; myContainer.insert(make_
我正在为 Web 应用程序创建数据库,并正在寻找一些建议来对可能具有多种类型的单个实体进行建模,每种类型具有不同的属性。 作为示例,假设我想为“数据源”对象创建一个关系模型。所有数据源都会有一些共享属
(1) =>CREATE TABLE T1(id BIGSERIAL PRIMARY KEY, name TEXT); CREATE TABLE (2) =>INSERT INTO T1 (name)
我不确定在使用别名时如何解决不明确的列引用。 假设有两个表,a 和 b,它们都有一个 name 列。如果我加入这两个表并为结果添加别名,我不知道如何为这两个表引用 name 列。我已经尝试了一些变体,
我的查询是: select * from table where id IN (1,5,4,3,2) 我想要的与这个顺序完全相同,不是从1...5,而是从1,5,4,3,2。我怎样才能做到这一点? 最
我正在使用 C# 代码执行动态生成的 MySQL 查询。抛出异常: CREATE TABLE dump ("@employee_OID" VARCHAR(50)); "{"You have an er
我有日期 2016-03-30T23:59:59.000000+0000。我可以知道它的格式是什么吗?因为如果我使用 yyyy-MM-dd'T'HH:mm:ss.SSS,它会抛出异常 最佳答案 Sim
我有一个示例模式,它的 SQL Fiddle 如下: http://sqlfiddle.com/#!2/6816b/2 这个 fiddle 只是根据 where 子句中的条件查询示例数据库,如下所示:
我是一名优秀的程序员,十分优秀!