柠(♡˙︶˙♡)檬 2022-02-24 16:32 采纳率: 100%
浏览 44
已结题

冒泡排序中出现的问题

使用冒泡排序的方法对一组数据进行排列,当我让j=1;j<=10-i时,代码运行报错,但当改成j=0;j<=9-i时,代码就能运行成功,请问这是为什么?

#include<stdio.h>
int main()
{
    int arr[10] = { 21,31,64,75,37,9,94,3,12,58 };
    printf("排序前的序列:\n");
    for (int k = 0; k < 10; ++k)
    {
            printf("%d ", arr[k]);
    }
    
    for (int i = 1; i < 10; ++i)
    {
        for (int j = 1; j <= 10- i; ++j)
        {
            if (arr[j] > arr[j + 1])
            {
                int temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
    printf("\n");
    printf("排序后的序列:\n");
    
    for (int k = 0; k < 10; ++k)
    {
        printf("%d ", arr[k]);
    }
    return 0;
}

报错内容:

Run-Time Check Failure #2 - Stack around the variable 'arr' was corrupted.
运行时检查失败# 2 -变量' a rr '周围的堆栈损坏。
  • 写回答

4条回答 默认 最新

  • 关注

    因为arr[j + 1];会产生数组越界。

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 3月4日
  • 已采纳回答 2月24日
  • 创建了问题 2月24日

悬赏问题

  • ¥15 做个有关计算的小程序
  • ¥15 MPI读取tif文件无法正常给各进程分配路径
  • ¥15 如何用MATLAB实现以下三个公式(有相互嵌套)
  • ¥30 关于#算法#的问题:运用EViews第九版本进行一系列计量经济学的时间数列数据回归分析预测问题 求各位帮我解答一下
  • ¥15 setInterval 页面闪烁,怎么解决
  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历
  • ¥15 TLE9879QXA40 电机驱动
  • ¥20 对于工程问题的非线性数学模型进行线性化