8.2插入排序
 #include "stdafx.h"
#include "stdafx.h" #include <iostream.h>
#include <iostream.h> #include <malloc.h>
#include <malloc.h>
 int const count=10;
int const count=10;
 typedef struct
typedef struct  {
{ int key;
    int key; }records;
}records;
 typedef records list[count+1];
typedef records list[count+1];
 void straightsort(list & r)
void straightsort(list & r) {
{ for(int i=2;i<=count;i++)
    for(int i=2;i<=count;i++) {
    { r[0].key=r[i].key;
        r[0].key=r[i].key; int j=i-1;
        int j=i-1; while(r[0].key<r[j].key)
        while(r[0].key<r[j].key) {
        { r[j+1].key=r[j].key;
            r[j+1].key=r[j].key; j--;
            j--; }
        } r[j+1].key=r[0].key;
        r[j+1].key=r[0].key; }
    } }
}
 void printList(list r)
void printList(list r) {
{ for(int i=0;i<count;i++)
    for(int i=0;i<count;i++) {
    { if (i==0)
        if (i==0) {
        { cout<<r[i+1].key;
            cout<<r[i+1].key; }
        } else
        else {
        { cout<<","<<r[i+1].key;
            cout<<","<<r[i+1].key; }
        } }
    } cout<<endl;
    cout<<endl; }
}
 int main(int argc, char* argv[])
int main(int argc, char* argv[]) {
{ list r;
    list r; for(int i=0;i<count;i++)
    for(int i=0;i<count;i++) {
    { cout<<"输入第"<<i+1<<"个主键";
        cout<<"输入第"<<i+1<<"个主键"; cin>>r[i+1].key;
        cin>>r[i+1].key; }
    } cout<<"输入的序列为:"<<endl;
    cout<<"输入的序列为:"<<endl; printList(r);
    printList(r); straightsort(r);
    straightsort(r); cout<<"插入排序后的序列为:"<<endl;
    cout<<"插入排序后的序列为:"<<endl; printList(r);
    printList(r); return 0;
    return 0; }
} 
    
    一点说明:为什么在标题中要嵌入英文?原因是为了能够让国外的网友能查询到这篇文章。平常在Google上查资料的时候,经常参考国外网友的博客,帮助我解决了很多问题,所以我也想让他们能够参考我写的内容。当然文中我不可能全部译为英文,所以我尽量把代码粘全,靠代码说话吧。
 
                     
                    
                 
                    
                


 
     
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号