将整数数组变为非负整数数组

如何解决将整数数组变为非负整数数组

|| 从整数数组开始,以便值的总和是某个正整数
S
。以下例程始终以相同数量的步骤终止,并获得相同的结果。为什么是这样? 从数组ѭ1开始,使得所有ѭ2都是整数。当出现否定条目时,请执行以下操作: 选择任意索引
i
,使
x_i < 0
。 在
x_(i-1 % N)
上加上to2ѭ(负数)。 在
x_(i+1 % N)
上加上to2ѭ(负数)。 将
x_i
替换为
-x_i
(正数)。 该处理维持ѭ11的性质。对于任何给定的起始数组
x
,无论在任何步骤中选择哪个索引,执行这些步骤的次数都与所得向量相同。 (至少对我而言)这个过程在有限的时间内终止甚至不是显而易见的,更不用说具有这种不错的不变性了。 例: 以
x = [4,-1,-2]
并翻转
x_1
开始,结果是
[4,-2]
[3,1,-3]
[0,-2,3]
[-2,2,1]
[2,-1]
[1,1]
[0,0]
另一方面,翻转ѭ16开始
[4,-2]
[2,-3,2]
[-1,3,-2]
[-1,2]
[1,0]
如果选择
x_2
而不是
x_0
来翻转第三个数组,则最后一种方法是使用从第三个倒数向下的数组反转此解决方案。在所有情况下,6步导致ѭ20。 我有一个理由解释为什么这是正确的,但是在我看来,它过于复杂(与Coxeter小组有关)。有谁能更直接地思考为什么会发生这种情况?即使找到理由终止该协议,也是很好的。 奖励指向任何找到一种确定给定数组的步骤数的方法的人(无需执行整个过程)。     

解决方法

        我认为,不管您在每一步选择什么索引,查看输出向量和步数为何相同的最简单方法是将问题视为一堆矩阵和向量乘法。 对于
x
具有3个分量的情况,请将
x
视为3x1向量:
x = [x_0 x_1 x_2]\'
(其中
\'
是转置运算)。循环的每次迭代都将选择翻转
x_0,x_1,x_2
之一,并且它对ѭ12performs执行的运算与乘以以下矩阵之一相同:
      -1  0  0               1  1  0                1  0  1
s_0 =  1  1  0       s_1 =   0 -1  0        s_2 =   0  1  1
       1  0  1               0  1  1                0  0 -1
其中乘以
s_0
是在索引
i=0
s_1
对应于
i=1
s_2
对应于
i=2
时执行的运算。使用此视图,您可以将算法解释为在每次迭代时将对应的
s_i
矩阵乘以
x
。因此,在第一个示例中,首先将
x_1
翻转,该算法计算得出:
s_1*s_2*s_0*s_1*s_2*s_1[4 -1 -2]\' = [0 1 0]\'
您选择的索引不会影响最终输出向量的事实来自于
s
矩阵的两个有趣属性。首先是
s_i*s_(i-1)*s_i = s_(i-1)*s_i*s(i-1)
,其中
i-1
是模数
n
的模数。该属性是查看为什么在包含3个元素的示例中获得相同结果的唯一需要的属性:
s_1*s_2*s_0*s_1*s_2*s_1 = s_1*s_2*s_0*(s_1*s_2*s_1) = s_1*s_2*s_0*(s_2*s_1*s_2)
,对应于开始时选择
x_2
,最后:
s_1*s_2*s_0*s_2*s_1*s_2 = s_1*(s_2*s_0*s_2)*s_1*s_2 = s_1*(s_0*s_2*s_0)*s1*s2
,对应于选择一开始翻转
x_2
,然后在第三次迭代中选择翻转
x_0
。 第二个属性仅在
x
具有4个或更多元素时适用。每当
k <= i-2
以again41ѭ为模再次计算computed50ѭ时,便是
s_i*s_k = s_k*s_i
。当
x
具有4个元素时,当考虑矩阵形式时,此属性显而易见:
       -1  0  0  0          1  1  0  0          1  0  0  0          1  0  0  1
s_0 =   1  1  0  0   s_1 =  0 -1  0  0   s_2 =  0  1  1  0   s_3 =  0  1  0  0
        0  0  1  0          0  1  1  0          0  0 -1  0          0  0  1  1
        1  0  0  1          0  0  0  1          0  0  1  1          0  0  0 -1
第二个属性从本质上说,您可以交换发生无冲突翻转的顺序。例如,在4元素向量中,如果先翻转
x_1
然后翻转
x_3
,则与先翻转
x_3
然后翻转then14ѭ的效果相同。     ,        我想象在两个方向上将负值推出,直到它们减弱为止。由于加法是可交换的,因此处理元素的顺序无关紧要。     ,这是一个N可以被3整除的观察结果……可能没有用,但我想写下来。 令
w
(复数)为1的原始立方根;即
w^3 = 1
1 + w + w^2 = 0
。例如,
w = cos(2pi/3) + i*sin(2pi/3)
。 考虑总和ѭ62。也就是说,将序列中的每个元素乘以consecutive58ѭ的连续幂,并将它们全部相加。 每个步骤的总和都会发生一些有趣的事情。 考虑序列中的三个连续数字
[a,-b,c]
,其中b为正。假设这些元素与ѭ58的幂对齐,使得这三个数字对总和贡献
a - b*w + c*w^2
。 现在,对中间元素执行此步骤。 在执行此步骤之后,这些数字将为总和贡献
(a-b) + b*w + (c-b)*w^2
。 但是从since60ѭ开始,
b + b*w + b*w^2 = 0
也开始。因此,我们可以将其添加到前面的表达式中以获得
a + 2*b*w + c
。这与我们之前执行的步骤非常相似。 换句话说,该步骤仅将“ 71”加到总和上。 如果三个连续的数字排列有
w
的幂以表示(例如)
a*w - b*w^2 + c
,那么该步骤将增加
3*b*w^2
。 换句话说,无论ѭ58power的幂与三个数字如何对齐,阶跃都会使和增加by76ѭ,
3*b*w
或or74ѭ。 不幸的是,从ѭ79开始,这实际上并没有产生稳定增加的功能。因此,正如我所说,可能没有用。但是,似乎似乎仍然是一种合理的策略,即为每个步调单调变化的位置寻找一个“签名”。     

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-