社区讨论

为什么log3N会比log2N慢呢

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

讨论操作

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

当前回复
10 条
当前快照
1 份
快照标识符
@lo7vcey4
此快照首次捕获于
2023/10/27 08:22
2 年前
此快照最后确认于
2023/10/27 08:22
2 年前
查看原帖
CPP
#include <bits/stdc++.h>
using namespace std;

const int N=1000100;
int n,m;
int a[N];

int main(){
	scanf("%d%d",&n,&m);
	for(int i=1;i<=n;i++)
		scanf("%d",&a[i]);
	for(int i=1;i<=m;i++){
		int x;
		scanf("%d",&x);
		int ll=1,rr=n;
		while(ll<rr){
			int mid1=ll+(rr-ll)/3;
			int mid2=ll+(rr-ll)/3*2;
			if(x<=a[mid1]){
				rr=mid1;
			}
			else if(x<=a[mid2]){
				ll=mid1+1,rr=mid2;
			}
			else{
				ll=mid2+1;
			}
		}
		if(a[ll]==x)
			printf("%d ",ll);
		else
			printf("%d ",-1);
	}
	return 0;
}
无聊写了个“三分查找”,然后失落地发现比传统的二分查找要慢,不是很理解。log3N为什么会比log2N慢呢

回复

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

正在加载回复...