2023CCPC河南省賽暨河南邀請賽個人補題ABEFGHK

Dashboard - 2023 CCPC Henan Provincial Collegiate Programming Contest - Codeforces

過題難度:A H F G B K E

銅獎: 2? 339

銀獎: 3? 318

金獎: 5? 523

A:

直接模擬

// Code Start Here	int t;cin >> t;while(t--){string s;cin >> s;set<char> seen;bool found = false;		for (int i = 1; i < sz(s); ++i) {bool ok = true;seen.clear();for (int j = 0; j < i; ++j) {if (seen.count(s[j])) {ok = false;break;}seen.insert(s[j]);}if (!ok) continue;int l = i, r = sz(s) - 1;while (l < r) {if (s[l] != s[r]) {ok = false;break;}++l;--r;}if (ok) {found = true;break;}}cout << (found ? "HE\n" : "NaN\n");}

H

思路:我們發現0.5會進位,而距離0.5無窮左邊就會被舍去,因此最小的方式是分出來的盡量距離0.5差一點點,最多的就是0.5

// Code Start Here	int t;cin >> t;while(t--){int n , k;cin >> n >> k;if(k > 2 * n)cout << 0 << " " << 2 * n <<endl;else{int minv = (2 * n - k + 2) / 2;int maxv = minv + k - 1;cout << minv << " " << maxv << endl;}}

F

題意:

給定一個數列A從中選出 k 個數,計算:這些數的最大值-最小值,記作 max。這些數相鄰差值中的最小值,記作 min。要求使max×min 最小

思路:我們發現排序后,任意 k 個數如果不連續,選中其中的最大和最小值之差一定不會比連續的更小。同時,相鄰差值的最小值如果跳著選,差值可能會變大,而連續的差值是最穩定的。

對于連續的 k 個數,max=A[i+k?1]?A[i]。假設有k?1 個相鄰差值,存在差分數組 diff,使得diff[j]=A[j+1]?A[j]。連續區間 [i, i+k-1] 中,相鄰差值的最小值就是min=min(diff[i],diff[i+1],...,diff[i+k?2])。

因此我們可以遍歷所有可能的連續 k 個數區間,求:每個區間內max×min,然后取最小值

考慮到5e5的數據規模,我們使用單調隊列維護區間內差值的最小值。在O(1) 時間內取當前窗口最小值,且在移動窗口時自動維護單調性,效率是O(n)。

// Code Start Here	int n , k;cin >> n >> k;vector<int> a(n);for(int i = 0;i<n;i++)cin >> a[i];sort(all(a));vector<int> diff(n-1);for(int i = 0;i<n-1;i++)diff[i] = a[i+1] - a[i];int ans =  1e18;deque<int> dq;for(int i = 0;i<n;i++){if(i > 0){while(!dq.empty() && diff[i-1] <= diff[dq.back()])dq.pop_back();dq.push_back(i - 1);}if(i >= k){if (!dq.empty() && dq.front() < i - k)dq.pop_front();}if(i >= k-1){int max_v = a[i] - a[i-k+1];int min_v = 1e9;if(k > 1 && !dq.empty() )min_v = diff[dq.front()];if(k == 1)min_v = 1e9;ans = min(ans , 1LL *max_v * min_v);}}cout << ans << endl;return 0;

G:

一道超級大模擬題,考慮到個體的特殊性,我們可以對底數和冪數分別開兩個數組來映射,使用的時候取出即可

