java!c! 2023-07-10 16:00 采纳率: 100%
浏览 20
已结题

有n个整数,使其前面各数按顺序向后移动m个位置,最后m个数变成最前面的m个数

题目描述:有n个整数,使其前面各数按顺序向后移动m个位置,最后m个数变成最前面的m个数

#include<stdio.h>
#define M 100 
void main()
{
    int n=0,m,a[M],i,b[M],j;
    printf("请输入n个整数:\n");
    scanf("%d",&a[M]);
   printf("需要向后移动m位:\n");
    scanf("%d",&m); 
     for(i=0;a[i]!='\0';i++)
    n++;
    for(i=n-m;i<n;i++)
    for(j=0;j<=m-1;j++)
        b[j]=a[i];
    for(i=0;i<n-m;i++)
    for(j=m;j<n;j++)
       b[j]=a[i];
    for(i=0;i<n;i++)
       printf("%3d",b[M]);
       return;
}

m输不进去,是哪里错了呢

img

  • 写回答

4条回答 默认 最新

  • winx96 2023-07-10 16:12
    关注

    如有帮助 请点个采纳~

    #include <stdio.h>
    #define M 100
    
    int main()
    {
        int n = 0, m, a[M], b[M], i, j;
        
        printf("请输入n个整数:\n");
        scanf("%d", &n);
        
        printf("请输入需要向后移动m位:\n");
        scanf("%d", &m);
        
        printf("请输入%d个整数:\n", n);
        for (i = 0; i < n; i++)
        {
            scanf("%d", &a[i]);
        }
    
        for (i = 0; i < m; i++)
        {
            b[i] = a[n - m + i];
        }
    
        for (i = 0; i < n - m; i++)
        {
            b[m + i] = a[i];
        }
    
        printf("移动后的数组:\n");
        for (i = 0; i < n; i++)
        {
            printf("%3d", b[i]);
        }
        
        return 0;
    }
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 7月18日
  • 已采纳回答 7月10日
  • 创建了问题 7月10日

悬赏问题

  • ¥30 电脑误删了手机的照片怎么恢复?
  • ¥15 (标签-python|关键词-char)
  • ¥15 python+selenium,在新增时弹出了一个输入框
  • ¥15 苹果验机结果的api接口哪里有??单次调用1毛钱及以下。
  • ¥20 学生成绩管理系统设计
  • ¥15 来一个cc穿盾脚本开发者
  • ¥15 CST2023安装报错
  • ¥15 使用diffusionbert生成文字 结果是PAD和UNK怎么办
  • ¥15 有人懂怎么做大模型的客服系统吗?卡住了卡住了
  • ¥20 firefly-rk3399上启动卡住了