| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 518 人关注过本帖
标题:高手帮忙
只看楼主 加入收藏
zhuyuanronaldo
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2007-11-29
收藏
 问题点数:0 回复次数:2 
高手帮忙
[bo]题目:[/bo]用递归算法实现折半查找问题。
数据输入:
第一行:测试集合个数m。
第二行:第一个测试用例测试数据的个数n。
第三行:第一个测试用例的要查找的s值。
第四行:第一个测试用例的n个测试数据。
第五行:第二个测试用例测试数据的个数n。
第六行:第二个测试用例的s值。
第七行:第二个测试用例的n个测试数据。
………
第2m行:第m个测试用例测试数据的个数n。
第2m+1行:第m个测试用例的s值。
第2m+2行:第m个测试用例的n个测试数据。
数据输出:
第一行到第m行:分别输出是否成功,如果能查到,则输出查到的位置,否则输出0。
示例:
输入文件input14.txt:
2
5
3
2 3 5 9 11
5
4
2 3 5 9 11
输出:(标准输出)
2
0
[bo]我的程序:[/bo]
#include<stdio.h>
#include<malloc.h>
int serch_bin(int s,int *p,int low,int high)//递归折半查找函数
{
    int mid;
    while(low<=high)
    {
        mid=(low+high)/2;
        if(s==*(p+mid)) return mid+1;
        else if(s>*(p+mid)) serch_bin(s,p,mid+1,high);
        else serch_bin(s,p,low,mid-1);
    }
    return 0;
}
int main()
{
    int m,n,s;
    int *p,*q;
    int i,j;
    printf("请输入测试集合个数:");
    scanf("%d",&m);
    q=(int *)malloc(sizeof(int)*m);
    for(i=1;i<=m;i++)
    {
        printf("请输入第%d个测试用例测试数据的个数:",i);
        scanf("%d",&n);
        printf("请输入第%d个测试用例的要查找的s值:",i);
        scanf("%d",&s);
        printf("请输入第%d个测试用例的n个测试数据:",i);
        p=(int *)malloc(sizeof(int)*n);
        for(j=0;j<n;j++)
            scanf("%d",p[j]);
        q[i-1]=serch_bin(s,p,0,n-1);
        free(p);
    }
    for(i=0;i<m;i++)
        printf("%d\n",q[i]);
}
看看哪错了
搜索更多相关主题的帖子: 五行 
2008-03-23 11:58
zm1986
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2008-3-16
收藏
得分:0 
#include<stdio.h>
#include<malloc.h>
int serch_bin(int s,int *p,int low,int high)//递归折半查找函数
{
    int mid;
    while(low<=high)
    {
        mid=(low+high)/2;
        if(s==*(p+mid)) return mid+1;
        else if(s>*(p+mid)) return serch_bin(s,p,mid+1,high);
        else return serch_bin(s,p,low,mid-1);
    }
    return 0;
}
int main()
{
    int m,n,s;
    int *p,*q;
    int i,j;
    printf("请输入测试集合个数:");
    scanf("%d",&m);
    q=(int *)malloc(sizeof(int)*m);
    for(i=1;i<=m;i++)
    {
        printf("请输入第%d个测试用例测试数据的个数:",i);
        scanf("%d",&n);
        printf("请输入第%d个测试用例的要查找的s值:",i);
        scanf("%d",&s);
        printf("请输入第%d个测试用例的n个测试数据:",i);
        p=(int *)malloc(sizeof(int)*n);
        for(j=0;j<n;j++)
            scanf("%d",&p[j]);
        q[i-1]=serch_bin(s,p,0,n-1);
        free(p);
    }
    for(i=0;i<m;i++)
        printf("%d\n",q[i]);
}
输入时应放数组的地址,“scanf("%d",&p[j]);”
还有递归之后要将得到的数据返回
2008-03-23 13:25
zhuyuanronaldo
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2007-11-29
收藏
得分:0 
谢了
2008-03-23 19:22
快速回复:高手帮忙
数据加载中...
 
   



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

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