- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试仅使用单个一维数组将数组左移 n 个位置。我可以在两个数组中完成它,但我还没有想出如何使用一个数组来完成它。请提出您的建议
最佳答案
实际上有一个聪明的算法。我们将使用 A
表示数组,N
表示数组大小,和 n
表示要移动的位置数。换类后您想要 i-th
要移动到 ((i + n) mod N)-th
的元素位置,因此我们可以通过以下映射定义新位置:
f(j) := (j + n) mod N (j = 0,...,N - 1)
i
处的元素开始.我们要做的是将元素移动到位置
i
到位置
f(i)
,但随后我们将覆盖该位置的元素,因此我们需要先保存位置
f(i)
处的元素然后执行移位。一旦我们移动了第一个元素,我们需要选择另一个元素来移动。由于我们想要节省空间,显而易见的候选对象是我们刚刚保存的元素(位于
f(i)
中的元素)。和以前一样,我们将元素保存在位置
f(f(i))
然后将我们保存的元素复制到那个位置。我们不断重复这个过程(经过位置
i, f(i), f(f(i)), f(f(f(i))), ...
),直到我们到达一个我们已经移动的元素(我们保证这样做,因为有有限多个位置)。如果我们通过了所有元素,那么我们就完成了,如果没有,那么我们选择另一个元素(还没有被移动),比如位置
j
,并重复该过程(通过
j, f(j), f(f(j)), f(f(f(j))), ...
)。就是这样。但是在我们可以实现这样的算法之前,或者甚至在我们确定这是否确实是一个好的算法之前,我们需要回答几个问题:
i, f(i), f(f(i)), ...
.我们怎么知道我们到达了一个已经转移的位置?我们是否需要保存我们经过的每个位置?如果我们这样做,那么这意味着我们需要保存一个大小为 N 的数组(以覆盖所有位置),并且我们还需要在每次移动元素时执行查找。这将使算法非常低效。幸运的是,这不是必需的,因为序列 i, f(i), f(f(i)), ...
必须在位置 i
处环绕自身,所以我们只需要等到我们到达那个位置。我们可以如下证明这个断言:假设我们遇到的第一个重复元素不是 i
.那么我们必须有 2 个不同的元素,当移动时会到达相同的位置 - 一个矛盾。 i, f(i), f(f(i)), ...
,但仍有元素未移动(我们可以通过计算移动了多少个元素来判断)。我们现在如何找到位置 j
包含这样的元素?而且,一旦我们完成第二次迭代(通过 j, f(j), f(f(j)), ...
)我们如何找到第三个位置 k
带有未移位的元素?等等.. 这也可能表明我们需要保存一个数组来说明使用过的\未使用的元素,并在每次需要查找未使用的元素时执行查找。然而,我们可以再次放松,因为我们很快就会展示,所有的起始位置(我们用 i
、 j
和 k
表示)都是相邻的。这意味着,如果我们从位置 i
开始,我们接下来选择 i + 1
,然后 i + 2
,等等…… i, f(i), f(f(i)), ...
和 j, f(j), f(f(j)), ...
(其中 i
和 j
不同)包含共同元素?如果他们这样做将意味着该算法是无用的,因为它可以将同一个元素移动两次 - 导致它最终处于错误的位置。那么答案(当然)是它们不能包含公共(public)元素。我们将说明原因。 d := gcd(N, n)
.对于每一个整数:
i = 0,...,d - 1
我们定义了以下集合:
S(i) := { kd + i | k = 0,...,N/d - 1}
S(0),...,S(d - 1)
合盖套
{0,...,N - 1}
.我们还观察到,在对集合中的元素进行划分时
S(i)
来自
d
,我们只剩下余数
i
,并将元素从不同的集合中划分
S(j)
来自
d
会给我们留下不同的余数(
j
)。因此,没有两个集合包含一个公共(public)元素。有了这个,我们已经建立了集合
S(0),...,S(d - 1)
形成
{0,...,N - 1}
的分区
i = 0,...,d - 1
,我们将定义集合
T(i)
如
i, f(i), f(f(i)), ...
.根据
f
的定义我们可以写
T(i)
如下:
T(i) = {(kn + i) mod N | k is an integer}
x
是
T(i)
中的一个元素,那么我们可以写一些
k
:
x = (kn + i) mod N = (k(n/d)d + i) mod N
z := k(n/d) mod N/d
,然后乘以
d
, 我们有:
kn mod N = zd
x = (kn + i) mod N = zd + i
x
也在
S(i)
.同样,如果我们取一些
y
来自
S(i)
我们观察到,对于一些
k
:
y = kd + i
gcd(n/d, N/d) = 1
存在一个
q
使得
q(n/d) mod N/d = 1
(模逆),因此我们可以写(乘以
kd
):
kd = kqn mod N
y = kd + i = ((kq)n + i) mod N
y
也在
T(i)
.我们得出的结论是
T(i) = S(i)
.从这个事实我们可以很容易地展示我们之前的断言。首先,由于集合形成了
{0,...,N - 1}
的分区。满足第三个断言(没有两个序列包含公共(public)元素)。二、由集合的定义
S(i)
我们可以带任何组
d
{0,...N - 1}
中的相邻元素并且它们中的每一个都将被放置在不同的集合中。这满足第二个断言。
0, d, 2d, ..., (N/d - 1)d
中的所有元素通过简单地替换位置
n mod N
处的元素元素位于
0
,位置
2n mod N
处的元素元素位于
n mod N
,依此类推……直到我们返回位置
0
中的元素(我们确信会发生)。下面是一个伪代码示例:
temp <- A[0]
j <- N - (n mod N)
while j != 0 do
A[(j + n) mod N] <- A[j];
j <- (j - n) mod N
A[n mod N] <- temp;
S(0)
.覆盖其余的集合,即
S(1), … ,S(d-1)
,我们将简单地以与第一个相同的方式迭代每个集合:
for i <- 0 to d - 1
temp <- A[i]
j <- N - ((n - i) mod N)
while j != i do
A[(j + n) mod N] <- A[j];
j <- (j - n) mod N
A[(i + n) mod N] <- temp;
O(1)
空间。 Java 中的实现示例:
public static int gcd(int a, int b) {
while(b != 0) {
int c = a;
a = b;
b = c % a;
}
return a;
}
public static void shift_array(int[] A, int n) {
int N = A.length;
n %= N;
if(n < 0)
n = N + n;
int d = gcd(N, n);
for(int i = 0; i < d; i++) {
int temp = A[i];
for(int j = i - n + N; j != i; j = (j - n + N) % N)
A[(j + n) % N] = A[j];
A[i + n] = temp;
}
}
关于java - 在java中将数组循环左移n个位置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11893053/
我正在尝试创建一个包含 int[][] 项的数组 即 int version0Indexes[][4] = { {1,2,3,4}, {5,6,7,8} }; int version1Indexes[
我有一个整数数组: private int array[]; 如果我还有一个名为 add 的方法,那么以下有什么区别: public void add(int value) { array[va
当您尝试在 JavaScript 中将一个数组添加到另一个数组时,它会将其转换为一个字符串。通常,当以另一种语言执行此操作时,列表会合并。 JavaScript [1, 2] + [3, 4] = "
根据我正在阅读的教程,如果您想创建一个包含 5 列和 3 行的表格来表示这样的数据... 45 4 34 99 56 3 23 99 43 2 1 1 0 43 67 ...它说你可以使用下
我通常使用 python 编写脚本/程序,但最近开始使用 JavaScript 进行编程,并且在使用数组时遇到了一些问题。 在 python 中,当我创建一个数组并使用 for x in y 时,我得
我有一个这样的数组: temp = [ 'data1', ['data1_a','data1_b'], ['data2_a','data2_b','data2_c'] ]; // 我想使用 toStr
rent_property (table name) id fullName propertyName 1 A House Name1 2 B
这个问题在这里已经有了答案: 关闭13年前。 Possible Duplicate: In C arrays why is this true? a[5] == 5[a] array[index] 和
使用 Excel 2013。经过多年的寻找和适应,我的第一篇文章。 我正在尝试将当前 App 用户(即“John Smith”)与他的电子邮件地址“jsmith@work.com”进行匹配。 使用两个
当仅在一个边距上操作时,apply 似乎不会重新组装 3D 数组。考虑: arr 1),但对我来说仍然很奇怪,如果一个函数返回一个具有尺寸的对象,那么它们基本上会被忽略。 最佳答案 这是一个不太理
我有一个包含 GPS 坐标的 MySQL 数据库。这是我检索坐标的部分 PHP 代码; $sql = "SELECT lat, lon FROM gps_data"; $stmt=$db->query
我需要找到一种方法来执行这个操作,我有一个形状数组 [批量大小, 150, 1] 代表 batch_size 整数序列,每个序列有 150 个元素长,但在每个序列中都有很多添加的零,以使所有序列具有相
我必须通过 url 中的 json 获取文本。 层次结构如下: 对象>数组>对象>数组>对象。 我想用这段代码获取文本。但是我收到错误 :org.json.JSONException: No valu
enter code here- (void)viewDidLoad { NSMutableArray *imageViewArray= [[NSMutableArray alloc] init];
知道如何对二维字符串数组执行修剪操作,例如使用 Java 流 API 进行 3x3 并将其收集回相同维度的 3x3 数组? 重点是避免使用显式的 for 循环。 当前的解决方案只是简单地执行一个 fo
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我有来自 ASP.NET Web 服务的以下 XML 输出: 1710 1711 1712 1713
如果我有一个对象todo作为您状态的一部分,并且该对象包含数组列表,则列表内部有对象,在这些对象内部还有另一个数组listItems。如何更新数组 listItems 中 id 为“poi098”的对
我想将最大长度为 8 的 bool 数组打包成一个字节,通过网络发送它,然后将其解压回 bool 数组。已经在这里尝试了一些解决方案,但没有用。我正在使用单声道。 我制作了 BitArray,然后尝试
我们的数据库中有这个字段指示一周中的每一天的真/假标志,如下所示:'1111110' 我需要将此值转换为 boolean 数组。 为此,我编写了以下代码: char[] freqs = weekday
我是一名优秀的程序员,十分优秀!