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比赛,我们每周日都会对比赛直播。

相关内容

热门资讯

天津大学:本科扩招260人 6月10日,澎湃新闻从天津大学获悉,今年该校在全国投放本科招生计划5280人,较去年扩招260人。作...
转给家长!2026 年幼儿园端... 幼儿园端午佳节 假 期 温 馨 提 示 端午节放假通知 尊敬的家长朋友们: 端午节即将到来,为了让您...
“文科遇冷”大环境下,中南财经... 图源:中南财经政法大学 近些年,“文科式微”的舆论持续发酵,考生和家长一窝蜂地涌向理工科,曾经热门的...
上海徐汇区教育局通报男幼师离世... 上海市徐汇区教育局6月13日发布情况通报: 来源:澎湃新闻
吓出冷汗!高考政治仅剩25分钟... 编辑|沉 6月9日,广东高考政治考试最后25分钟,深圳南头中学考点的考场内,所有考生都在争分夺秒赶进...
装修工人走错楼层,误将303室... 装修安家本是满心期盼的喜事, 江苏无锡一位业主却遭遇一桩 令其哭笑不得的糟心事: 施工工人未核对房号...
高考成绩公布时间定了! 为按照今年我省普通高校招生考试工作进程,拟于6月11日至24日,组织开展评卷、核查、校验等工作,6月...
以情景剧目演绎榜样故事,延庆6... 6月12日,北京市延庆区创新开展榜样主题课堂活动,以情景剧目演绎、实景教学的全新形式,生动讲述辖区各...
研究生院召开2026届毕业典礼... 研究生院召开2026届 毕业典礼第一次工作协调会 2026年6月5日上午,我校2026届毕业典礼第一...
2026年马鞍山特训学校哪家靠... 专家访谈引入 “很多家长一听到‘特训学校’就联想到吃苦、军训,这是个巨大的误区。”从事青少年心...