#include <stdio.h>
#include <string.h>
#define N 10
int main()
{void input(int [],char name[][8]);
void sort(int [],char name[][8]);
void search(int ,int [],char name[][8]);
int num[N],number,flag=1,c;
char name[N][8];
input(num,name);
sort(num,name);
while (flag==1)
{ printf("\ninput number to look for:");
scanf("%d",&number);
search(number,num,name);
printf("continue ot not(Y/N)?");
getchar();
c=getchar();
if (c=='N'||c=='n')
flag=0;
}
return 0;
}
void input(int num[],char name[N][8])
{int i;
for (i=0;i<N;i++)
{printf("input NO.: ");
scanf("%d",&num[i]);
printf("input name: ");
getchar();
gets(name[i]);
}
}
void sort(int num[],char name[N][8])
{ int i,j,min,templ;
char temp2[8];
for (i=0;i<N-1;i++)
{min=i;
for (j=i;j<N;j++)
if (num[min]>num[j]) min=j;
templ=num[i];
strcpy(temp2,name[i]);
num[i]=num[min];
strcpy (name[i],name[min]);
num[min]=templ;
strcpy(name[min],temp2);
}
printf("\n result:\n");
for (i=0;i<N;i++)
printf("\n %5d%10s",num[i],name[i]);
}
void search(int n,int num[],char name[N][8])
{int top,bott,mid,loca,sign;
top=0;
bott=N-1;
loca=0;
sign=1;
if ((n<num[0])||(n>num[N-1]))
loca=-1;
while((sign==1) && (top<=bott))
{mid=(bott+top)/2;
if (n==num[mid])
{loca=mid;
printf("NO. %d , his name is %s.\n",n,name[loca]);
sign=-1;
}
else if (n<num[mid])
bott=mid-1;
else
top=mid+1;
}
if (sign==1 || loca==-1)
printf("%d not been found.\n",n);
}
[C语言课件]第7章-用函数实现模块化程序设计
120 浏览量
2023-09-26
19:51:45
上传
评论
收藏 7KB RAR 举报

深海大凤梨_
- 粉丝: 28
- 资源: 214
最新资源
- 网络建设与运维模拟器2
- 04-腾讯云ES在日志和搜索的场景化能力建设-腾讯云师文博-最终版 12.02 2023 Beijing
- 03-Vega 或 Vega-Lite二次开发 Kibana 接口可视化 12.02 2023 Beijing
- 02-Elasticsearch 索引优化-小红书刘显鹏 12.02 2023 Beijing
- HikariCP-5.1.0.jar
- 01-ES-QL for Community - Chinese 12.03 2023 Beijing
- 实验1-1.ms14
- 突发2fsk,通过卷积分析其中的起始时间
- ESETNOD32防病毒软件
- Scratch AI 赛车游戏:糟糕的赛车手
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈


