QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#21626 | #2848. 城市地铁规划 | ha114514ha# | WA | 23ms | 78240kb | C++20 | 3.9kb | 2022-03-07 17:04:26 | 2022-05-08 03:43:55 |
Judging History
answer
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<string.h>
#include<queue>
#include<vector>
#include<map>
#include<bitset>
#include<set>
#include<cmath>
#include<ctime>
#include<random>
#define vi vector<int>
#define pb push_back
#define fi first
#define se second
#define mp make_pair
#define bc(x) __builtin_popcount(x)
#define re register
#define il inline
#define pii pair<int,int>
#define pil pair<int,long long>
#define pll pair<long long,long long>
#define mem0(x) memset(x,0,sizeof(x))
#define mem0x3f(x) memset(x,0x3f,sizeof(x))
#define dbg(x) cerr<<"In Line "<< __LINE__<<" the "<<#x<<" = "<<x<<'\n';
// #pragma GCC optimize(3)
#define int long long
typedef long long ll;
typedef unsigned long long ull;
using namespace std;
namespace IO_BUFF{
mt19937 rnd(time(0)^(ll)(new char));
int rend(int x){
return rnd()%x+1;
}
void rendom_shuffle(int *a,int len){
shuffle(a+1,a+len+1,rnd);
}
const int BS=(1<<24)+5;char Buffer[BS],*HD,*TL;
inline int gc(){
if(HD==TL) TL=(HD=Buffer)+fread(Buffer,1,BS,stdin);
return (HD==TL)?EOF:*HD++;
}
inline int inn(){
int x,ch,s=1;while((ch=gc())<'0'||ch>'9')if(ch=='-')s=-1;x=ch^'0';
while((ch=gc())>='0'&&ch<='9') x=(x<<1)+(x<<3)+(ch^'0');return x*s;
}
char ssss[19999999],tttt[20];int ssl,ttl;
inline int print(int x)
{
if(x<0)ssss[++ssl]='-',x=(-x);
if(!x) ssss[++ssl]='0';for(ttl=0;x;x/=10) tttt[++ttl]=char(x%10+'0');
for(;ttl;ttl--) ssss[++ssl]=tttt[ttl];return ssss[++ssl]='\n';
}
inline int Flush(){return fwrite(ssss+1,sizeof(char),ssl,stdout),ssl=0,0;}
int read(){
char c=getchar();int x=1;int s=0;
while(c<'0' || c>'9'){if(c=='-')x=-1;c=getchar();}
while(c>='0' && c<='9'){
s=s*10+c-'0';c=getchar();
}
return s*x;
}
}using namespace IO_BUFF;
/*namespace CFConTest{
const int mod=998244353;
inline int add(const int &x,const int &y){
return (x+y>=mod?x+y-mod:x+y);
}
inline int del(const int &x,const int &y){
return (x-y<0?x-y+mod:x-y);
}
int ksm(int x,int k){
int base=1;
while(k){
if(k&1)base=1ll*base*x%mod;
k>>=1;
x=1ll*x*x%mod;
}
return base;
}
};
using namespace CFConTest;*/
const int N=3050;
const int mod=59393;
int n,m,a[N],h[N];
int f[N][N],g[N]; // in i have chose k
int s[N],c[N];
int st[N],top;
vector<pii> pruefer_decode(vector<int> const& code) {
int n = code.size() + 2;
vector<int> degree(n, 1);
for (int i : code) degree[i]++;
set<int> leaves;
for (int i = 0; i < n; i++)
if (degree[i] == 1) leaves.insert(i);
vector<pair<int, int>> edges;
for (int v : code) {
int leaf = *leaves.begin();
leaves.erase(leaves.begin());
edges.emplace_back(leaf, v);
if (--degree[v] == 1) leaves.insert(v);
}
edges.emplace_back(*leaves.begin(), n - 1);
return edges;
}
signed main(){
#ifdef newbiewzs
freopen("data.in","r",stdin);
#else
#endif
n=read();m=read();
// n=3000;m=0;
for(int i=0;i<=m;i++){
a[i]=read();
}
for(int i=1;i<=n;i++){
int pre=1;
for(int k=0;k<=m;k++){
h[i]=(h[i]+a[k]*pre)%mod;
pre=pre*i%mod;
}
}
memset(f,-10,sizeof(f));
f[1][1]=h[2]-h[1];
for(int i=1;i<=n-2;i++){
for(int j=1;j<=i-1;j++){
if(f[i-1][j]+h[2]-h[1]>f[i][1]){
g[i]=j;
}
f[i][1]=max(f[i][1],f[i-1][j]+h[2]-h[1]);
}
for(int k=1;k<=i;k++){
if(k>1)f[i][k]=max(f[i][k],f[i-1][k-1]+h[k+1]-h[k]);
}
}
int ans=-1e9;
int las=0;
for(int i=1;i<=n;i++){
if(f[n-2][i]>ans){
las=i;
}
ans=max(ans,f[n-2][i]);
}
ans+=h[1]*n;
cout<<n-1<<" "<<ans<<'\n';
int u=n-2;
while(1){
u=u-las+1;
st[++top]=las;
las=g[u];
u--;
if(!las)break;
}
vi tmp;
for(int i=1;i<=top;i++){
for(int k=1;k<=st[i];k++)tmp.pb(i-1);
}
auto kel=pruefer_decode(tmp);
for(auto k:kel){
cout<<k.fi+1<<" "<<k.se+1<<'\n';
}
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 11ms
memory: 77608kb
input:
63 7 4 50 14 48 33 13 44 24
output:
62 992106 32 1 1 2 33 2 2 3 34 3 3 4 35 4 4 5 36 5 5 6 37 6 6 7 38 7 7 8 39 8 8 9 40 9 9 10 41 10 10 11 42 11 11 12 43 12 12 13 44 13 13 14 45 14 14 15 46 15 15 16 47 16 16 17 48 17 17 18 49 18 18 19 50 19 19 20 51 20 20 21 52 21 21 22 53 22 22 23 54 23 23 24 55 24 24 25 56 25 25 26 57 26 26 27 58 2...
result:
ok
Test #2:
score: 0
Accepted
time: 7ms
memory: 78216kb
input:
208 7 23 28 14 16 46 28 26 28
output:
207 3317121 104 1 105 1 1 2 106 2 2 3 107 3 3 4 108 4 4 5 109 5 5 6 110 6 6 7 111 7 7 8 112 8 8 9 113 9 9 10 114 10 10 11 115 11 11 12 116 12 12 13 117 13 13 14 118 14 14 15 119 15 15 16 120 16 16 17 121 17 17 18 122 18 18 19 123 19 19 20 124 20 20 21 125 21 21 22 126 22 22 23 127 23 23 24 128 24 24...
result:
ok
Test #3:
score: 0
Accepted
time: 23ms
memory: 77308kb
input:
2928 3 27 20 7 29
output:
2927 13889888 267 1 268 1 269 1 270 1 271 1 272 1 273 1 274 1 275 1 276 1 277 1 1 2 278 2 279 2 280 2 281 2 282 2 283 2 284 2 285 2 286 2 287 2 2 3 288 3 289 3 290 3 291 3 292 3 293 3 294 3 295 3 296 3 297 3 3 4 298 4 299 4 300 4 301 4 302 4 303 4 304 4 305 4 306 4 307 4 4 5 308 5 309 5 310 5 311 5 ...
result:
ok
Test #4:
score: 0
Accepted
time: 23ms
memory: 77796kb
input:
320 3 46 42 15 15
output:
319 1260206 24 1 25 1 26 1 27 1 28 1 29 1 30 1 31 1 32 1 33 1 1 2 34 2 35 2 36 2 37 2 38 2 39 2 40 2 41 2 42 2 43 2 44 2 45 2 46 2 2 3 47 3 48 3 49 3 50 3 51 3 52 3 53 3 54 3 55 3 56 3 57 3 58 3 59 3 3 4 60 4 61 4 62 4 63 4 64 4 65 4 66 4 67 4 68 4 69 4 70 4 71 4 72 4 4 5 73 5 74 5 75 5 76 5 77 5 78...
result:
ok
Test #5:
score: 0
Accepted
time: 8ms
memory: 77624kb
input:
380 5 41 27 8 3 31 0
output:
379 3140470 77 1 78 1 79 1 1 2 80 2 81 2 82 2 83 2 2 3 84 3 85 3 86 3 87 3 3 4 88 4 89 4 90 4 91 4 4 5 92 5 93 5 94 5 95 5 5 6 96 6 97 6 98 6 99 6 6 7 100 7 101 7 102 7 103 7 7 8 104 8 105 8 106 8 107 8 8 9 108 9 109 9 110 9 111 9 9 10 112 10 113 10 114 10 115 10 10 11 116 11 117 11 118 11 119 11 11...
result:
ok
Test #6:
score: 0
Accepted
time: 15ms
memory: 77408kb
input:
365 5 35 20 24 29 3 25
output:
364 3508667 122 1 123 1 124 1 1 2 125 2 126 2 2 3 127 3 128 3 3 4 129 4 130 4 4 5 131 5 132 5 5 6 133 6 134 6 6 7 135 7 136 7 7 8 137 8 138 8 8 9 139 9 140 9 9 10 141 10 142 10 10 11 143 11 144 11 11 12 145 12 146 12 12 13 147 13 148 13 13 14 149 14 150 14 14 15 151 15 152 15 15 16 153 16 154 16 16 ...
result:
ok
Test #7:
score: 0
Accepted
time: 20ms
memory: 77676kb
input:
318 6 4 44 46 6 37 14 49
output:
317 6799456 159 1 160 1 1 2 161 2 2 3 162 3 3 4 163 4 4 5 164 5 5 6 165 6 6 7 166 7 7 8 167 8 8 9 168 9 9 10 169 10 10 11 170 11 11 12 171 12 12 13 172 13 13 14 173 14 14 15 174 15 15 16 175 16 16 17 176 17 17 18 177 18 18 19 178 19 19 20 179 20 20 21 180 21 21 22 181 22 22 23 182 23 23 24 183 24 24...
result:
ok
Test #8:
score: 0
Accepted
time: 23ms
memory: 77208kb
input:
416 6 30 23 4 16 45 32 19
output:
415 5383994 208 1 209 1 1 2 210 2 2 3 211 3 3 4 212 4 4 5 213 5 5 6 214 6 6 7 215 7 7 8 216 8 8 9 217 9 9 10 218 10 10 11 219 11 11 12 220 12 12 13 221 13 13 14 222 14 14 15 223 15 15 16 224 16 16 17 225 17 17 18 226 18 18 19 227 19 19 20 228 20 20 21 229 21 21 22 230 22 22 23 231 23 23 24 232 24 24...
result:
ok
Test #9:
score: 0
Accepted
time: 4ms
memory: 76600kb
input:
572 5 15 27 5 18 3 46
output:
571 9396678 191 1 192 1 193 1 1 2 194 2 195 2 2 3 196 3 197 3 3 4 198 4 199 4 4 5 200 5 201 5 5 6 202 6 203 6 6 7 204 7 205 7 7 8 206 8 207 8 8 9 208 9 209 9 9 10 210 10 211 10 10 11 212 11 213 11 11 12 214 12 215 12 12 13 216 13 217 13 13 14 218 14 219 14 14 15 220 15 221 15 15 16 222 16 223 16 16 ...
result:
ok
Test #10:
score: 0
Accepted
time: 7ms
memory: 78044kb
input:
531 8 20 13 35 27 41 43 36 25 5
output:
530 9024252 178 1 1 2 179 2 180 2 2 3 181 3 182 3 3 4 183 4 184 4 4 5 185 5 186 5 5 6 187 6 188 6 6 7 189 7 190 7 7 8 191 8 192 8 8 9 193 9 194 9 9 10 195 10 196 10 10 11 197 11 198 11 11 12 199 12 200 12 12 13 201 13 202 13 13 14 203 14 204 14 14 15 205 15 206 15 15 16 207 16 208 16 16 17 209 17 21...
result:
ok
Test #11:
score: 0
Accepted
time: 19ms
memory: 77052kb
input:
487 10 29 29 40 45 5 16 40 47 47 2 14
output:
486 18026623 486 1 1 2 2 3 3 4 4 5 5 6 6 7 7 8 8 9 9 10 10 11 11 12 12 13 13 14 14 15 15 16 16 17 17 18 18 19 19 20 20 21 21 22 22 23 23 24 24 25 25 26 26 27 27 28 28 29 29 30 30 31 31 32 32 33 33 34 34 35 35 36 36 37 37 38 38 39 39 40 40 41 41 42 42 43 43 44 44 45 45 46 46 47 47 48 48 49 49 50 50 5...
result:
ok
Test #12:
score: 0
Accepted
time: 4ms
memory: 78084kb
input:
584 7 10 27 29 8 32 43 26 3
output:
583 11437238 292 1 293 1 1 2 294 2 2 3 295 3 3 4 296 4 4 5 297 5 5 6 298 6 6 7 299 7 7 8 300 8 8 9 301 9 9 10 302 10 10 11 303 11 11 12 304 12 12 13 305 13 13 14 306 14 14 15 307 15 15 16 308 16 16 17 309 17 17 18 310 18 18 19 311 19 19 20 312 20 20 21 313 21 21 22 314 22 22 23 315 23 23 24 316 24 2...
result:
ok
Test #13:
score: 0
Accepted
time: 7ms
memory: 76528kb
input:
59 4 48 16 9 42 21
output:
58 422967 12 1 13 1 14 1 15 1 16 1 1 2 17 2 18 2 19 2 20 2 2 3 21 3 22 3 23 3 24 3 3 4 25 4 26 4 27 4 28 4 4 5 29 5 30 5 31 5 32 5 5 6 33 6 34 6 35 6 36 6 6 7 37 7 38 7 39 7 40 7 7 8 41 8 42 8 43 8 44 8 8 9 45 9 46 9 47 9 48 9 9 10 49 10 50 10 51 10 52 10 10 11 53 11 54 11 55 11 56 11 57 11 58 11 11...
result:
ok
Test #14:
score: 0
Accepted
time: 7ms
memory: 77220kb
input:
561 3 22 31 17 49
output:
560 3223790 64 1 1 2 65 2 66 2 67 2 68 2 69 2 70 2 71 2 72 2 2 3 73 3 74 3 75 3 76 3 77 3 78 3 79 3 80 3 3 4 81 4 82 4 83 4 84 4 85 4 86 4 87 4 88 4 4 5 89 5 90 5 91 5 92 5 93 5 94 5 95 5 96 5 5 6 97 6 98 6 99 6 100 6 101 6 102 6 103 6 104 6 6 7 105 7 106 7 107 7 108 7 109 7 110 7 111 7 112 7 7 8 11...
result:
ok
Test #15:
score: 0
Accepted
time: 2ms
memory: 77368kb
input:
629 6 26 31 41 32 13 39 41
output:
628 13149156 315 1 1 2 316 2 2 3 317 3 3 4 318 4 4 5 319 5 5 6 320 6 6 7 321 7 7 8 322 8 8 9 323 9 9 10 324 10 10 11 325 11 11 12 326 12 12 13 327 13 13 14 328 14 14 15 329 15 15 16 330 16 16 17 331 17 17 18 332 18 18 19 333 19 19 20 334 20 20 21 335 21 21 22 336 22 22 23 337 23 23 24 338 24 24 25 3...
result:
ok
Test #16:
score: 0
Accepted
time: 4ms
memory: 76520kb
input:
616 3 38 48 27 2
output:
615 1394108 26 1 27 1 28 1 29 1 30 1 31 1 32 1 33 1 34 1 35 1 36 1 37 1 38 1 39 1 1 2 40 2 41 2 42 2 43 2 44 2 45 2 46 2 47 2 48 2 49 2 50 2 51 2 52 2 53 2 54 2 55 2 56 2 57 2 58 2 59 2 60 2 61 2 62 2 63 2 2 3 64 3 65 3 66 3 67 3 68 3 69 3 70 3 71 3 72 3 73 3 74 3 75 3 76 3 77 3 78 3 79 3 80 3 81 3 ...
result:
ok
Test #17:
score: 0
Accepted
time: 21ms
memory: 77664kb
input:
744 2 49 45 50
output:
743 1425426 24 1 25 1 26 1 27 1 28 1 29 1 30 1 31 1 32 1 33 1 34 1 35 1 36 1 37 1 38 1 39 1 1 2 40 2 41 2 42 2 43 2 44 2 45 2 46 2 47 2 48 2 49 2 50 2 51 2 52 2 53 2 54 2 55 2 56 2 57 2 58 2 59 2 60 2 61 2 62 2 63 2 64 2 65 2 66 2 67 2 68 2 69 2 70 2 71 2 2 3 72 3 73 3 74 3 75 3 76 3 77 3 78 3 79 3 ...
result:
ok
Test #18:
score: 0
Accepted
time: 17ms
memory: 77248kb
input:
629 7 27 18 48 24 37 38 6 3
output:
628 9258317 159 1 1 2 160 2 2 3 161 3 162 3 163 3 3 4 164 4 165 4 166 4 4 5 167 5 168 5 169 5 5 6 170 6 171 6 172 6 6 7 173 7 174 7 175 7 7 8 176 8 177 8 178 8 8 9 179 9 180 9 181 9 9 10 182 10 183 10 184 10 10 11 185 11 186 11 187 11 11 12 188 12 189 12 190 12 12 13 191 13 192 13 193 13 13 14 194 1...
result:
ok
Test #19:
score: 0
Accepted
time: 12ms
memory: 76876kb
input:
602 8 17 25 14 13 2 16 23 24 44
output:
601 9947756 601 1 1 2 2 3 3 4 4 5 5 6 6 7 7 8 8 9 9 10 10 11 11 12 12 13 13 14 14 15 15 16 16 17 17 18 18 19 19 20 20 21 21 22 22 23 23 24 24 25 25 26 26 27 27 28 28 29 29 30 30 31 31 32 32 33 33 34 34 35 35 36 36 37 37 38 38 39 39 40 40 41 41 42 42 43 43 44 44 45 45 46 46 47 47 48 48 49 49 50 50 51...
result:
ok
Test #20:
score: 0
Accepted
time: 19ms
memory: 76440kb
input:
900 2 9 13 12
output:
899 787522 15 1 16 1 17 1 18 1 19 1 20 1 21 1 22 1 23 1 24 1 25 1 26 1 27 1 28 1 1 2 29 2 30 2 31 2 32 2 33 2 34 2 35 2 36 2 37 2 38 2 39 2 40 2 41 2 42 2 43 2 44 2 45 2 46 2 47 2 48 2 49 2 50 2 51 2 52 2 53 2 54 2 55 2 56 2 57 2 58 2 59 2 60 2 61 2 62 2 63 2 64 2 65 2 66 2 67 2 68 2 69 2 70 2 71 2 ...
result:
ok
Test #21:
score: 0
Accepted
time: 12ms
memory: 77992kb
input:
839 7 12 12 28 33 35 29 14 17
output:
838 24516016 420 1 1 2 421 2 2 3 422 3 3 4 423 4 4 5 424 5 5 6 425 6 6 7 426 7 7 8 427 8 8 9 428 9 9 10 429 10 10 11 430 11 11 12 431 12 12 13 432 13 13 14 433 14 14 15 434 15 15 16 435 16 16 17 436 17 17 18 437 18 18 19 438 19 19 20 439 20 20 21 440 21 21 22 441 22 22 23 442 23 23 24 443 24 24 25 4...
result:
ok
Test #22:
score: 0
Accepted
time: 20ms
memory: 77448kb
input:
768 7 27 3 40 6 39 9 48 31
output:
767 18960055 384 1 385 1 1 2 386 2 2 3 387 3 3 4 388 4 4 5 389 5 5 6 390 6 6 7 391 7 7 8 392 8 8 9 393 9 9 10 394 10 10 11 395 11 11 12 396 12 12 13 397 13 13 14 398 14 14 15 399 15 15 16 400 16 16 17 401 17 17 18 402 18 18 19 403 19 19 20 404 20 20 21 405 21 21 22 406 22 22 23 407 23 23 24 408 24 2...
result:
ok
Test #23:
score: 0
Accepted
time: 4ms
memory: 76540kb
input:
783 3 25 19 31 45
output:
782 4263811 88 1 89 1 90 1 91 1 92 1 93 1 94 1 1 2 95 2 96 2 97 2 98 2 99 2 100 2 101 2 102 2 2 3 103 3 104 3 105 3 106 3 107 3 108 3 109 3 110 3 3 4 111 4 112 4 113 4 114 4 115 4 116 4 117 4 118 4 4 5 119 5 120 5 121 5 122 5 123 5 124 5 125 5 126 5 5 6 127 6 128 6 129 6 130 6 131 6 132 6 133 6 134 ...
result:
ok
Test #24:
score: -100
Wrong Answer
time: 19ms
memory: 78240kb
input:
2 4 24 9 31 45 15
output:
1 -999999752 1 2
result:
wrong answer