| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 8840 人关注过本帖
标题:求一个C程算法——折半查找法
只看楼主 加入收藏
学C中
Rank: 1
等 级:新手上路
帖 子:68
专家分:0
注 册:2005-10-30
收藏
得分:0 
3楼?要排序咩?直接找都比你快啦!哈哈......

2006-05-24 07:37
论坛
Rank: 3Rank: 3
等 级:新手上路
威 望:6
帖 子:1372
专家分:0
注 册:2006-3-27
收藏
得分:0 
以下是引用学C中在2006-5-24 7:37:00的发言:
3楼?要排序咩?直接找都比你快啦!哈哈......

你到底懂不懂,不懂不要乱发言,用折半查找你写个程序,我输入数据,你给我找出来我看看


日出东方,唯我不败! 做任何东西都是耐得住寂寞,任何一个行业要有十年以上的积累才能成为专家
2006-05-24 10:26
xsimon
Rank: 1
等 级:新手上路
帖 子:121
专家分:0
注 册:2006-5-5
收藏
得分:0 
楼上的, 11楼大概是说用眼睛看就好了.
2006-05-24 17:24
独角龙
Rank: 1
等 级:新手上路
帖 子:221
专家分:0
注 册:2006-5-5
收藏
得分:0 

#include <stdio.h>
#define N 10

int binary_search(int a[], int key, int left, int right);//二分查找(折半查找)
void bubble_sort(int a[]);//从小到大排序

int main(void)
{
int i, key, a[] = {74, 5, 45, 2, 21, 6, 7, 8, 15, 10};

printf("Enter search number:\n");
scanf("%d", &key);
bubble_sort(a);
i = binary_search(a, key, 0, N - 1);

printf("i = %d\n", i);

return 0;
}

int binary_search(int a[], int key, int left, int right)
{
int mid;
mid = (left + right) / 2;

if (left > right)
return -1;
else if (left <= right)
{
if (a[mid] == key)
return mid;
else if (a[mid] > key)
binary_search(a, key, left, mid - 1);
else if (a[mid] < key)
binary_search(a, key, mid + 1, right);
}
}

void bubble_sort(int a[])
{
int i, j, temp;

for (i = 0; i < N - 1; i++)
for ( j = 0; j < N - 1 - i; j++)
{
if (a[j] > a[j + 1])
{
temp = a[j];
a[j] = a[j + 1];
a[j + 1] = temp;
}
}
}


奋斗改变一切!!
2006-05-24 18:18
hyln
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2006-5-25
收藏
得分:0 
[分享]

上一楼的程序我觉得应该在加一个int b[] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
来记录a[] = {74, 5, 45, 2, 21, 6, 7, 8, 15, 10}中数值的初始位置,这样好
象更合理一些,不知各位大侠意见如何?

2006-05-25 11:07
mechanics
Rank: 1
等 级:新手上路
帖 子:87
专家分:0
注 册:2006-5-16
收藏
得分:0 

2006-05-25 11:41
soft_wind
Rank: 3Rank: 3
等 级:新手上路
威 望:8
帖 子:1430
专家分:0
注 册:2006-4-5
收藏
得分:0 
楼上的仍美中不足,经过您这样的排序之后数组的位置变了,
用结构体,
struct
{
int pos;  /*标记数的位置*/
int num;
};
这样才好,排序后也可以从pos变量中得出是数组的哪个位置。

对不礼貌的女生收钱......
2006-05-26 14:44
djx20040701
Rank: 1
等 级:新手上路
帖 子:44
专家分:0
注 册:2006-4-20
收藏
得分:0 

楼上的回答的很好,利用结构体的思想,对数据和位置保持一致,

2006-05-26 15:29
dw_4
Rank: 1
等 级:新手上路
帖 子:44
专家分:0
注 册:2006-5-26
收藏
得分:0 
应该是直接找就行了吧。排序就把数组走了好多遍了,太浪费了哦!

2006-05-26 15:50
独角龙
Rank: 1
等 级:新手上路
帖 子:221
专家分:0
注 册:2006-5-5
收藏
得分:0 
楼上的能给写个吗
我结构体用的不怎么好!!

奋斗改变一切!!
2006-05-27 11:23
快速回复:求一个C程算法——折半查找法
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.014494 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved