#include<stdio.h> int BinSearch(int r[],int n,int k) { int mid,low=0,high=n-1; while(low<=high) { mid=(low+high)/2; if(k<r[mid]) high=mid-1; else if(k>r[mid]) low=mid+1; else return mid+1; } return 0; } int main() { int n=9,k=22; int r[]={98,86,75,64,55,48,37,22,13}; int num; num=BinSearch(r,n,k); printf("%d",num); return 0; }
时间: 2024-04-06 18:33:53 浏览: 104
这段代码实现了一个二分查找算法。该算法的目的是在已排序的数组 r[] 中查找值为 k 的元素,若找到则返回其下标加一,否则返回 0。
具体实现过程为:首先将查找区间的下界 low 设为 0,上界 high 设为 n-1,表示待查找的区间为 [0,n-1]。然后在每次循环中,计算中间位置 mid,若 k 小于 r[mid],则说明待查找元素在区间 [low,mid-1] 中,将 high 更新为 mid-1;若 k 大于 r[mid],则说明待查找元素在区间 [mid+1,high] 中,将 low 更新为 mid+1;否则,即 k 等于 r[mid],则找到了该元素,返回其下标加一,即 mid+1。
最后,如果循环结束时仍未找到元素,则返回 0。
相关问题
#include <stdio.h> #include <algorithm> using namespace std; #define MAXN 200000 //问题表示 int a[MAXN]; int n,c; int BinSearch(int low,int high,int x) //在a[low..high]中查找x出现的次数 { while(low<=high) { int mid=(low+high)/2; if(a[mid]==x) //找到a[mid]=x:求左右为x的个数 { int count=1,i; i=mid-1; while(i>=low && a[i]==x) //在a[mid]左边找x的次数 { count++; i--; } i=mid+1; while(i<=high && a[i]==x) //在a[mid]右边找x的次数 { count++; i++; } return count; } else if(x>a[mid]) //x>a[mid]:在右区间中查找 low=mid+1; else //x<a[mid]:在左区间中查找 high=mid-1; } return 0; //没有查找返回0 } int main() { scanf("%d%d", &n, &c); for(int i=0;i<n;i++) scanf("%d",&a[i]); sort(a,a+n); //对数组a递增排序 int ans=0; for(int j=0;j<n-1;j++) ans+=BinSearch(j+1,n-1, ); printf( printf("%d\n",ans); return 0; }补齐代码
补齐的代码如下:
#include <stdio.h>
#include <algorithm>
using namespace std;
#define MAXN 200000 //问题表示
int a[MAXN];
int n,c;
int BinSearch(int low,int high,int x) //在a[low..high]中查找x出现的次数
{
while(low<=high)
{
int mid=(low+high)/2;
if(a[mid]==x) //找到a[mid]=x:求左右为x的个数
{
int count=1,i;
i=mid-1;
while(i>=low && a[i]==x) //在a[mid]左边找x的次数
{
count++;
i--;
}
i=mid+1;
while(i<=high && a[i]==x) //在a[mid]右边找x的次数
{
count++;
i++;
}
return count;
}
else if(x>a[mid]) //x>a[mid]:在右区间中查找
low=mid+1;
else //x<a[mid]:在左区间中查找
high=mid-1;
}
return 0; //没有查找返回0
}
int main()
{
scanf("%d%d", &n, &c);
for(int i=0;i<n;i++)
scanf("%d",&a[i]);
sort(a,a+n); //对数组a递增排序
int ans=0;
for(int j=0;j<n-1;j++)
ans+=BinSearch(j+1,n-1,a[j]+c);
printf("%d\n",ans);
return 0;
}
#include <stdio.h> #include <algorithm> using namespace std; #define MAXN 200000 //问题表示 int a[MAXN]; int n,c; int BinSearch(int low,int high,int x) //在a[low..high]中查找x出现的次数 { while(low<=high) { int mid=(low+high)/2; if(a[mid]==x) //找到a[mid]=x:求左右为x的个数 { int count=1,i; i=mid-1; while(i>=low && a[i]==x) //在a[mid]左边找x的次数 { count++; i--; } i=mid+1; while(i<=high && a[i]==x) //在a[mid]右边找x的次数 { count++; i++; } return count; } else if(x>a[mid]) //x>a[mid]:在右区间中查找 low=mid+1; else //x<a[mid]:在左区间中查找 high=mid-1; } return 0; //没有查找返回0 } int main() { scanf("%d%d", &n, &c); for(int i=0;i<n;i++) scanf("%d",&a[i]); sort(a,a+n); //对数组a递增排序 int ans=0; for(int j=0;j<n-1;j++) ans+=BinSearch(j+1,n-1,a[j]+c); printf("%d\n",ans); return 0; }该实验应该在编译器里输入什么运行结果?
这个程序的功能是读入一个长度为n的整数数组a,然后对其进行排序,最后查找数组中有多少对元素之差等于常数c。
你应该在编译器里输入整数n和c,以及n个整数作为数组a的元素,然后运行程序。程序会输出数组中有多少对元素之差等于常数c。
例如,如果输入以下内容:
```
5 2
1 5 3 4 2
```
则程序会输出:
```
3
```
这是因为数组中有三对元素之差等于2,它们是(1,3)、(3,5)和(2,4)。
阅读全文