QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#469130 | #8565. Basic Blooms | PhantomThreshold# | WA | 928ms | 35316kb | C++17 | 2.0kb | 2024-07-09 14:43:35 | 2024-07-09 14:43:35 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef double db;
const db eps=1e-12;
const ll mod=998244353;
ll ksm(ll a,ll x){
ll ret=1;
for (;x;x>>=1,a=a*a%mod) if (x&1) ret=ret*a%mod;
return ret;
}
ll inv(ll a){return ksm(a,mod-2);}
ll poww(ll a,ll x){
ll ret=1;
for (;x;x>>=1,a=a*a) if (x&1) ret=ret*a;
return ret;
}
db _lg[150];
db calc(ll x,ll B,ll k){
db ans=_lg[x]-_lg[B-1]+k*_lg[B];
for (int i=1;i<=60;i++){
db tmp=pow((db)1.0/B,i*k)/i;
ans=ans-tmp;
if (tmp<eps) break;
}
return ans;
}
ll get_realv(ll x,ll B,ll k){
ll ans=x*(poww(B,k)-1)/(B-1);
return ans;
}
ll get_v(tuple<ll,ll,ll> num1){
auto [x,B,k]=num1;
ll ans=x*(ksm(B,k)+mod-1)%mod*inv(B-1)%mod;
return ans;
}
bool cmp(tuple<ll,ll,ll> num1,tuple<ll,ll,ll> num2){
auto [x,B,k]=num1;
auto [y,C,m]=num2;
db res1=calc(x,B,k);
db res2=calc(y,C,m);
if (res1<40 && res2<40){
ll v1=get_realv(x,B,k);
ll v2=get_realv(y,C,m);
return v1<v2;
}
return res1+eps<res2;
}
tuple<ll,ll,ll> get_next(tuple<ll,ll,ll> num){
auto [x,B,k]=num;
if (x<B-1) return make_tuple(x+1,B,k);
return make_tuple(1,B,k+1);
}
vector<tuple<ll,ll,ll>> a;
vector<ll> sum;
void prepare(){
for (int i=1;i<=30;i++) _lg[i]=log((db)i);
a.emplace_back(0LL,0LL,0LL);
vector<tuple<ll,ll,ll>> tp(17);
for (ll B=2;B<=16;B++){
tp[B]=make_tuple(1LL,B,1LL);
}
for (;a.size()<1'000'001;){
ll now=2;
for (ll B=3;B<=16;B++) if (cmp(tp[B],tp[now])) now=B;
if (cmp(a.back(),tp[now])){
a.push_back(tp[now]);
}
tp[now]=get_next(tp[now]);
}
int sz=a.size();
sum.resize(sz);
for (int i=1;i<sz;i++){
sum[i]=(sum[i-1]+get_v(a[i]))%mod;
}
// for (int i=1;i<=1000;i++){
// cout << get_realv(get<0>(a[i]),get<1>(a[i]),get<2>(a[i])) << " ";
// }
// cout << endl;
}
int main(){
ios_base::sync_with_stdio(false);
prepare();
cin.tie(0);
int Tcase=1;
cin >> Tcase;
for (;Tcase--;){
int l=15,r=2000;
cin >> l >> r;
cout << (sum[r]-sum[l-1]+mod)%mod << "\n";
}
return 0;
}
詳細信息
Test #1:
score: 100
Accepted
time: 743ms
memory: 34512kb
input:
3 1 2 1 10 15 2000
output:
3 55 736374621
result:
ok 3 number(s): "3 55 736374621"
Test #2:
score: 0
Accepted
time: 756ms
memory: 34576kb
input:
100000 26 99975 57 99944 28 99973 62 99939 71 99930 25 99976 53 99948 60 99941 73 99928 72 99929 30 99971 7 99994 3 99998 35 99966 73 99928 68 99933 83 99918 37 99964 63 99938 17 99984 34 99967 74 99927 6 99995 3 99998 23 99978 91 99910 39 99962 85 99916 82 99919 17 99984 61 99940 31 99970 44 99957 ...
output:
957904590 358359691 31524403 519690359 208321031 477204717 835715447 186583689 847423322 760952087 25753603 241428916 832623523 232679133 847423322 11425904 640652773 663756612 767901835 356898792 503593019 495288401 265039242 832623523 793754988 389398856 758928836 349243444 158978749 356898792 873...
result:
ok 100000 numbers
Test #3:
score: -100
Wrong Answer
time: 928ms
memory: 35316kb
input:
1000000 561662 731870 560627 798415 497930 613164 210084 556894 479283 902738 271881 288854 467622 971733 55854 157477 310152 415183 146385 874852 140599 526659 438420 629148 733746 924626 84146 436790 275793 457537 466464 541539 661070 696519 534866 688272 190259 412401 206392 354525 2344 217676 51...
output:
387682849 91353801 759238022 175113502 413046722 488887729 399797806 359127675 954541571 861295551 254074751 589282709 970062033 298821716 593042756 268635027 495659009 878948937 741148909 716887807 31798813 425888650 765930054 831198164 372500280 694558761 918178838 919393601 344732693 134966024 37...
result:
wrong answer 5th numbers differ - expected: '143631299', found: '413046722'