AtCoder-ABC415 真题直播解析预告
开心田螺
2025-07-19 17:04:03
0

AtCoder (ABC 414)于上周六晚20:00进行,周日晚 19:00我们在B站进行了AtCoder Beginner Contest 414的题解直播讲解,以下为本次直播讲解内容及文字解析。

AtCoder (ABC 415)将于今天晚上20:00进行,周日晚 19:00我们在B站进行了AtCoder Beginner Contest 415的题解直播讲解,请同学们关注。

ABC414主讲老师:清华大学 吴老师(NOI2021银牌)

ABC415主讲老师:清华 殷老师(NOI2019银牌)

欢迎加入ABC交流QQ群咨询、沟通、交流群密码:AtCoder

ABC414比赛真题讲解

题目列表:

题目地址:https://atcoder.jp/contests/abc414/tasks

ABC413题解及参考程序(文字版)

========================================

A

#include

intmain{ intn,L,R; scanf( "%d%d%d",&n,&L,&R); intans = 0; for( inti = 1;i <= n;++i){ intl,r; scanf( "%d%d",&l,&r); if(l <= L && R <= r){ ans++;}}printf( "%d\n",ans); return0;}

B

#include

charS[ 105]; intm; // 此刻 S 的长度是多少intn;

intmain{ scanf( "%d",&n); for( inti = 1;i <= n;++i){ charstr[ 23]; longlong l;scanf( "%s%lld",str,&l); charc = str[ 0]; if(m+l > 100){ puts( "Too Long"); return0;}while(l--) S[++m] = c; }for( inti = 1;i <= m;++i) putchar(S[i]); puts( "");

return0;}

C

#include

#defineLL long longusingnamespacestd;intA; LL N;

