用java写一个算法:给定一个整数数组 nums,将数组中的元素向右轮转 k 个位置,其中 k 是非负数。代码换行对其
以下是用Java编写的将数组元素向右轮转k个位置的算法:
```java
public class RotateArray {
public static void rotate(int[] nums, int k) {
int n = nums.length;
k = k % n; // 处理k大于数组长度的情况
// 反转整个数组
reverse(nums, 0, n - 1);
// 反转前k个元素
reverse(nums, 0, k - 1);
// 反转剩余的元素
reverse(nums, k, n - 1);
}
private static void reverse(int[] nums, int start, int end) {
while (start < end) {
int temp = nums[start];
nums[start] = nums[end];
nums[end] = temp;
start++;
end--;
}
}
public static void main(String[] args) {
int[] nums = {1, 2, 3, 4, 5, 6, 7};
int k = 3;
rotate(nums, k);
System.out.println("旋转后的数组:");
for (int num : nums) {
System.out.print(num + " ");
}
}
}
```
这段代码中,我们首先对k进行取模运算,以处理k大于数组长度的情况。然后,我们分别对整个数组、前k个元素和剩余元素进行反转操作,即先反转整个数组,再反转前k个元素,最后反转剩余的元素。最后,我们输出旋转后的数组。在示例中,给定的数组为[1, 2, 3, 4, 5, 6, 7],k为3,旋转后的数组为[5, 6, 7, 1, 2, 3, 4]。
```java
public class RotateArray {
public static void rotate(int[] nums, int k) {
int n = nums.length;
k = k % n; // 处理k大于数组长度的情况
// 反转整个数组
reverse(nums, 0, n - 1);
// 反转前k个元素
reverse(nums, 0, k - 1);
// 反转剩余的元素
reverse(nums, k, n - 1);
}
private static void reverse(int[] nums, int start, int end) {
while (start < end) {
int temp = nums[start];
nums[start] = nums[end];
nums[end] = temp;
start++;
end--;
}
}
public static void main(String[] args) {
int[] nums = {1, 2, 3, 4, 5, 6, 7};
int k = 3;
rotate(nums, k);
System.out.println("旋转后的数组:");
for (int num : nums) {
System.out.print(num + " ");
}
}
}
```
这段代码中,我们首先对k进行取模运算,以处理k大于数组长度的情况。然后,我们分别对整个数组、前k个元素和剩余元素进行反转操作,即先反转整个数组,再反转前k个元素,最后反转剩余的元素。最后,我们输出旋转后的数组。在示例中,给定的数组为[1, 2, 3, 4, 5, 6, 7],k为3,旋转后的数组为[5, 6, 7, 1, 2, 3, 4]。
上一篇:火影忍者手游青年水门的技能是什么
下一篇:表达自己对学校领导的关怀的语句