社区讨论

0分。。求助一下大佬,谢谢

P2249【深基13.例1】查找参与者 1已保存回复 1

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
1 条
当前快照
1 份
快照标识符
@lumpiffu
此快照首次捕获于
2024/04/05 21:33
2 年前
此快照最后确认于
2024/04/06 02:39
2 年前
查看原帖
CPP
#include<iostream>
#include<algorithm>
#include<cstring>

using namespace std;

int n,m;
int a[100010];
int q;

bool isBlue( int num, int x ) {
	if( num<x ) {
		return true;
	}
	else{
		return false;
	}
}
//二分查找
int bin_search( int a[], int x ) {
	int l=0,r=n+1;
	while(l+1!=r) {
		int mid=(l+r)/2;
		if(isBlue(a[mid],x)) {
			l=mid;
		}
		else{
			r=mid;
		}
	}
	if( a[r]==x ) {
		return r;
	}
	else{
		return -1;
	}
}

int main()
{
	scanf("%d %d",&n,&m);
	for( int i=1; i<=n; i++ ) {
		scanf("%d",&a[i]);
	} 
	while(m--) {
		scanf("%d",&q);
		int res=bin_search(a,q);
		printf("%d ",res);
	}
	return 0;
}

回复

1 条回复,欢迎继续交流。

正在加载回复...