美文网首页Index out of boundsC/C++
实现冒泡排序时又一例数组越界导致的奇妙现象

实现冒泡排序时又一例数组越界导致的奇妙现象

作者: Dumbass | 来源:发表于2017-07-30 02:25 被阅读0次

代码:

#include <stdio.h>
#include "print_int_array.h"
int main(void)
{
  int array[10] = {0,4,2,1,6,3,1,5,0,1};
  int cache;
  for(int i=0;i<10;++i)
  {
    for(int k=0;k<10-i;++k) //BUG
    {
      if(array[k] > array[k+1])
      {
        cache = array[k];
        array[k] = array[k+1];
        array[k+1] = cache;
      }
    }
    print_int_array(array,10);
  }
  return 0;
}

问题在于注释旁的语句,array[k+1]最大时可达array[10],C只保证其合法,并不保证其内容。
如运行上述程序,会出现时而正常时而崩溃的奇妙现象,总结原因为:
array[k+1]可能是任意值,若符合 array[k] > array[k+1],直接参与排序过程,造成数组内有11个元素。

相关文章

  • 实现冒泡排序时又一例数组越界导致的奇妙现象

    代码: 问题在于注释旁的语句,array[k+1]最大时可达array[10],C只保证其合法,并不保证其内容。如...

  • Java 实现冒泡排序

    本文介绍冒泡排序原理及 Java 语言实现。 目录 冒泡排序原理 代码实现 冒泡排序原理 比较相邻的元素,升序时如...

  • C数组知识点(越界风险、数组传递、栈溢出)

    一、一维数组 1.数组初始化 2.数组越界会导致的风险 数组越界就是访问数组元素的时候,索引超过了定义的数组长度,...

  • 利用runtime来实现一个数组防崩溃替换

    前言 很多时候,我们常常在使用数组的时候因为数组越界而导致程序崩溃。我们通过runtime中的特殊手段,实现在运行...

  • iOS 数组越界 Crash处理

    前段时间由于app 没有做好数组越界处理,导致 App 大面积崩溃.数组越界这点小事,苹果也没有帮我们处理好,网上...

  • ios开发之防数组越界

    ios开发中,不免会遇到数组越界的问题,而当数组越界时往往会导致程序的崩溃,结局的方法之一就是在数组的分类中使用r...

  • iOS Crash三部曲~之二常见Crash

    1 越界 1.1 数组越界 第1类崩溃就是越界问题,最常见的就是数组越界。 崩溃信息: 分析: 可以看出当前数组的...

  • 前端算法学习-第一篇

    冒泡排序算法 冒泡排序算法是最慢的排序算法之一,也是最容易实现的排序算法。之所以叫冒泡排序是因为使用这种算法排序时...

  • 学习OC

    1.数组越界,字典取空问题解决 实现一个数组或者字典的扩展方法,判断数组或者字典是否为空或者越界,如果是返回对象,...

  • 算法-冒泡排序

    算 法:冒泡排序算法时间复杂度: 冒泡排序算法概述 冒泡排序伪代码 冒泡排序实现 冒泡排序算法概述 冒泡排...

网友评论

    本文标题:实现冒泡排序时又一例数组越界导致的奇妙现象

    本文链接:https://www.haomeiwen.com/subject/qolhlxtx.html