char a[][100] = {"",".................................................................................",".................................................................................",".0000000.......1.2222222.3333333.4.....4.5555555.6666666.7777777.8888888.9999999.",".0.....0.......1.......2.......3.4.....4.5.......6.............7.8.....8.9.....9.",".0.....0.......1.......2.......3.4.....4.5.......6.............7.8.....8.9.....9.",".0.....0.......1.2222222.3333333.4444444.5555555.6666666.......7.8888888.9999999.",".0.....0.......1.2.............3.......4.......5.6.....6.......7.8.....8.......9.",".0.....0.......1.2.............3.......4.......5.6.....6.......7.8.....8.......9.",".0000000.......1.2222222.3333333.......4.5555555.6666666.......7.8888888.9999999.",".................................................................................",
};char b[][100] = {"",".............................................................",".00000.....1.22222.33333.4...4.55555.66666.77777.88888.99999.",".0...0.....1.....2.....3.4...4.5.....6.........7.8...8.9...9.",".0...0.....1.22222.33333.44444.55555.66666.....7.88888.99999.",".0...0.....1.2.........3.....4.....5.6...6.....7.8...8.....9.",".00000.....1.22222.33333.....4.55555.66666.....7.88888.99999.",".............................................................",".............................................................",".............................................................",".............................................................",
};char c[][100] = {"",".................................",".................................",".........IIIIIII.N.....N.FFFFFFF.","............I....NN....N.F.......",".=======....I....N.N...N.F.......","............I....N..N..N.FFFFFFF.",".=======....I....N...N.N.F.......","............I....N....NN.F.......",".........IIIIIII.N.....N.F.......",".................................",
};char ans[20][1000];
int tot;void add(ll x, int d){stack<int> q;if (x == 0) q.push(0);while (x) {q.push(x % 10);x /= 10;}while (!q.empty()) {int top = q.top();for (int i = 1; i <= 10; i++) {if (d == 1)for (int j = tot, k = top * 8; j < tot + 8; j++, k++)ans[i][j] = a[i][k];elsefor (int j = tot, k = top * 6; j < tot + 6; j++, k++)ans[i][j] = b[i][k];}if (d == 1) tot += 8;else tot += 6;q.pop();}
}void INV(int l, int r){for (int i = 1; i <= 10; i++)for (int j = tot, tl = l; tl <= r; j++, tl++)ans[i][j] = c[i][tl];tot = tot + (r - l + 1);
}bool check(ll x, ll y){if (x == 1) return false;ll a = 1e18;for (ll i = 1; i <= y; i++) {if (a < x) return true;a /= x;}return false;
}ll qp(ll x, ll y){if (x == 1) return 1;ll t = 1;for (; y; y--) {if (t > 1e18 / x) return 1e18 + 1;t = t * x;}return t;
}
int main(){int T;cin >> T;cin.ignore();for (int t = 0; t < T; t++) {string s;getline(cin, s);ll x = 0, y = 0;size_t pos = s.find("^{");string xs = s.substr(0, pos);string ys = s.substr(pos + 2, s.size() - pos - 3);x = stoll(xs);y = stoll(ys);tot = 0;add(x, 1);add(y, 2);INV(0, 7);if (check(x, y))INV(8, 31);elseadd(qp(x, y), 1);for (int i = 1; i <= 10; i++) {ans[i][tot] = 0;printf("%s.\n", ans[i]);}printf("\n");}
}

B

發現對于ai>aj,i<j,那么i和j必須在同一個塊里。否則任意即可

所以可以直接劃分成最小的不可再分的幾個區間。從l到i,i是右端點當且僅當區間最大值小于等于后面的最小值。把這些右端點標記一下,滿足答案的必須滿足是倍數

預處理一下后綴,再暴力掃一遍倍數即可

// Code Start Here	int n;cin >> n;vector<int> a(n+10) , m(n+10) , f(n+10);for(int i = 1;i<=n;i++)cin >> a[i];m[n+1] = a[n];for(int i = n;i>=1;i--)m[i] = min(m[i+1],a[i]);int max_val = 0;for(int i = 1;i<=n;i++){max_val = max(max_val , a[i]);if(max_val <= m[i + 1] || i == n){f[i] = 1;max_val = 0;}}int ans = 0;for(int i = 1;i<=n;i++){ans ++;for(int j = i;j<=n;j+=i){if(f[j] == 0){ans--;break;}}}cout << ans <<endl;

K

題意:構造一個序列使得相鄰兩個數差的絕對值為質數

對于n < 10可以暴力枚舉,對于n > 10

若n為奇數,可以1 3 5 ... n-2 .. n .. n-3 .. n-5 .. 6 4 2

若n為偶數,可以1 3 5 .. n-3? n n-2 ...6 4 2

// Code Start Here	
int n;cin >> n;
switch (n) {
case 1: case 2: case 3: case 4:cout << "-1";break;
case 5:cout << "5 3 1 4 2";break;
case 6:cout << "5 3 1 6 4 2";break;
case 7:cout << "6 3 5 2 7 4 1";break;
case 8:cout << "6 3 8 5 2 7 4 1";break;
case 9:cout << "1 3 8 5 7 2 9 6 4";break;
default:if (n % 2) {for (int i = 4; i <= n; i += 2) {cout << i << ' ';if (n - 7 == i) cout << n - 2 << ' ';if (n - 5 == i) cout << n << ' ';}for (int i = n - 4; i >= 1; i -= 2) {cout << i << ' ';if (i == 7) cout << "2 ";}} else {for (int i = 4; i <= n; i += 2) {cout << i << ' ';if (n - 6 == i) cout << n - 1 << ' ';}for (int i = n - 3; i >= 1; i -= 2) {cout << i << ' ';if (i == 7) cout << "2 ";}}
}

E

考慮到可以使用KMP算法來計算最大前后綴,我們跑一遍KMP然后對ne數組去一個最大值即可,當最大值大于 50就可以考慮是錯的

