scau 8638 直接插入排序

scau 8638 直接插入排序,第1张

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;
}

 

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/langs/915186.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-16
下一篇2022-05-16

发表评论

登录后才能评论

评论列表(0条)

    保存