优客文库提供全面的范文格式和文档模板,包括申请书、合同、借据、证明、求职信等,助力您快速撰写专业文档。

用java写一个算法:给定一个整数数组 nums,将数组中的元素向右轮转 k 个位置,其中 k 是非负数。代码换行对其

来自 黑龙江省哈尔滨市 的网友 时间: 热度:°C 加入收藏 我要投稿 点赞()
以下是用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]。
221381
领取福利

微信扫码领取福利

微信扫码分享