// Code Start Here	string s;cin >> s;vector<int> ne(sz(s)+10 , 0);for(int i = 1;i<sz(s);i++){int j = ne[i - 1];while(j && s[i] != s[j]){j = ne[j - 1];}if(s[j] == s[i])j++;ne[i] = j;if(ne[i] >= 50){cout <<"No" << endl;return 0;}}cout <<"Yes" <<endl;

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

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

相關文章

如何用Python批量解壓ZIP文件?快速解決方案

如何用Python批量解壓ZIP文件&#xff1f;快速解決方案 文章目錄 **如何用Python批量解壓ZIP文件&#xff1f;快速解決方案**代碼結果詳細解釋 話不多說&#xff0c;先上干貨&#xff01;&#xff01;&#xff01; 代碼 import os import zipfiledef unzip_file(dir_path: str…

Spring Boot 的高級特性與經典的設計模式應用

目錄 1. 設計模式在 Spring Boot 中的應用 1.1 單例模式&#xff1a;Bean 管理與全局實例 1.1.1 Spring 中的單例 Bean 1.1.2 自定義單例實現 1.1.3 單例模式的優勢 1.2 工廠模式&#xff1a;動態創建 Bean 1.2.1 Spring 的工廠方法 1.2.2 自定義工廠類 1.2.3 工廠模式…

在Excel中使用函數公式時,常見錯誤對應不同的典型問題

在Excel中使用函數公式時&#xff0c;常見錯誤對應不同的典型問題 1. #DIV/0!&#xff08;除以零錯誤&#xff09;2. #N/A&#xff08;值不可用&#xff09;3. #NAME?&#xff08;名稱錯誤&#xff09;4. #NULL!&#xff08;空交集錯誤&#xff09;5. #NUM!&#xff08;數值錯…

【cursor疑惑】cursor續杯后使用agent對話時,提示“需要pro或商業訂閱的用戶才能使用“

背景 cursor的pro會員體驗過期了&#xff0c;想再次體驗deepseek、Claude等agent對話提示:“免費版本不可以使用agent對話功能(英文忘記截圖了&#xff0c;大意是這樣)”。 處理方法 Step-1&#xff1a;再次續杯cursor的pro會員14天體驗 詳情&#xff0c;見&#xff1a;【c…

解決qt.network.ssl: QSslSocket::connectToHostEncrypted: TLS initialization failed

可以參考&#xff1a;解決qt.network.ssl: QSslSocket::connectToHostEncrypted: TLS initialization failed-CSDN博客 講的是程序執行目錄下可能缺少了&#xff1a; libssl-1_1-x64.dll 和 libcrypto-1_1-x64.dll 庫文件&#xff0c;將其復制到可執行文件exe的同級目錄下即可…

白楊SEO:不到7天,白楊SEO博客網站百度搜索顯示和排名恢復正常!順帶說說上海線下GEO聚會分享和播客紅利

大家好&#xff0c;我是白楊SEO&#xff0c;專注SEO十年以上&#xff0c;全網SEO流量實戰派&#xff0c;AI搜索優化研究者。 5月開始&#xff0c;明顯就忙起來了&#xff0c;不管是個人陪跑還是企業顧問&#xff0c;不管是需要傳統SEO還是新媒體流量&#xff0c;還是當下這個A…

FART 自動化脫殼框架簡介與脫殼點的選擇

版權歸作者所有&#xff0c;如有轉發&#xff0c;請注明文章出處&#xff1a;https://cyrus-studio.github.io/blog/ FART簡介 ART 環境下基于主動調用的自動化脫殼方案&#xff0c;可以解決函數抽取殼。 關于函數抽取殼的實現原理可以參考&#xff1a;基于 art 下的類加載機…

卷積神經網絡進階:轉置卷積與棋盤效應詳解

【內容摘要】 本文深入解析卷積神經網絡中的轉置卷積&#xff08;反卷積&#xff09;技術&#xff0c;重點闡述標準卷積與轉置卷積的計算過程、轉置卷積的上采樣作用&#xff0c;以及其常見問題——棋盤效應的產生原因與解決方法&#xff0c;為圖像分割、超分辨率等任務提供理論…

Redis進階知識

Redis 1.事務2. 主從復制2.1 如何啟動多個Redis服務器2.2 監控主從節點的狀態2.3 斷開主從復制關系2.4 額外注意2.5拓撲結構2.6 復制過程2.6.1 數據同步 3.哨兵選舉原理注意事項 4.集群4.1 數據分片算法4.2 故障檢測 5. 緩存5.1 緩存問題 6. 分布式鎖 1.事務 Redis的事務只能保…

SDC命令詳解:使用get_libs命令進行查詢

