Atcoder Beginner Contest 410 題解報告

零、前言

經過七七四十九天的分別,本期 ABC 題解又和大家見面啦!

經過七周的奮勇殺題,我終于達成了三個小心愿:

  1. 不吃罰時AK
  2. 上金
  3. 排名 100 100 100 以內 且 Rated(悲催的是,我 ABC400 排名兩位數但沒Rated)

在這里插入圖片描述

咳咳,言歸正傳,開始講題:

一、正文

第 A 題 G1

十分簡單,即求 K K K 小于等于 a a a 中幾個數即可。

代碼:

#include <bits/stdc++.h>
using namespace std;
int a[1110];
int main(){int n; cin>>n;for (int i=1; i<=n; i++) cin>>a[i];int k,ans=0; cin>>k;for (int i=1; i<=n; i++){if (a[i]>=k) ans++;}cout<<ans;
} 

第 B 題 Reverse Proxy

本題題意為維護 n n n 個盒子, m m m 次操作,每次可以往特定一個盒子或球數量最小(如有多個則取編號最小的)的盒子里放一個球,問每個球被放進那些盒子里了。

考慮到 n , m ≤ 100 n,m\le 100 n,m100 可以暴力查詢球數量最小的盒子編號。

代碼:

#include <bits/stdc++.h>
using namespace std;
int a[1110];
int main(){int n,q; cin>>n>>q;for (int i=1; i<=q; i++){int x; cin>>x;if (x!=0) cout<<x<<" ",a[x]++;else{int mn=1000000000,id;for (int i=1; i<=n; i++){if (a[i]<mn) mn=a[i],id=i;}cout<<id<<" "; a[id]++;}}
} 

第 C 題 Rotatable Array

題意為維護一個數組,有三種操作:

  1. 單點修改
  2. 單點查詢
  3. 旋轉(即把第一個元素放到最后)

我們發現,數組長度不變,旋轉 n n n 次可以抵消。

假設我們的下標從 0 0 0 開始,那么旋轉 u u u 次的第一個元素就是 a u % n a_{u\% n} au%n?

修改、查詢第 p p p 個點轉化為修改、查詢第 ( p + ∑ i = 1 i d k i ) % n (p+\sum_{i=1}^{id} k_i)\% n (p+i=1id?ki?)%n 個點, i d id id 表示當前操作編號, k k k 為旋轉次數。

代碼:

#include <bits/stdc++.h>
using namespace std;
int a[2000010];
int main(){int n,q,st=0; cin>>n>>q;for (int i=1; i<=n; i++) a[i-1]=i;for (int i=1; i<=q; i++){int op; cin>>op;if (op==1){int p,s; cin>>p>>s; p--;a[(p+st)%n]=s;}else if (op==2){int p; cin>>p; p--;cout<<a[(p+st)%n]<<"\n";}else{int k; cin>>k;st=(st+k)%n;}}
} 

第 D 題 XOR Shortest Walk

一句話題意:給你 n n n 個點 m m m 條邊的圖,求 1 1 1 n n n 的最小異或路徑。

發現 w < 2 10 = 1024 w<2^{10}=1024 w<210=1024,可以維護 o k i , j ok_{i,j} oki,j? 表示從 1 1 1 走到 i i i 是否有異或和為 j j j 的路徑。

BFS 維護,時間復雜度為 O ( w × ( n + m ) ) O(w\times(n+m)) O(w×(n+m)) 可以通過本題。

代碼:

#include <bits/stdc++.h>
using namespace std;
bool vis[2010][2010];
vector <pair<int,int>> vc[2010];
int main(){int n,m; cin>>n>>m;for (int i=1; i<=m; i++){int u,v,w; cin>>u>>v>>w;vc[u].push_back({v,w});}vis[1][0]=1;queue <int> qx,qy;qx.push(1); qy.push(0);while (qx.size()){int x=qx.front(),y=qy.front();qx.pop(); qy.pop();for (auto z:vc[x]){if (!vis[z.first][z.second^y]){vis[z.first][z.second^y]=1;qx.push(z.first); qy.push(z.second^y);}}}for (int i=0; i<=2000; i++){if (vis[n][i]) {cout<<i; return 0;}}cout<<-1;
} 

