标题:现有两个一维整型有序数组合成一组。 解决求排在第N位(升序)的的数字,使 ...
取消只看楼主
人士online
Rank: 1
等 级:新手上路
帖 子:22
专家分:4
注 册:2010-8-21
结帖率:66.67%
已结贴  问题点数:10 回复次数:1 
现有两个一维整型有序数组合成一组。 解决求排在第N位(升序)的的数字,使用二分查找法求其在哪组
求该程序修改
#include <iostream>

using namespace std;

int  main()
{
    int a[10]={1,2,4,5,7,8,10,23,24,58},
        b[10]={1,3,5,7,9,10,11,12,13,14},
        c[30];

    int k=0,i=0,j=0;
    for( ; ; )
    {
        
        if(a[i]<b[j])
        {
            c[k]=a[i];
            k++;i++;
        }
        else
        {
            c[k]=b[j];
            k++;j++;
        }
        if(i==10|| j==10)
            break;

    }

    if(i==10)
        for(;j<10;j++)
        {
            c[k]=b[j];
            k++;
        }

   if(j==10)
      for(;i<10;i++)
        {
            c[k]=a[i];
            k++;
        }



  int n;

  cout<<"请输入一个整数n"<<endl;

    cin>>n;

  cout<<"n = "<<n<<endl;

    if(n<=k)
   
     cout<<"第n个数为 "<<c[n-1]<<endl;

int search(a[10],c[n-1],10)    ;     
   

   

return 0;   
}


int search(int a[],int &x,int n)
{
        int left=0;

           int right=n-1;
           
           if(x==a[left] || x==a[right])
               
               cout<<"该数在a组"<<endl;

     
           else
           {
             while(left<=right)
             {

             int middle=(left+right)/2;

             if (x==a[middle]) cout<<"该数在a组"<<endl;

             if (x>a[middle]) left=middle+1;

             else right=middle-1;
             }
           }
           return 0;
}
搜索更多相关主题的帖子: 序数 整型 求其 数字 
2010-10-10 23:47
人士online
Rank: 1
等 级:新手上路
帖 子:22
专家分:4
注 册:2010-8-21
得分:0 
回复 2楼 cacker
恩。。
我运用了,解决了调用的问题了。。。

thanks!!!!
2010-10-11 14:56



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-322510-1-1.html




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

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