相關閱讀 SDC命令詳解https://blog.csdn.net/weixin_45791458/category_12931432.html?spm1001.2014.3001.5482 get_libs命令用于創建一個庫對象集合&#xff0c;關于設計對象和集合的更詳細介紹&#xff0c;可以參考下面的博客。需要注意的是&#xff0c;在有些工具中還存在…

idea2024 不知道安裝了什么插件,界面都是中文的了,不習慣,怎么修改各個選項改回英文

如果你的 IntelliJ IDEA 2024 突然變成中文界面&#xff0c;很可能是安裝了中文語言包插件&#xff08;如 “Chinese (Simplified) Language Pack”&#xff09;。以下是 徹底恢復英文界面 的方法&#xff1a; 方法 1&#xff1a;直接卸載中文插件&#xff08;推薦&#xff09;…

物流項目第二期(用戶端登錄與雙token三驗證)

第一期內容&#xff1a; 物流項目第一期&#xff08;登錄業務&#xff09;-CSDN博客 用戶端登錄 實現分析 登錄功能 Data public class UserLoginRequestVO {ApiModelProperty("登錄臨時憑證")private String code;ApiModelProperty("手機號臨時憑證"…

精準掌控張力動態,重構卷對卷工藝設計

一、MapleSim Web Handling Library仿真和虛擬調試解決方案 在柔性材料加工領域&#xff0c;卷對卷&#xff08;Roll-to-Roll&#xff09;工藝的效率與質量直接決定了產品競爭力。如何在高動態生產場景中實現張力穩定、減少斷裂風險、優化加工速度&#xff0c;是行業長期面臨的…

Voxblox算法

文章目錄 1. 算法簡介2. 由 TSDF 構建 ESDF 的方法2.1. 論文解讀2.2. 偽代碼實現 1. 算法簡介 Voxblox 算法出現于文獻《Voxblox: Incremental 3D Euclidean Signed Distance Fields for On-Board MAV Planning》&#xff0c;PDF 鏈接&#xff1a;https://arxiv.org/pdf/1611.…

計算機圖形學基礎--Games101筆記(一)數學基礎與光柵化

文章目錄 數學基礎向量插值三角形插值雙線性插值 平面定義法線-點表示 第一部分&#xff1a;光柵化坐標變換二維變換3D變換視圖變換&#xff08;MVP&#xff09;投影變換 光柵化采樣抗鋸齒&#xff08;反走樣&#xff09;可見性&#xff08;遮擋&#xff09; 著色與紋理Blinn-P…

@RequestParam 和 @RequestBody、HttpServletrequest 與HttpServletResponse

在Java Web開發中&#xff0c;RequestParam、RequestBody、HttpServletRequest 和 HttpServletResponse 是常用的組件&#xff0c;它們用于處理HTTP請求和響應。下面分別介紹它們的使用場景和使用方法&#xff1a; 1. RequestParam RequestParam 是Spring MVC框架中的注解&am…

【硬核數學】2. AI如何“學習”?微積分揭秘模型優化的奧秘《從零構建機器學習、深度學習到LLM的數學認知》

在上一篇中&#xff0c;我們探索了線性代數如何幫助AI表示數據&#xff08;向量、矩陣&#xff09;和變換數據&#xff08;矩陣乘法&#xff09;。但AI的魅力遠不止于此&#xff0c;它最核心的能力是“學習”——從數據中自動調整自身&#xff0c;以做出越來越準確的預測或決策…

10.15 LangChain v0.3重磅升級:Tool Calling技術顛覆大模型工具調用,效率飆升300%!

LangChain v0.3 技術生態與未來發展:支持 Tool Calling 的大模型 關鍵詞:LangChain Tool Calling, 大模型工具調用, @tool 裝飾器, ToolMessage 管理, Few-shot Prompting 1. Tool Calling 的技術革新 LangChain v0.3 的工具調用(Tool Calling)功能標志著大模型應用開發進…

[架構之美]從PDMan一鍵生成數據庫設計文檔:Word導出全流程詳解(二十)

[架構之美]從PDMan一鍵生成數據庫設計文檔&#xff1a;Word導出全流程詳解&#xff08;二十&#xff09; 一、痛點 你是否經歷過這些場景&#xff1f; 數據庫字段頻繁變更&#xff0c;維護文檔耗時費力用Excel維護表結構&#xff0c;版本混亂難以追溯手動編寫Word文檔&#…

Image and depth from a conventional camera with a coded aperture論文閱讀

Image and depth from a conventional camera with a coded aperture 1. 研究目標與實際意義1.1 研究目標1.2 實際問題與產業意義2. 創新方法:編碼光圈設計與統計模型2.1 核心思路2.2 關鍵公式與模型架構2.2.1 圖像形成模型2.2.2 深度可區分性準則2.2.3 統計模型與優化框架2.2…