社区讨论
为什么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 条回复,欢迎继续交流。
正在加载回复...