憨憨39 2021-11-29 18:55 采纳率: 100%
浏览 36
已结题

请问我这个代码哪里错了,感激不尽

题目要求是写几个函数:
(1)输入几个职工的姓名和职工编号;
(2)按职工号由小到大顺序排序,姓名顺序也随之调整;
(3)要求输入一个职工号,用折半查找法找出该职工的姓名,从主函数输入要查找的职工号输出职工姓名。
#include<stdio.h>
#include<string.h>
int main()
{
void name(char a[5][100],int b[5]);
void sun(char a[5][100],int b[5]);
void seek(char a[5][100],int b[5],int x);
char a[5][100];
int b[5];
name(a,b);
sun(a,b);
int n;
printf("please enter seek data:");
scanf("%d",&n);
seek(a,b,n);
return 0;
}

void name(char a[5][100],int b[5])
{
int i;
for(i=0;i<5;i++)
{
printf("(%d)please enter name:",i);
gets(a[i]);
printf("(%d)please enter data:",i);
scanf("%d",&b[i]);
getchar();
}
}

void sun(char a[5][100],int b[5])
{
char x[100];
int t,i,j;
for(i=0;i<4;i++)
{
for(j=i+1;j<5;j++)
if(b[i]>b[j])
{
t=b[j];
b[j]=b[i];
b[i]=t;
strcpy(x,a[j]);
strcpy(a[j],a[i]);
strcpy(a[i],x);
}
}
for(i=0;i<5;i++)
printf("%s %d\n",a[i],b[i]);
}

void seek(char a[5][100],int b[5],int x)
{
int mid,left,right,flag=0;
left=0;
right=4;
while(b[left]<=b[right])
{
mid=(left+right)/2;
if(b[mid]==x)
{
flag=1;
break;
}
else if(x<b[mid])
right=mid-1;
else
left=mid+1;
}
if(flag==1)
printf("%s %d",a[mid][100],b[mid]);
else
printf("Don't seek:%d",x);
}

  • 写回答

1条回答 默认 最新

  • qzjhjxj 2021-12-06 11:16
    关注

    修改如下,供参考:

    #include<stdio.h>
    #include<string.h>
    int main()
    {
        void name(char a[5][100], int b[5]);
        void sun(char a[5][100], int b[5]);
        int  seek(char a[5][100], int b[5], int x);  //修改
        char a[5][100];
        int  b[5];
        name(a, b);
        sun(a, b);
        int n;
        printf("please enter seek data:");
        scanf("%d", &n);
        n = seek(a, b, n);  //修改
        if (n >= 0)
            printf("%s %d", a[n], b[n]);
        else
            printf("Don't seek");
        return 0;
    }
    
    void name(char a[5][100], int b[5])
    {
        int i;
        for (i = 0; i < 5; i++)
        {
            printf("(%d)please enter name:", i);
            gets(a[i]);
            printf("(%d)please enter data:", i);
            scanf("%d", &b[i]);
            getchar();
        }
    }
    
    void sun(char a[5][100], int b[5])
    {
        char x[100];
        int t, i, j;
        for (i = 0; i < 4; i++)
        {
            for (j = i + 1; j < 5; j++)
                if (b[i] > b[j])
                {
                    t = b[j];
                    b[j] = b[i];
                    b[i] = t;
                    strcpy(x, a[j]);
                    strcpy(a[j], a[i]);
                    strcpy(a[i], x);
                }
        }
        for (i = 0; i < 5; i++)
            printf("%s %d\n", a[i], b[i]);
    }
    
    int seek(char a[5][100], int b[5], int x)
    {
        int mid, left, right, flag = 0;
        left = 0;
        right = 4;
        while (b[left] <= b[right])
        {
            mid = (left + right) / 2;
            if (b[mid] == x)
            {
                flag = 1;
                break;
            }
            else if (x < b[mid])
                right = mid - 1;
            else
                left = mid + 1;
        }
        if (flag == 1)
            //printf("%s %d", a[mid], b[mid]);  //printf("%s %d", a[mid][100], b[mid]);
            return mid;
        else
            //printf("Don't seek:%d", x);
            return -1;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 12月16日
  • 已采纳回答 12月8日
  • 创建了问题 11月29日

悬赏问题

  • ¥20 给自己本科IT专业毕业的妹m找个实习工作
  • ¥15 用友U8:向一个无法连接的网络尝试了一个套接字操作,如何解决?
  • ¥30 我的代码按理说完成了模型的搭建、训练、验证测试等工作(标签-网络|关键词-变化检测)
  • ¥50 mac mini外接显示器 画质字体模糊
  • ¥15 TLS1.2协议通信解密
  • ¥40 图书信息管理系统程序编写
  • ¥20 Qcustomplot缩小曲线形状问题
  • ¥15 企业资源规划ERP沙盘模拟
  • ¥15 树莓派控制机械臂传输命令报错,显示摄像头不存在
  • ¥15 前端echarts坐标轴问题