鱼C论坛

 找回密码
 立即注册
查看: 1408|回复: 2

[已解决]移动

[复制链接]
发表于 2023-11-17 23:28:20 | 显示全部楼层 |阅读模式
本帖为密码帖 ,请输入密码 
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-11-17 23:28:31 | 显示全部楼层    本楼为最佳答案   
  1. #include <stdio.h>
  2. int main()
  3. {
  4.     int n, m, i, j;
  5.     scanf("%d", &n);
  6.     int a[n];
  7.     for (i = 0; i < n; i++)
  8.     {
  9.         scanf("%d", &a[ i]);
  10.     }
  11.     scanf("%d", &m);
  12.     for (j = 0; j < n; j++)
  13.     {
  14.         printf("%d ", a[(j + n - m) % n]);
  15.     }
  16.     return 0;
  17. }
复制代码


这段代码的作用是将数组中的元素向后移动m个位置。在输出时,使用了 (j + n - m) % n 的方式来实现向后移动m个位置的效果。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-11-17 23:28:39 | 显示全部楼层
这段代码是一个将数组元素循环右移的程序。根据你提供的代码,它已经实现了你描述的功能。只需要输入一组整数,然后输入一个数 m,程序就会输出数组右移 m 位后的结果。

如果你有任何关于这段代码的问题,或者需要进一步的解释,请随时告诉我。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-20 13:50

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表