• 职工信息中选择排序,折半查找的综合应用


    /* 
     Date: 07/03/19 19:27
     Description: 选择排序、折半查找、函数的综合应用
    */

    #include<stdio.h>

    #include<string.h>

    #define N 10

    //函数声明部分

    void input(int [],char name[][8]);
    void output(int [],char name[][8]);
    void sort(int [],char name[][8]);
    void search(int n,int [],char name[][8]);

    int main(void)
    {
       int num[N],number,flag=1,c;
       char name[N][8];
     
       input(num,name);//调用输入函数
       sort(num,name);//调用排序函数 
       output(num,name);//调用输出函数
       while(flag==1) 
       {
          printf(" input number to look for:");
          scanf("%d",&number);
          search(number,num,name);//调用折半查找函数
          printf("continue or not(Y/N)?");
          getchar();//吃掉scanf输入末尾的回车键
          c=getchar();
          if(c=='N'||c=='n')
          {
             flag=0;
          }
       }
       return 0;
    }
    void input(int num[],char name[][8])//输出信息函数
    {
       int i;
       for(i=0;i<N;i++)
       {
          printf("%d: input NO.:",i+1);
          scanf("%d",&num[i]);
          printf("input name:");
          getchar();//吃掉scanf输入末尾的回车键
          gets(name[i]);
       }
    }
    void output(int num[],char name[][8])//输出信息函数
    {
       int i;
       printf(" result: ");
       for(i=0;i<N;i++)
          printf(" %5d%10s",num[i],name[i]); 
    }
    void sort(int num[],char name[][8])//选择排序
    {
       int i,j,min,temp1;
       char temp2[8];
     
       for(int i=0;i<N;i++)
       {
          min=i;
          for(j=i;j<N;j++)
             if(num[min]>num[j])
                min=j;
          temp1=num[i];
          strcpy(temp2,name[i]);
          num[i]=num[min];
          strcpy(name[i],name[min]);
          num[min]=temp1;
          strcpy(name[min],temp2);
       }
    }
    void search(int n,int num[],char name[][8])//折半查找
    {
       int top,bott,mid,local,sign;
       top=0;bott=N-1;local=0;sign=1;
     
       if((n<num[0])||(n>num[N-1]))
          local=-1;
       while((sign==1) && (top<=bott))
       {
          mid=(top+bott)/2;
          if(n==num[mid])//查找到
          {
             local=mid;
             printf("NO. %d,his name is %s. ",n,name[local]);
             sign=-1;
          }
          else if(n<num[mid])//在前半部分
             bott=mid-1;
          else//在后半部分
             top=mid+1;
       } 
       if(sign==1||local==-1)//没找到
          printf("%d not been found. ",n);
    }

  • 相关阅读:
    [置顶] 宏途_LCD调试流程.
    字典树的数据结构及基本算法的实现
    uva 10714 Ants(贪心)
    paip.输入法编程---增加码表类型
    chomp方法
    ios 限制输入长度
    我所理解的设计模式(C++实现)——策略模式(Strategy Pattern)
    Android用户界面 UI组件--AdapterView及其子类(一) ListView及各种Adapter详解
    C#系列教程——switch定义及使用
    局域网内linux由ip反解析主机名
  • 原文地址:https://www.cnblogs.com/sinlearn/p/10492128.html
Copyright © 2020-2023  润新知