第 E 題 Battles in a Row

題意:有 n n n 個怪物,每個怪物有兩個參數 a i , b i a_i,b_i ai?,bi?,你也有兩個參數 A , B A,B A,B。你可以令你的 A A A 減去 a i a_i ai? B B B 減去 b i b_i bi? 來殺死怪物 i i i,你的 A , B A,B A,B 不能變為負數。問 依次殺死怪物,你能殺死幾個呢?

特別提醒標黑部分(本蒟蒻讀錯題不會做卡了 20min

考慮二分,二分一個怪物數量。對于前 m i d mid mid 個怪物,我們先把默認每個怪物都用 A A A 殺,然后把 b b b 作為代價, a a a 作為價值, B B B 為容量跑背包,跑出最大價值 v v v,發現如果 ( ∑ a ) ? v ≤ A (\sum a)-v\le A (a)?vA,則有解。

其實不用二分也可以,但我賽時沒寫。

代碼:

#include <bits/stdc++.h>
using namespace std;
#define N 500000
int x[N],y[N],n,a,b,dp[N];
bool check(int mid){int sum=0;for (int i=1; i<=mid; i++) sum+=x[i];memset(dp,0,sizeof(dp));for (int i=1; i<=mid; i++){for (int j=b; j>=y[i]; j--){dp[j]=max(dp[j],dp[j-y[i]]+x[i]);}}return sum-dp[b]<=a;
}
int main(){ios::sync_with_stdio(0);cin.tie(0); cout.tie(0);cin>>n>>a>>b;for (int i=1; i<=n; i++){cin>>x[i]>>y[i];}int l=0,r=n;while (l<r-1){int mid=(l+r>>1);if (check(mid)) l=mid;else r=mid;}if (check(r)) cout<<r;else cout<<l;
} 

第 F 題 Balanced Rectangles

一句話題意,給你一個黑白網格,求多少子矩陣內黑白數量相等。

首先注意到 H × W ≤ 300000 H\times W\le 300000 H×W300000,則 H × W × min ? ( H , W ) ≤ 300000 × 300000 = 164316767 H\times W\times \min(H,W)\le 300000\times \sqrt{300000}=164316767 H×W×min(H,W)300000×300000 ?=164316767,考慮這個時間復雜度。

首先你可以把黑設為 1 1 1,白為 ? 1 -1 ?1,跑二維前綴和,那么假設 H ≤ W H\le W HW

枚舉 u , d u,d u,d,滿足 1 ≤ u ≤ d ≤ H 1\le u\le d\le H 1udH,然后根據前綴和,我們可以求出每個紫矩陣的權值和,任選兩個(紅,綠)矩陣,如果它們權值相等,則構成一個可行答案(黑)。
在這里插入圖片描述
那么請使用桶來統計答案,時間復雜度為上述值。

如果 H > W H > W H>W,同理枚舉兩列即可。

代碼:

#include <bits/stdc++.h>
using namespace std;
#define K 500000
int cnt[K+K+K];
string s[K];
vector <int> sum[K];
int main(){ios::sync_with_stdio(0);cin.tie(0); cout.tie(0);int t; cin>>t;while (t--){int n,m; cin>>n>>m;for (int i=1; i<=n; i++) cin>>s[i],s[i]=" "+s[i];for (int i=0; i<=n; i++){sum[i].clear();for (int j=0; j<=m; j++){sum[i].push_back(((i==0||j==0)?0:(s[i][j]=='.'?1:-1)));}}for (int i=1; i<=n; i++){for (int j=1; j<=m; j++) sum[i][j]+=sum[i][j-1];}for (int i=1; i<=n; i++){for (int j=1; j<=m; j++) sum[i][j]+=sum[i-1][j];}if (n<=m){long long ans=0;for (int i=1; i<=n; i++){for (int j=i; j<=n; j++){cnt[K]++;for (int k=1; k<=m; k++){ans+=cnt[sum[j][k]-sum[i-1][k]+K];cnt[sum[j][k]-sum[i-1][k]+K]++;}for (int k=1; k<=m; k++){cnt[sum[j][k]-sum[i-1][k]+K]--;}cnt[K]--;}}cout<<ans<<"\n";}else{long long ans=0;for (int i=1; i<=m; i++){for (int j=i; j<=m; j++){cnt[K]++;for (int k=1; k<=n; k++){ans+=cnt[sum[k][j]-sum[k][i-1]+K];cnt[sum[k][j]-sum[k][i-1]+K]++;}for (int k=1; k<=n; k++){cnt[sum[k][j]-sum[k][i-1]+K]--;}cnt[K]--;}}cout<<ans<<"\n";}}
} 

第 G 題 Longest Chord Chain

一句話題意:一個圓上有一些弦,保留互不相交的一些弦,再畫一條弦,求問它們之間最多存在多少個交點。

猜結論:保留最多的弦,使得它們可以分成兩部分,每部分都依次包含,兩部分無交集。

看如下圖:
在這里插入圖片描述
可以粗略證明上述結論。

現在考慮如何求解,首先假設 a i < b i a_i<b_i ai?<bi?(可以交換兩者),接下來把 a a a 從大到小排序,設 d p i dp_i dpi? 為第 i i i 個弦可以連套多少個區間,易得 d p i = max ? j ∈ [ 1 , n ] j ! = i , a i < a j < b j < b i d p j + 1 dp_i=\max_{j\in[1,n]}^{j!=i,a_i<a_j<b_j<b_i} dp_j+1 dpi?=maxj[1,n]j!=i,ai?<aj?<bj?<bi??dpj?+1,可以使用樹狀數組優化。

接下來有了 d p dp dp 后,易得答案為 max ? i , j ∈ [ 1 , n ] i ! = j , b j < a i d p i + d p j \max_{i,j\in[1,n]}^{i!=j,b_j<a_i} dp_i+dp_j maxi,j[1,n]i!=j,bj?<ai??dpi?+dpj? max ? ( d p i ) \max(dp_i) max(dpi?) 求最大值,前者也用樹狀數組優化即可,具體實現請參考代碼。

代碼:

#include <bits/stdc++.h>
using namespace std;
#define N 500010
int n,dp[N];
struct edg{int x,y;
}a[N];
bool cmp(edg a,edg b){return a.x>b.x; 
}
struct node{int c[N];void update(int id,int mx){while (id<=n*2){c[id]=max(c[id],mx); id+=(id&-id);}}int query(int id){int ans=0;while (id>0){ans=max(ans,c[id]); id-=(id&-id);}return ans;}
}tr,tr2;
int main(){ios::sync_with_stdio(0);cin.tie(0); cout.tie(0);cin>>n;for (int i=1; i<=n; i++){cin>>a[i].x>>a[i].y;if (a[i].x>a[i].y) swap(a[i].x,a[i].y);}sort(a+1,a+n+1,cmp);for (int i=1; i<=n; i++){dp[i]=tr.query(a[i].y)+1;tr.update(a[i].y,dp[i]);}for (int i=1; i<=n; i++){tr2.update(a[i].y,dp[i]);}int ans=0;for (int i=1; i<=n; i++){ans=max(ans,tr2.query(a[i].x)+dp[i]);}cout<<ans;
} 

二、后記

本篇題解結束了,祝愿大家能夠在學習中實現一個一個小目標,在突破自我中成長。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/84877.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/84877.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/84877.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

pyspark非安裝使用graphframes

pyspark版本3.1.3 需要文件 graphframes-0.8.2-spark3.1-s_2.12.jarspark-graphx_2.12-3.1.3.jar從 https://github.com/microsoft/adb2spark/raw/main/graphframes-0.8.2-py3-none-any.whl 下載graphframes-0.8.2-py3-none-any.whl。下載后把whl后綴改成zip&#xff0c;解壓…

[Linux入門] Linux磁盤管理與文件系統

目錄 Linux磁盤與文件系統管理詳解&#xff1a;從基礎到實踐 ??一、磁盤基礎簡述?? 1????硬盤類型??&#xff1a; ?2??機械硬盤結構??&#xff1a; 3????磁盤容量計算??&#xff1a; 公式&#xff1a;磁盤容量磁頭數柱面數每磁道扇區數每扇區字節數 …

【Flutter】性能優化總結

【Flutter】性能優化總結 Flutter 性能優化是提升應用流暢度、響應速度和用戶體驗的關鍵。可以從以下幾個方面進行優化&#xff1a; 一、UI 構建與布局優化 1、避免不必要的重建 使用 const 構造函數&#xff1a;如 const Text(Hello)&#xff0c;可以減少 Widget 重建。使用…

5、ZYNQ PL 點燈--流水燈

目錄 1、 概述 2 、硬件電路 3、 新建 VIVADO 工程 4、 添加工程文件 6、編寫流水燈功能的Verilog代碼 7 、添加管腳約束文件 8、 RTL 仿真 8.1 添加仿真測試源碼 8.2 仿真結果 9、 編譯并且產生 bit 文件 10、 下載程序 11、實驗結果 ?編輯12、總結 1、 概述 本…

HTML5 浮動

1. 常見網頁布局 1-3-1布局 1-2-1布局 2. 標準文檔流 3. display屬性? display&#xff1a; block 給span元素設置成block display&#xff1a; inline 給div元素設置成inline display&#xff1a; inline-block 給div和span元素設置為inline-block display&#xff1a; no…

若依使用RedisCache需要注意的事項

存入redis對象的時候會帶一個type字段&#xff0c;此處需要注意 存入方&#xff1a; 此處需要注意&#xff0c;存入redis的時候會帶一個type&#xff0c;也就是類的路徑名 redisCache.setCacheObject(screenPlayQueueName, userDemondDto,userDemondDto.getPlayDuration().in…

【STM32的通用定時器CR1的CKD[1:0]: 時鐘分頻因子 (Clock division)】

在 STM32 的通用定時器&#xff08;如 TIM2, TIM3, TIM4, TIM5 等&#xff09;中&#xff0c;CR1 (Control Register 1) 寄存器中的 CKD[1:0] (Clock division) 位域是一個與抗干擾和數字濾波相關的設置&#xff0c;它并不直接影響定時器計數器 (CNT) 的計數頻率&#xff08;計…

渲染學進階內容——機械動力的渲染系統(2)

Flywheel代碼 這篇來研究一下實例 InstanceHandle 接口深度解析 接口核心作用 InstanceHandle 是 Flywheel 渲染引擎中的 GPU實例句柄 接口,它提供了對底層渲染實例的直接控制能力。這個接口是**實例化渲染(Instanced Rendering)**系統的核心操作接口,與之前討論的 Vis…

Redis:極速緩存與數據結構存儲揭秘

Redis —— 這個強大又靈活的 開源、內存中的數據結構存儲系統。它常被用作數據庫、緩存、消息代理和流處理引擎。 核心特點 (為什么它這么受歡迎&#xff1f;)&#xff1a; 內存存儲 (In-Memory): 數據主要存儲在 RAM 中&#xff0c;讀寫操作直接在內存中進行。核心優勢&…

vulnyx Diff3r3ntS3c writeup

信息收集 arp-scan nmap 這里默認的話是只有80端口的&#xff0c;這個22端口是我拿到root后開的 獲取userFlag 直接上web看看 掃個目錄 把網頁拉到最下面可以看到一個文件上傳點 我們嘗試上傳一個php文件 失敗了&#xff0c;那xxx呢 上傳成功了&#xff0c;看來后端的后綴名…

【構建】CMake 構建系統重點內容

CMake 構建系統重點內容 1 基本語法與結構 cmake_minimum_required() 指定使用的最低 CMake 版本&#xff0c;防止不同版本行為不一致&#xff1a; cmake_minimum_required(VERSION 3.16)project() 定義項目名稱、語言和版本&#xff1a; project(MyApp VERSION 1.0 LANGU…

Packagerun:VSCode 擴展 快捷執行命令

Packagerun&#xff1a;VSCode 快捷命令擴展&#xff08;兼容cursor&#xff09; Packagerun 是一個為 前端和node開發者設計的 VSCode 擴展&#xff0c;旨在簡化 package.json 中腳本的執行&#xff0c;并支持自定義命令以提升開發效率。通過右鍵菜單、快捷鍵或自定義配置&am…

【C語言】計算機組成、計算機語言介紹

1.1 計算機組成 1946年2月14日&#xff0c;由美國軍方定制的世界上第一臺電子計算機“電子數字積分計算機”( ENIAC Electronic Numerical And Calculator)在美國賓夕法尼亞大學問世。 計算機(俗稱電腦)堪稱是人類智慧的結晶&#xff0c;隨著計算機的不斷發展&#xff0c;各行各…

(九)山東大學軟件學院項目實訓-基于大模型的模擬面試系統-面試對話標題自動總結

面試對話標題自動總結 主要實現思路&#xff1a;每當AI回復用戶之后&#xff0c;調用方法查看當前對話是否大于三條&#xff0c;如果大于則將用戶的兩條和AI回復的一條對話傳給DeepSeek讓其進行總結&#xff08;后端&#xff09;&#xff0c;總結后調用updateChatTopic進行更新…

降階法求解偏微分方程

求解給定的四個偏微分方程,采用降階法,令 v = u x v = u_x v=ux?,從而將原方程轉化為關于 v v v 的一階方程。 方程 u x y = 0 u_{xy} = 0 uxy?=0 令 v = u x v = u_x v=ux?,則方程變為 v y = 0 v_y = 0 vy?=0。解得 v = C 1 ( x ) v = C_1(x) v=C1?(x),即 u …

提的缺陷開發不改,測試該怎么辦?

經歷長時間的細致檢查&#xff0c;逐條執行數十條測試用例&#xff0c;終于發現一處疑似缺陷。截圖留存、粘貼日志&#xff0c;認真整理好各項信息&#xff0c;將它提交到缺陷管理系統。可不到五分鐘&#xff0c;這條缺陷就被打回了。開發人員給出的回復十分簡潔&#xff1a;“…

【Flutter】Widget、Element和Render的關系-Flutter三棵樹

【Flutter】Widget、Element和Render的關系-Flutter三棵樹 一、前言 在 Flutter 中&#xff0c;所謂的“三棵樹”是指&#xff1a; Widget Tree&#xff08;部件樹&#xff09;Element Tree&#xff08;元素樹&#xff09;Render Tree&#xff08;渲染樹&#xff09; 它們是…

IO之詳解cin(c++IO關鍵理解)

目錄 cin原理介紹 控制符(hex、oct、dec) cin如何檢查輸入 cin與字符串 cin.get(char ch) cin.get(void) istream &get(char*,int) istream &get(char*,int,char) istream &getline(char*,int); 遇到文件結尾EOF 無法完成一次完整輸入&#xff1a;設置f…

Bootstrap 5學習教程,從入門到精通, Bootstrap 5 分頁(Pagination)知識點及案例代碼(13)

Bootstrap 5 分頁&#xff08;Pagination&#xff09;知識點及案例代碼 Bootstrap 5 提供了強大的分頁組件&#xff0c;幫助開發者輕松實現分頁功能。以下是關于 Bootstrap 5 分頁的詳細語法知識點以及一個完整的案例代碼&#xff0c;包含詳細注釋&#xff0c;幫助初學者快速上…

Dina靶機滲透

1.信息查詢 1.1. Ip查詢 arp-scan -l 192.168.220.137 1.2. 端口收集 nmap -T4 -A -p- 192.168.220.137 1.3. 目錄掃描 dirsearch -u 192.168.220.137 -e* -i 200 通過訪問 robots.txt 文件發現有些禁止訪問得目錄 User-agent: *Disallow: /ange1Disallow: /angel1Dis…