zoukankan
html css js c++ java
职工信息中选择排序,折半查找的综合应用
/*
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);
}
查看全文
相关阅读:
备忘:java在cmd中编译运行
Java基础学习 —— 对象的克隆
将博客搬至CSDN
jenkins节点管理中没有默认没有Launch agent via Java Web Start
postman 集成ci
postman初级使用
jmeter分布式压测实践及踩坑记录(linux压力机)
jmeter监控服务器cpu、内存等
jmeter跨线程组传递token实践
初识jmeter
原文地址:https://www.cnblogs.com/sinlearn/p/10492128.html
最新文章
jdk8中map新增的merge方法介绍
基于Redis实现分布式锁
java中多线程产生死锁的原因以及解决意见
Mybatis中$和#取数据的区别
mongodb java操作常用写法
微信公众号开发上传图文素材带有卡片小程序报错:errcode=45166,errmsg = invalid content hint
java中Class.getMethods()和Class.getDeclaredMethods()的区别
RabbitMQ学习第四记:路由模式(direct)
Angular 组件之间的传值
Angular广播/消息通知的接收与发送
热门文章
BootStrap Select2组件
百度地图(多点定位+聚合)
Swiper插件轮播
高德地图定位
胶囊式菜单
JS中的逻辑运算符&&、||,位运算符|,&
calc() 计算CSS属性值
css 超出规定行数自动隐藏
dom4j读取xml
备忘:Junit单元测试
Copyright © 2011-2022 走看看