C 练习实例68
题目:有 n 个整数,使其前面各数顺序向后移 m 个位置,最后m个数变成最前面的 m 个数。
程序分析:可以使用一个辅助数组来保存需要移动的元素,然后再将元素按照要求移动到正确的位置。
实例 1
#include <stdio.h>
// 通过 shiftArray 函数来实现数组元素的移动。
void shiftArray(int arr[], int n, int m) {
int temp[m];
// 保存最后 m 个数到临时数组
for (int i = n - m, j = 0; i < n; i++, j++) {
temp[j] = arr[i];
}
// 将前面的 n-m 个数向后移动 m 个位置
for (int i = n - m - 1; i >= 0; i--) {
arr[i + m] = arr[i];
}
// 将临时数组中的数放到最前面
for (int i = 0; i < m; i++) {
arr[i] = temp[i];
}
}
// 在 main 函数中获取用户输入的数组和要移动的位置,调用s hiftArray 函数,最后输出移动后的数组
int main() {
int n, m;
printf("请输入整数个数 n:");
scanf("%d", &n);
printf("请输入向后移动的位置 m:");
scanf("%d", &m);
int arr[n];
printf("请输入 %d 个整数:", n);
for (int i = 0; i < n; i++) {
scanf("%d", &arr[i]);
}
shiftArray(arr, n, m);
printf("移动后的数组:");
for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
// 通过 shiftArray 函数来实现数组元素的移动。
void shiftArray(int arr[], int n, int m) {
int temp[m];
// 保存最后 m 个数到临时数组
for (int i = n - m, j = 0; i < n; i++, j++) {
temp[j] = arr[i];
}
// 将前面的 n-m 个数向后移动 m 个位置
for (int i = n - m - 1; i >= 0; i--) {
arr[i + m] = arr[i];
}
// 将临时数组中的数放到最前面
for (int i = 0; i < m; i++) {
arr[i] = temp[i];
}
}
// 在 main 函数中获取用户输入的数组和要移动的位置,调用s hiftArray 函数,最后输出移动后的数组
int main() {
int n, m;
printf("请输入整数个数 n:");
scanf("%d", &n);
printf("请输入向后移动的位置 m:");
scanf("%d", &m);
int arr[n];
printf("请输入 %d 个整数:", n);
for (int i = 0; i < n; i++) {
scanf("%d", &arr[i]);
}
shiftArray(arr, n, m);
printf("移动后的数组:");
for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
实例 2
// Created by www.runoob.com on 15/11/9.
// Copyright © 2015年 菜鸟教程. All rights reserved.
//
#include <stdio.h>
#include <stdlib.h>
int main()
{
int arr[20];
int i,n,offset;
//输入数组大小和数组内容
printf("Total numbers?\n");
scanf("%d",&n);
printf("Input %d numbers.\n",n);
for(i=0;i<n;i++)
scanf("%d",&arr[i]);
//输入滚动偏移量
printf("Set your offset.\n");
scanf("%d",&offset);
printf("Offset is %d.\n",offset);
//打印滚动前数组
print_arr(arr,n);
//滚动数组并打印
move(arr,n,offset);
print_arr(arr,n);
}
//打印数组
void print_arr(int array[],int n)
{
int i;
for(i=0;i<n;++i)
printf("%4d",array[i]);
printf("\n");
}
//滚动数组
void move(int array[],int n,int offset)
{
int *p,*arr_end;
arr_end=array+n; //数组最后一个元素的下一个位置
int last;
//滚动直到偏移量为0
while(offset)
{
last=*(arr_end-1);
for(p=arr_end-1;p!=array;--p) //向右滚动一位
*p=*(p-1);
*array=last;
--offset;
}
}
banhuxun
ban***un@163.com
参考解法:
banhuxun
ban***un@163.com
半折枯松
152***0570@qq.com
参考方法:
半折枯松
152***0570@qq.com
HIT_CCC
117***2963@qq.com
参考方法:
HIT_CCC
117***2963@qq.com
HIT_CCC
117***2963@qq.com
参考方法:
HIT_CCC
117***2963@qq.com
huanhuan
992***291@qq.com
参考方法(用两个数组实现):
huanhuan
992***291@qq.com
zxw09y
444***701@qq.com
参考方法:
zxw09y
444***701@qq.com
BakaCirno1001
341***2969@qq.com
BakaCirno1001
341***2969@qq.com
BakaCirno1001
341***2969@qq.com
再用函数实现(方法有些复杂)
BakaCirno1001
341***2969@qq.com
Darkbird00x0
107***4459@qq.com
初学者编写,借助其他两个数组存储并重新赋元素,代码比较好理解。
Darkbird00x0
107***4459@qq.com
kleeper
845***161@qq.com
利用malloc创建两个动态数组
kleeper
845***161@qq.com
gitm2lin
197***4269@qq.com
用 2 个数组实现,原理类似补码原理,得到新位置索引后,直接赋值即可:
结果:
gitm2lin
197***4269@qq.com