C++实现插入排序对整数数组排序

 更新时间:2020年05月29日 08:31:13   作者:Alex山南水北  
这篇文章主要为大家详细介绍了C++实现插入排序对整数数组排序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

利用插入排序,对整数数组排序

根据如下插入排序基本思想编程:

  • 一个数显然是有序的,因此规模为1的排序问题能够求解;
  • 如果能够为n-1个数排序,那么当有n个数时,只需先将前n-1个数排好序,再将最后一个数插入前面这n-1个有序数列中的合适位置即可。

例如:

要对3,6,2,4从小到大排序:

1、考虑规模为1的问题,即数字3,一个数显然是有序的;
2、规模为1的问题求解完毕后,加入新的数字6,将其放在3后面,得到序列3,6,从而解决了规模为2的问题;
3、规模为2的问题求解完毕后,加入新的数字2,将其放在3前面,得到序列2,3,6,从而解决了规模为3的问题;
4、规模为3的问题求解完毕后,加入新的数字4,将其放在2和3中间,得到序列2,3,4,6,从而解决了规模为4的问题,排序过程结束。

适用于初学者

#include <iostream>

using namespace std;

int main() {
  int i, j, num, temp;
  int intarray[10] = {2, 5, 1, 9, 10, 0, 4, 8, 7, 6};
  int new_intarray[10] = {0};
  //第一个数不用排序
  new_intarray[0] = intarray[0];
  for (i = 1; i < 10; ++i) {
    //开始排序第i个数,把它储存在一个临时变量
    num = intarray[i];
    //判断第i个数和第i-1个数的大小,如果比第i-1个数大,则把第i个数放在新数组的第i位
    if (num >= new_intarray[i - 1])new_intarray[i] = num;
      //如果不是的话,依此从大到小交换位置,直到大小顺序符合
    else {
      new_intarray[i] = new_intarray[i - 1];
      new_intarray[i - 1] = num;
      //交换大小顺序错误的两个
      for (j = i - 1; j > 0; --j) {
        if (new_intarray[j] < new_intarray[j - 1]) {
          temp = new_intarray[j];
          new_intarray[j] = new_intarray[j - 1];
          new_intarray[j - 1] = temp;
        } else break;
      }
    }
  }
  for (i = 0; i < 10; ++i)cout << new_intarray[i] << '\t';
  return 0;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C语言链表实现学生管理系统

    C语言链表实现学生管理系统

    这篇文章主要为大家详细介绍了C语言链表实现学生管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-06-06
  • linux c++模拟简易网络爬虫实例

    linux c++模拟简易网络爬虫实例

    下面小编就为大家带来一篇linux c++模拟简易网络爬虫实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • Qt中QMainWindow使用及技巧

    Qt中QMainWindow使用及技巧

    QMainWindow是Qt框架中提供的一个主窗口类,它具有菜单栏、工具栏、状态栏等常见的GUI元素,本文就来介绍一下使用技巧,具有一定的参考价值,感兴趣的可以了解一下
    2023-10-10
  • c语言中联合体和枚举用法详解

    c语言中联合体和枚举用法详解

    结构体、联合体是C语言中的构造类型,结构体我们平时应该都用得很多,下面这篇文章主要给大家介绍了关于c语言中联合体和枚举用法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2023-12-12
  • C语言仿QQ聊天界面抖动功能

    C语言仿QQ聊天界面抖动功能

    这篇文章主要为大家详细介绍了C语言仿QQ聊天界面抖动功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-11-11
  • Qt中QUndoView控件的具体使用

    Qt中QUndoView控件的具体使用

    QUndoView是Qt框架中用于可视化显示QUndoStack内容的控件,本文主要介绍了Qt中QUndoView控件的具体使用,具有一定的参考价值,感兴趣的可以了解一下
    2025-04-04
  • Qt使用QWT绘制柱状图详解

    Qt使用QWT绘制柱状图详解

    QT中提供了一个叫做QWT的库。QWT,全称是Qt Widgets for Technical Applications,是一个基于LGPL版权协议的开源项目,可生成各种统计图。本文将通过它绘制柱状图,需要的可以参考一下
    2022-01-01
  • 实例讲解在C++的函数中变量参数及默认参数的使用

    实例讲解在C++的函数中变量参数及默认参数的使用

    这篇文章主要介绍了在C++的函数中变量参数及默认参数的使用,是C++函数入门学习中的基础知识,需要的朋友可以参考下
    2016-01-01
  • 一起来了解c语言的str函数

    一起来了解c语言的str函数

    这篇文章主要为大家详细介绍了c语言的str函数,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • 利用C++和QT实现Log自定义日志系统

    利用C++和QT实现Log自定义日志系统

    这篇文章主要为大家详细介绍了如何利用C++和QT实现Log自定义日志系统,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考下
    2023-12-12

最新评论