栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

scau 8638 直接插入排序

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

scau 8638 直接插入排序

Description
用函数实现直接插入排序,并输出每趟排序的结果.
输入格式
第一行:键盘输入待排序关键的个数n
第二行:输入n个待排序关键字,用空格分隔数据
输出格式
每行输出一趟排序结果,数据之间用一个空格分隔
输入样例
10
5 4 8 0 9 3 2 6 7 1
输出样例
4 5 8 0 9 3 2 6 7 1
4 5 8 0 9 3 2 6 7 1
0 4 5 8 9 3 2 6 7 1
0 4 5 8 9 3 2 6 7 1
0 3 4 5 8 9 2 6 7 1
0 2 3 4 5 8 9 6 7 1
0 2 3 4 5 6 8 9 7 1
0 2 3 4 5 6 7 8 9 1
0 1 2 3 4 5 6 7 8 9

笔记笔记~

步骤:

(1)用数组存放待排序的数列

(2)循环n-1次,将a[i],a[i-1],a[i-2]…a[1]从后往前顺序比较。

顺序查找法:查找a[i](i=2,3…n)在已排好序的序列a[1]…a[i-1]中的插入位置,然后将a[i]插入到表长为i-1的有序序列a[1]…a[i-1]中,直到将r[n]插入到表长为n-1的有序序列a[1]…a[n-1]中,最后得到表长为n的有序序列。

代码如下。

#include 
#include 
#include 

using namespace std;

int n,a[100005];

void print()
{
    for(int i=1;i<=n;i++)
        cout << a[i] << ' ';
    cout << endl;
}

void zhijie(int a[])
{
    int i,j;
    for(i=2;i<=n;i++)
    {
        if(a[i]> n;
    for(int i=1;i<=n;i++)
        cin >> a[i];
    zhijie(a);
    return 0;
}

 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/876182.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号