叫我小林就好 2022-10-18 23:00 采纳率: 100%
浏览 33
已结题

请问一下为什么要定义为int 0?为什么需要三次逆置?一次不行吗?

请问一下为什么要定义为int 0?为什么需要三次逆置?一次逆置不行吗?

img

  • 写回答

1条回答 默认 最新

  • qzjhjxj 2022-10-18 23:59
    关注

    算法思路里,已经说清楚了,先将 a 段的元素逆置,再将 b 段的元素逆置,最后将 a + b 段逆置,共调用逆置函数三次。
    void Reverse(int A[], int o, int n); 函数共三个形参,int A[] 是数组形参,int o ,这是字符 'o‘ ,不是数字 0, 这是数组的起始地址下标,int n 是数组的长度即元素个数。
    这个函数可以实现将 数组 A[] 分段操作,第一次 Reverse(A, 0 ,m-1) ; 实现对 a 段 A[0] - A[m-1] 元素的逆置, 第二次 Reverse(A,m ,m+n-1) ;实现对 b 段 A[m] - A[m+n-1] 元素逆置,第三次Reverse(A, 0 ,m+n-1) ; 是对整个 A[] 数组逆置。
    所以在Reverse(int *,int ,int ) ;函数体里,for(i = o; .......) 这里 i = 字符 o , 不是 0 。建议将函数的形参名改为: Reverse(int A[],int start ,int end) ;更直观,函数实现里,修改如下:

    void Reverse(int A[], int start, int end)
    {
        int i;
        Elemtype temp;
        for (i = start;i < end / 2;i++)
        {
            temp = A.data[i];
            A.data[i] = A.data[end - i - 1];
            A.data[end - i - 1] = temp;
        }
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

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

悬赏问题

  • ¥15 怎样才能让鼠标沿着线条的中心线轨迹移动
  • ¥60 用visual studio编写程序,利用间接平差求解水准网
  • ¥15 Llama如何调用shell或者Python
  • ¥20 谁能帮我挨个解读这个php语言编的代码什么意思?
  • ¥15 win10权限管理,限制普通用户使用删除功能
  • ¥15 minnio内存占用过大,内存没被回收(Windows环境)
  • ¥65 抖音咸鱼付款链接转码支付宝
  • ¥15 ubuntu22.04上安装ursim-3.15.8.106339遇到的问题
  • ¥15 blast算法(相关搜索:数据库)
  • ¥15 请问有人会紧聚焦相关的matlab知识嘛?