| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1326 人关注过本帖
标题:c++简单程序
只看楼主 加入收藏
xxjjkk
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2011-12-18
结帖率:100%
收藏
 问题点数:0 回复次数:8 
c++简单程序
#include <iostream>

using namespace std;

const int size = 10;

void search(const int a[],int first,int last,int key,bool& found,int& laction);

int main()

{
   
    int n;
   
    int a[size];
   
    int first;
   
    int last;
   
    int laction;
   
    bool found;
   
    int key;
   
    for(n=0;n<size;n++)
        
    {
        
        a[n]=n+1;
        
        cout<<a[n]<<"  ";
        
    }
   
    cout<<endl;
   
   
   
   
   
    last=size-1;
   
    cin>>key;
   
    search(a,0,last,key,found,laction);
   
    if(found)
        
        cout<<key<<"laction is :"<<laction<<endl;
   
    else
        
        cout<<key<<"is not laction"<<endl;
   
   
   
    return 0;
   
}



void search(const int a[],int first,int last,int key,bool& found,int& laction)

{
   
    int mid;
   
    if(first > last)
        
        found = false;
   
    else
        
    {
        
        mid=(first + last)/2;
        
        if(key = a[mid])
            
        {
            
            found=true;
            
            laction=mid;
            
        }
        
        else if (key > a[mid])
            
            search(a,mid+1,last,key,found,laction);
        
        else if(key < a[mid])
            
            search(a,first,mid-1,key,found,laction);
        
    }
   
}
这个是递归的二分法,我的输出总是4,求解决。。。
搜索更多相关主题的帖子: include search 
2011-12-20 15:42
hellovfp
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:禁止访问
威 望:30
帖 子:2976
专家分:7697
注 册:2009-7-21
收藏
得分:0 
if(key = a[mid]) ? if( key == a[mid] )

我们都在路上。。。。。
2011-12-21 11:26
chenbjin
Rank: 2
等 级:论坛游民
帖 子:14
专家分:13
注 册:2011-12-22
收藏
得分:0 
同上!
2012-01-06 23:08
韦德隆东墙
Rank: 1
等 级:新手上路
帖 子:5
专家分:7
注 册:2011-12-24
收藏
得分:0 
不能都用int型
2012-01-11 20:25
Tlife
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2011-9-3
收藏
得分:0 
if(key = a[mid])  这句话错了 等号是 ==
我修改以后运行了一遍没问题
2012-01-14 15:25
CooperOne
Rank: 2
来 自:珠海
等 级:论坛游民
帖 子:40
专家分:48
注 册:2012-1-25
收藏
得分:0 
同上,一个等号是赋值,两个等号是判断

蹲得越低,跳得越高.
2012-01-25 21:19
lucky563591
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:4
帖 子:765
专家分:2103
注 册:2009-11-18
收藏
得分:0 
赋值和判断不同
2012-01-29 09:35
pys92726
Rank: 1
等 级:新手上路
帖 子:3
专家分:1
注 册:2012-1-29
收藏
得分:0 
这个是基础啊 - -  
2012-01-29 13:18
aduxuefei
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2011-12-12
收藏
得分:0 
回复 楼主 xxjjkk
#include<iostream>
#define N 10
using namespace std;
int main()
{
    int a[N],front,end,mid,x,i;
    cout<<"输入已排好序的a数组元素:"<<endl;
    for(i=0;i<N;i++)
     {a[i]=i+1;
    cout<<a[i]<<" ";
     }cin>>x;
    front=0;
    end=N-1;
    mid=(front+end)/2;
    while(front<end&&a[mid]!=x)
    {
        if(a[mid]<x)front=mid+1;
        if(a[mid]>x)end=mid-1;
        mid=front + (end - front)/2;
    }
    if(a[mid]!=x)
    cout<<"没找到!"<<endl;
    else
    cout<<"找到了!在第"<<mid+1<<"项里。"<<endl;
    return 0;
}
2012-02-03 16:21
快速回复:c++简单程序
数据加载中...
 
   



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

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