用c语言写从键盘输入两个整数k和n(1<k,n<20),再输入n个整数,使其前面各数顺序向右移动k个位置,即最后k个数变成最前面k个数。
时间: 2024-05-14 20:19:49 浏览: 39
下面是用C语言实现的代码:
```c
#include<stdio.h>
int main()
{
int k, n, i, j, temp;
int a[20];
printf("请输入k和n(1<k,n<20):\n");
scanf("%d%d", &k, &n);
printf("请输入%d个整数:\n", n);
for(i = 0; i < n; i++)
{
scanf("%d", &a[i]);
}
// 将前面的k个数移到后面
for(i = 0; i < k; i++)
{
temp = a[n - 1];
for(j = n - 1; j > 0; j--)
{
a[j] = a[j - 1];
}
a[0] = temp;
}
printf("移动后的%d个数为:\n", n);
for(i = 0; i < n; i++)
{
printf("%d ", a[i]);
}
return 0;
}
```
首先,从键盘输入k和n。然后,使用数组a存储n个整数。接着,将前面的k个数移到后面,具体操作是:将数组最后一个数保存到temp中,然后将数组中的每个数向右移动一位,最后将temp赋值给数组的第一个数。最后,输出移动后的n个数。
相关问题
c语言:从键盘输入两个整数k和n(1<k,n<20),再输入n个整数,使其前面各数顺序向右移动k个位置,即最后k个数变成最前面k个数
以下是实现此功能的C语言代码:
```c
#include <stdio.h>
int main() {
int k, n, i, j, temp;
int nums[20];
// 从键盘输入k和n
printf("请输入k和n(1<k,n<20):");
scanf("%d %d", &k, &n);
// 从键盘输入n个整数
printf("请输入%d个整数:", n);
for (i = 0; i < n; i++) {
scanf("%d", &nums[i]);
}
// 将前面各数顺序向右移动k个位置
for (i = 0; i < k; i++) {
temp = nums[n - 1];
for (j = n - 1; j > 0; j--) {
nums[j] = nums[j - 1];
}
nums[0] = temp;
}
// 输出移动后的n个整数
printf("移动后的%d个整数:", n);
for (i = 0; i < n; i++) {
printf("%d ", nums[i]);
}
printf("\n");
return 0;
}
```
代码思路:
1. 从键盘输入k和n。
2. 从键盘输入n个整数,并存储在数组nums中。
3. 循环k次,每次将nums中最后一个数存储到temp中,再将nums中其他数向右移动一位,最后将temp存储到nums[0]中。
4. 输出移动后的n个整数。
注意事项:
1. 输入的k和n必须满足1<k,n<20的条件。
2. 输入的n个整数不能超过20个。
3. 程序只能处理整数,不能处理小数或其他类型的数据。
c语言写:从键盘输入两个整数k和n(1<k,n<20),再输入n个整数,使其前面各数顺序向右移动k个位置,即最后k个数变成最前面k个数。
```c
#include <stdio.h>
int main() {
int k, n;
printf("请输入k和n(1<k,n<20):");
scanf("%d %d", &k, &n);
int arr[n];
printf("请输入%d个整数:", n);
for(int i = 0; i < n; i++) {
scanf("%d", &arr[i]);
}
// 将前 n-k 个元素逆序
for(int i = 0, j = n-k-1; i < j; i++, j--) {
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
// 将后 k 个元素逆序
for(int i = n-k, j = n-1; i < j; i++, j--) {
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
// 将整个数组逆序
for(int i = 0, j = n-1; i < j; i++, j--) {
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
printf("移动后的数组为:\n");
for(int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
return 0;
}
```
这里的思路是先将前 n-k 个元素逆序,再将后 k 个元素逆序,最后将整个数组逆序即可得到结果。
阅读全文