zoukankan      html  css  js  c++  java
  • 实践6.4

    二分法查找(选择排序)

    源程序:

    #include <stdio.h>
    #define MaxSize 8
    typedef struct
    {
    int stuno;
    char stuname[20];
    }TableElem;

    TableElem stu[]={{1009,"wang"},{4400,"ren"},{1001,"zhang"},
    {4003,"qin"},{2005,"sun"},{2008,"liu"},{3001,"zheng"},{3005,"lai"}};

    typedef struct
    {
    TableElem elem[MaxSize];
    int n;
    }SqTable;

    //二分查找函数
    int bin_search(SqTable *T,int key)
    {
    int low,high,mid;
    low=1;
    high=MaxSize;

    while(low<=high)
    {
    mid=(low+high)/2;
    if(T->elem[mid].stuno==key)
    return mid;
    else if(key<T->elem[mid].stuno)
    high=mid-1;
    else
    low=mid+1;
    }
    return 0;
    }
    /*
    int searchsqtable(SqTable T,int key) //查找函数
    {
    T.elem[0].stuno=key;
    int i=T.n;
    while(T.elem[i].stuno!=key)
    i--;
    return i;
    }
    */
    //选择排序
    void select_sort(SqTable *T,int nn)
    {
    int min,i,j;
    TableElem temp;
    for(i=0;i<nn;i++)
    {
    min=i;
    for(j=i+1;j<nn;j++)
    {
    if(T->elem[j].stuno<T->elem[min].stuno)
    min=j;
    }
    if(min!=j)
    {
    temp=T->elem[min];
    T->elem[min]=T->elem[i];
    T->elem[i]=temp;
    }
    }
    }
    int main()
    {
    SqTable seq;
    for(int i=0;i<MaxSize;i++)
    {
    seq.elem[i]=stu[i]; //用stu[8]8个人初始化elem[8]数组
    }
    seq.n=MaxSize;
    //8个人按学号排序
    int n=MaxSize;
    select_sort(&seq,n);

    for(i=0;i<MaxSize;i++)
    printf("%d %s ",seq.elem[i].stuno,seq.elem[i].stuname);

    int kk,mm;

    //for(i=0;i<MaxSize;i++)
    //{
    //seq1.elem[i]=seq.elem[i]; //用stu[8]8个人初始化elem[8]数组
    //}

    printf("请输入要查找的学号:");
    scanf("%d",&kk);
    mm=bin_search(&seq,kk); //调用查找函数
    printf("此人在顺序表中的位置是:%d ",mm+1);
    printf("%d号的姓名为:%s ",mm+1,seq.elem[mm].stuname);
    return 1;
    }

    运行结果:

  • 相关阅读:
    学习进度条
    学期总结
    实验四主存空间的分配和回收
    学术诚信与职业道德
    《构建之法》第8,9,10章 读后感
    实验三 进程调度模拟程序
    团队项目:学习四则运算,团队准备 3.0
    团队项目:学习四则运算,团队准备 2.0
    "数学口袋精灵"bug(团队)
    实验二作业调度模拟程序
  • 原文地址:https://www.cnblogs.com/duanqibo/p/13345609.html
Copyright © 2011-2022 走看看