| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 747 人关注过本帖
标题:这是循环体出问题了吗?折半二分法
只看楼主 加入收藏
DJY774692667
Rank: 1
等 级:新手上路
帖 子:21
专家分:7
注 册:2015-7-14
结帖率:90%
收藏
已结贴  问题点数:18 回复次数:2 
这是循环体出问题了吗?折半二分法
#include<stdio.h>
#include<stdlib.h>
int main()
{
    void f(int *p,int k,int n);
    int n,i,s,k;
    int *a;
printf("intput :");
scanf("%d",&n);
a=(int*)calloc(n,sizeof(int));
for(i=0,s=0;i<n;i++)
{
    scanf("%d",&a[i]);
    if(a[i]<=s)
        printf("该数列不是升序序列,请重新输入");
   
    else
    s=a[i];
        
    }
printf("您要查找的数是:");
    scanf("%d",&k);
f(a,k,n);
}
void f(int *p,int k,int n)
{
    int i,j,c,low,high,mid;
for(i=0,j=n-1;i<=j;)
{
c=(i+j)/2;
    low=p[i];
    high=p[j];
    mid=p[c];
    if(mid==k)
    {
        printf("您要找的数是%d个",c+1);
    break;
    }
    if(mid<k)
        i=c+1;
     if(mid>k)
        j=c-1;
    if(i=j&&p[i]!=k)
    {
printf("没有你要找的数");
break;
    }
}
}


2015-12-13 19:24
ms268el8
Rank: 4
等 级:业余侠客
威 望:1
帖 子:84
专家分:299
注 册:2015-11-30
收藏
得分:18 
if(i==j&&p[i]!=k)
2015-12-13 20:12
DJY774692667
Rank: 1
等 级:新手上路
帖 子:21
专家分:7
注 册:2015-7-14
收藏
得分:0 
回复 2楼 ms268el8
谢谢
2015-12-15 09:45
快速回复:这是循环体出问题了吗?折半二分法
数据加载中...
 
   



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

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