boolcheck(LL x){ // 检测 x 是否是 A 进制下的回文数vector< int> digits; while(x){ digits. push_back(x%A); x /= A;}intm = digits. size; for( inti = 0;i <= (m -1)/ 2;++i){ if(digits[i] != digits[m -1-i]) returnfalse; }returntrue;}

LL get_pali(intx,intodd){ // x 是前一半,是否要奇数长度vector< int> digits; while(x) digits. push_back(x% 10),x /= 10; longlong res = 0; intm = digits. size; for( inti = m -1;i >= 0;--i) res = res * 10+ digits[i]; for( inti = odd;i <= m -1;++i) res = res * 10+ digits[i]; returnres; }

intmain{ scanf( "%d%lld",&A,&N); // 偶数长度longlong ans = 0; for( intx = 1;;x++){ longlong pali = get_pali(x, 0); if(pali > N) break; if( check(pali)) ans += pali; }// 奇数长度for( intx = 1;;x++){ longlong pali = get_pali(x, 1); if(pali > N) break; if( check(pali)) ans += pali; }printf( "%lld\n",ans); return0;}

D

#include

#define LL long longusingnamespacestd;intn,m; constint MAXN = 5e5 + 5; LL x[MAXN];

intmain{scanf( "%d%d",&n,&m); for( inti = 1;i <= n;++i) scanf( "%lld", x+i); sort( x+ 1, x+n+ 1); vector vec; for( inti = 2;i <= n;++i) vec.push_back( x[i] - x[i- 1]); sort(vec.begin,vec.end); reverse(vec.begin,vec.end); LL ans = x[n]- x[ 1]; for( inti = 0;i < m- 1;++i){ ans -= vec[i]; }printf( "%lld\n",ans); return0; }

E

#include

intmain{LL n;scanf( "%lld",&n); intpart1 = 1ll*(n%mod)*((n+ 1)%mod)%mod*inv2%mod; intpart2 = 0; for(LL l = 1,r;l <= n;l = r+ 1){ //遍历了所有可能的值 // 相同的值只访问一次// [n/i] 只有不超过 2sqrt(n) 个 r = n / (n / l);intlen = (r-l+ 1)%mod; intval = (n/l)%mod; (part2 += 1ll*len * val % mod) %= mod; }intans = (part1 - part2 + mod) % mod; printf( "%d\n",ans); return0; }

F

#includeusingnamespacestd;constint MAXN = 2e5+ 5; constint MAXK = 20+ 5;

structEdge{intto,nxt; }e[MAXN<< 1]; inthead[MAXN], cnt; intn,K;

voidadd( intu, intv){ e[++cnt] = (Edge){v,head[u]};head[u] = cnt;e[++cnt] = (Edge){u,head[v]};head[v] = cnt;}

intf[MAXN<< 1][MAXK],ans[MAXN]; intvis[MAXN][MAXK]; // f[i][j]: 上一步走的是第i条边(u->v),走完了第j步

inlinevoidSolve{ scanf( "%d%d",&n,&K); for( inti = 1;i <= n;++i){ head[i] = 0; ans[i] = 1e9; for( intj = 0;j <= K;++j) vis[i][j] = 0; }cnt = 1; for( inti = 1;i < n;++i){ intu,v; scanf( "%d%d",&u,&v); add(u,v); }for( inti = 1;i <= cnt;++i){ for( intj = 0;j <= K;++j) f[i][j] = -1; }

queueint, int> > q; for( inti = head[ 1];i;i=e[i].nxt){ f[i][ 1] = 1; q. push({i, 1}); }while(!q. empty){ auto[id, k] = q. front;q. pop; intv = e[id].to, u = e[id^ 1].to; if(k == K) ans[v] = min(ans[v], f[id][k] / K); if(vis[v][k] == 2) continue; ++vis[v][k];for( inti = head[v];i;i = e[i].nxt){ if(k < K && e[i].to == u) continue; intnxt_k = k == K ? 1: k+ 1; if(f[i][nxt_k] == -1){ f[i][nxt_k] = f[id][k] + 1; q. push({i, nxt_k}); }}}for( inti = 2;i <= n;++i) printf( "%d%c",ans[i]== 1e9? -1:ans[i], " \n"[i==n]); }

intmain{ intT; scanf( "%d",&T); while(T--) Solve; return0;}

G

#includeusingnamespacestd;

#defineLL long longconstint MAXN = 6e5+ 5;

intlc[MAXN], rc[MAXN]; inttot; // 1~n: 叶子编号vectorint,LL> > G[MAXN];

voidadd( intu, intv,LL w){ G[u]. push_back({v, w}); }LL p[MAXN];// s: 上车 t: 下车// l: 靠左 r: 靠右intrt_sl, rt_sr, rt_tl, rt_tr;

voidbuild( int&x, intl, intr, intup, intleft){ // up=1: 子 -> 父// up=0: 父 -> 子// left=1: 靠左// left=0: 靠右if(l == r){ x = l; // 所有线段树的叶子节点共享return; }if(!x) x = ++tot; intmid = (l + r) >> 1; build(lc[x], l, mid, up, left); build(rc[x], mid+ 1, r, up, left); if(left){ if(up){ add(lc[x], x, 0); add(rc[x], x, p[mid+ 1]-p[l]); }else{ add(x, lc[x], 0); add(x, rc[x], p[mid+ 1]-p[l]); }}else{ if(up){ add(lc[x], x, p[r]-p[mid]); add(rc[x], x, 0); }else{ add(x, lc[x], p[r]-p[mid]); add(x, rc[x], 0); }}}

structNode{intl,r,x; };

voidgetseg( intx, intl, intr, intL, intR,vector &res){ if(l == L && r == R){ res. push_back({l,r,x}); return; }intmid = (l + r) >> 1; if(R <= mid) getseg(lc[x],l,mid,L,R,res); elseif(L > mid) getseg(rc[x],mid+ 1,r,L,R,res); elsegetseg(lc[x],l,mid,L,mid,res), getseg(rc[x],mid+ 1,r,mid+ 1,R,res); }

LL dis[MAXN];boolused[MAXN];

voiddij{ for( inti = 1;i <= tot;++i) dis[i] = 1e18; priority_queueint>, vectorint> >, greaterint> > > pq; dis[ 1] = 0;pq. push({ 0, 1}); while(!pq. empty){ autov = pq. top.second;pq. pop; if(used[v]) continue; used[v] = 1; for( auto[x,w]:G[v]){ if(dis[x] > dis[v]+w){ dis[x] = dis[v] + w;pq. push({dis[x], x}); }}}}

intn,m;

intmain{ scanf( "%d%d",&n,&m); for( inti = 1;i <= n;++i) scanf( "%lld", &p[i]); tot = n;build(rt_sr, 1, n, 1, 0); build(rt_sl, 1, n, 1, 1); build(rt_tr, 1, n, 0, 0); build(rt_tl, 1, n, 0, 1);

for( inti = 1;i <= m;++i){ intl,r,L,R;LL c; scanf( "%d%d%d%d%lld",&l,&r,&L,&R,&c); vector segs, segt;if(r < L){ getseg(rt_sr, 1, n, l, r, segs); getseg(rt_tl, 1, n, L, R, segt); ++tot;for( auto[ll,rr,x]:segs){ add(x, tot, p[L]-p[rr]); }for( auto[ll,rr,x]:segt){ add(tot, x, c + p[ll]-p[L]); }}else{ getseg(rt_sl, 1, n, l, r, segs); getseg(rt_tr, 1, n, L, R, segt); ++tot;for( auto[ll,rr,x]:segs){ add(x, tot, p[ll]-p[R]); }for( auto[ll,rr,x]:segt){ add(tot, x, c + p[R]-p[rr]); }}}dij; for( inti = 2;i <= n;++i) printf( "%lld%c", dis[i] == 1e18? -1: dis[i], " \n"[i == n]); return0;}

题库地址:https://atcoder.jp

针对每周六20:00举办的ABC比赛,我们每周日都会对比赛直播。

相关内容

热门资讯

法考知识点:物权编高频考点(二... 法考知识点:物权编高频考点(二)——所有权与用益物权(附真题详解) 物权编的核心考点——所有权(共有...
法考经验分享 | 稻香里的法考... 初心如磐:检徽之下,再启新程 我是丹东铁路运输检察院的一名检察干警,入检生涯即将迈入第五个年头。 身...
速看!210所高校拟新增硕博点... 对于27考研党而言,近期最值得关注的重磅消息莫过于2026年度学位授权审核动态调整名单的陆续公示。全...
2027宁波大学设计专硕769... A 真题试卷答案部分: 2025年宁波大学769艺术设计评论考研真题试卷与参考答案 2024年宁波大...
正在公示!郑州14名校长入选 经个人申报、市县遴选推荐、专家评审 拟确定马大志等122名中小学校(园)长 作为河南省“十五五”中小...
青岛盟诺学校:西北、港大+伯克... 2026申请季已渐近尾声。当四封来自加州大学伯克利分校的录取通知轰轰烈烈地抵达盟诺校园,点燃了整个申...
留学生求职网站性价比高:客观评... 据公开行业数据显示,超过 50% 的留学生选择回国发展,70% 的毕业生面临即时就业压力,热门岗位的...
2026新人教版高中化学必修(... 2026年学生将迎来新版教材,新教材将更加重视思维和阅读!为了方便广大学生在暑假预习新学期的课本知识...
小学二升三每天一道练习题——第... 步骤一:先算出乐乐一共有多少钱 1大杯6元,买3大杯: 6x3=18(元) 还剩4元,所以总钱数: ...
深圳市福田区荔园小学学子亮相央... 4月,深圳市福田区荔园小学(通新岭)205名学子受邀登上中央广播电视总台《2026 CMG 4・23...