Codeforces Round 930 (Div. 2) (A~B)

比賽:Codeforces Round 930 (Div. 2) (A~B)

目錄:A B

A題:Shuffle Party

標簽: 模擬

題目大意

  • 給你一個數組 a1,a2,…,an。最初,每個 1 ≤ i ≤ n都有 ai = i,整數 k ≥ 2的運算 swap(k)定義如下:
    • 設 d是不等于 k本身的最大除數 。然后交換元素 ad 和 ak
  • 執行swap(2) swap(3) … swap(n):問執行完后1在哪個位置

思路

  • 只關注1的交換位置,2的最大除數是1,4的最大除數是2,8的最大除數是4…
  • 所以1的位置會有1 -> 2 -> 4 -> 8 -> 16 … 一直到接近n的位置

AC代碼

#include <bits/stdc++.h>
using namespace std;
void solve()
{int n; cin >> n;int t = log2(n);	// 找到滿足 2^t <= n 最大的tcout << (1 << t) << endl; // 2^t即為答案
} 
int main()
{int T; cin >> T;while(T--)solve();return 0;
}

B題:Binary Path

標簽: 實現問題,編程技巧,模擬(implementation)

題目大意

  • 給你一個 2×n 充滿了 0 和 1的 網格。 i 行和j列的數字是 aij
  • 從(1, 1)點開始只能向下或向右走,走到(2, n),經過路徑上的數字拼接起來。
  • 問:拼接后的數字 字典序最小的是什么,有幾種走法能得到這個字典序最小值。

思路

  • 因為是2 * n的網格只能向下或向右走,所以只能向下走一次,走完一次向下后路線固定了因為只能向右走了
  • 為了好說明,這里將那個向下走的位置稱為斷點
  • 將1 ~ n 每一個點當作斷點枚舉,要字典序最小所以要走法有以下幾種情況:
    1. 如果當前點右邊點小于下邊點那么一定向右走,繼續向后尋找斷點
    1. 下面的點小于右邊的點,那么向下走。那么這個點就是斷點,并且只有這一種情況
    1. 下面的點等于右邊的點,這時既可以向下又可以向右,但如果在之后遇到下面的點不等于右邊的點得情況那么路線會被確定到后面得點,沒有則當前點和右邊點都可以作為斷點
  • 樣例3 斷點可為0011,即從0011往下字典序最小且一樣,如下:
  • 001 0011 1
    111 011 01

AC代碼

#include <bits/stdc++.h>
using namespace std;
const int N = 2e5 + 10;
vector<string> v;
void solve()
{int n; cin >> n;v.clear();for(int i = 0; i < 2; i++){string s; cin >> s;v.push_back(s);}	int res = 1, idx = 0;for(int i = 0; i < n-1; i++){if(v[0][i+1] == v[1][i])res ++;else {// 下面的點小于右邊的點,那么向下走,那么這個點就是斷點if(v[0][i+1] > v[1][i]) {idx = i; break;}// 如果當前點右邊點小于下邊點那么一定向右走,那么當前點不是斷點,繼續向后尋找斷點idx = i + 1;res = 1; // 上一步是向右走,路線時固定的刷新為一種情況}}// 斷點為idx輸出路徑for(int i = 0; i <= idx; i++)cout << v[0][i];for(int i = idx; i < n; i++)cout << v[1][i];cout << "\n" << res << "\n";
} 
int main()
{int T; cin >> T;while(T--)solve();return 0;
}

logo

//へ     /|
//  /\7    ∠_/
//  / │   / /
// │ Z _,< /   /`ヽ
// │     ヽ   /  〉
//  Y     `  /  /
// イ● 、 ●  ??〈  /
// ()  へ    | \〈
//  >ー 、_  ィ  │ //
//  / へ   / ノ<| \\
//  ヽ_ノ  (_/  │//
//	  7       |/
//
/*__   _,--="=--,_   __/  \."    .-.    "./  \/  ,/  _   : :   _  \/` \\  `| /o\  :_:  /o\ |\__/`-'| :="~` _ `~"=: |\`     (_)     `/.-"-.   \      |      /   .-"-.
.---{     }--|  /,.-'-.,\  |--{     }---.)  (_)_)_)  \_/`~-===-~`\_/  (_(_(_)  (
(                         				))                                     (
'---------------------------------------'
*/

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

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

相關文章

Python圖像形態學處理:腐蝕、膨脹、禮帽、黑帽……

文章目錄 二值形態學灰度形態學 python圖像處理教程&#xff1a;初步&#x1f4f7;插值變換 最基礎的形態學操作有四個&#xff0c;分別是腐蝕、膨脹、開計算和閉計算&#xff0c;【scipy.ndimage】分別實現了二值數組和灰度數組的這四種運算。而針對灰度圖像&#xff0c;【sc…

Office/WPS 好用的PPT插件-智能選擇布局

軟件介紹 PPT大珩助手是一款全新設計的Office PPT插件&#xff0c;它是一款功能強大且實用的PPT輔助工具&#xff0c;能夠輕松幫助您修改、優化和管理幻燈片。憑借豐富的功能和用戶友好的界面&#xff0c;PPT大珩助手能夠助力您打造出精美而專業的演示文稿。我們致力于為用戶提…

Flutter學習7 - Dart 泛型

1、泛型類 //泛型類 class Cache<T> {final Map<String, T> _cache {};void saveData(String key, T value) {_cache[key] value;}//泛型方法T? getData(String key) {return _cache[key];} }void main() {Cache<int> cache1 Cache();const String name…

NGINX的重寫與反向代理機制解析

目錄 引言 一、重寫功能 &#xff08;一&#xff09;if指令 1.判斷訪問使用的協議 2.判斷文件 &#xff08;二&#xff09;return指令 1.設置返回狀態碼 2.返回指定內容 3.指定URL &#xff08;三&#xff09;set指令 1.手動輸入變量值 2.調用其它變量值為自定義變…

RISC-V特權架構 - CSR寄存器

RV32/64 特權架構 - CSR寄存器 1 CSR地址空間2 CSR定義2.1 用戶級2.2 監管級2.3 超級監管級2.4 機器級 3 CSR訪問3.1 CSRRW3.2 CSRRS3.3 CSRRC3.4 CSRRWI3.5 CSRRSI3.6 CSRRCI 本文屬于《 RISC-V指令集基礎系列教程》之一&#xff0c;歡迎查看其它文章。 1 CSR地址空間 RISC&…

房貸計算器微信小程序原生語言

微信小程序: 房貸計算器 效果: 輸入 300萬 結果 還款明細 一共有3個頁面 1、輸入頁面 2、結果頁面 3、詳情頁面 1 index頁面 index.wxml文件 <view class="text-black"><!--房屋總價--><view class="cu-bar bg-white solid-bottom"&…

TCP/IP狀態遷移

TCP&#xff08;傳輸控制協議&#xff09;是一種面向連接的流式控制協議&#xff0c;它定義了不同的狀態以管理通信過程中的連接。TCP 狀態遷移描述了 TCP 連接在不同狀態之間的轉換過程&#xff0c;常見的 TCP 狀態包括 CLOSED、LISTEN、SYN_SENT、SYN_RECEIVED、ESTABLISHED、…

免費下載《金融行業數據安全交換解決方案白皮書》

金融行業包括商業銀行業務、證券業務、保險業務、基金業務、信托業務等&#xff0c;因此數據類型多種多樣&#xff0c;并且數據涉及主體眾多&#xff0c;應用場景上較為多樣復雜&#xff0c;在數據交換上存在安全、合規、可控、可靠、高效等需求。 金融行業會面臨哪些數據安全…

IIS發布PHP網站字體404解決辦法

最近在使用 IIS 發布 PHP 網站時&#xff0c;我遇到了一個前端問題&#xff0c;即字體庫文件 404 錯誤。這個問題的根本原因是 IIS 未能正確識別字體文件類型&#xff0c;導致瀏覽器在加載頁面時無法正確獲取所需字體資源&#xff0c;進而觸發了404錯誤。這樣的問題會導致網站頁…

npm install 報錯常見的解決方法

npm install 報錯的情況有很多種&#xff0c;每種錯誤的具體解決方案也有所不同。這里我將匯總一些常見的npm install報錯及其解決辦法&#xff1a; 1. 下載速度慢/網絡問題 解決辦法&#xff1a;更換npm包的鏡像源至國內鏡像&#xff0c;如淘寶npm鏡像&#xff1a;npm confi…

Javascript:輸入輸出

目錄 一.前言 二.正文 1.輸出 2.輸入 3.字面量 概念&#xff1a; 三.結語 一.前言 Javascript作為運行瀏覽器的語言&#xff0c;對于學習前端的同學來說十分重要&#xff0c;那么從現在開始我們將開始介紹有關 Javascript。 二.正文 1.輸出 document.write() : 向body內…

第十四篇【傳奇開心果系列】Python的文本和語音相互轉換庫技術點案例示例:深度解讀Azure Cognitive Services個性化推薦系統

傳奇開心果博文系列 系列博文目錄Python的文本和語音相互轉換庫技術點案例示例系列 博文目錄前言一、個性化推薦系統介紹和關鍵功能以及優勢解說二、雛形示例代碼三、個性化推薦示例代碼四、實時推薦示例代碼五、多種推薦算法示例代碼六、易于集成示例代碼七、數據安全和隱私保…

C# DLL實現泄露實驗

先說結論&#xff1a;如果應用程序項目中使用直接引用的形式調用動態鏈接庫&#xff0c;當動態鏈接庫是在調試模式生成的情況下&#xff0c;即使應用程序以發布模式生成&#xff0c;跟隨應用程序一同生成的動態鏈接庫仍為調試模式&#xff0c;會引發DLL實現泄露問題&#xff1b…

Google Genie:創意互動環境

每周跟蹤AI熱點新聞動向和震撼發展 想要探索生成式人工智能的前沿進展嗎&#xff1f;訂閱我們的簡報&#xff0c;深入解析最新的技術突破、實際應用案例和未來的趨勢。與全球數同行一同&#xff0c;從行業內部的深度分析和實用指南中受益。不要錯過這個機會&#xff0c;成為AI領…

cJSON讀寫數據例子

cJSON使用案例代碼。 #include <stdio.h> #include <stdlib.h> #include "../cJson/cJSON.h" int main() { FILE* jsonFile fopen("data.json", "r"); if (jsonFile) { fseek(jsonFile, 0, SEEK_END); i…

C++的一些細節技巧

列表和數組的區別 【C】list使用 1.C中怎么把字符串放到list&#xff1a; 在C中將字符串存入列表&#xff08;List&#xff09;可以使用標準庫的std::list<std::string>。下面是示例代碼&#xff1a; #include <iostream> #include <list> #include <st…

pt模型轉換為onnx的作用,直接用pt模型去檢測可以嗎

將PyTorch模型轉換為ONNX模型的作用主要在于提高模型的可移植性和兼容性&#xff0c;同時不能直接用PyTorch模型去檢測的原因可能涉及到環境配置、性能優化等方面。 首先&#xff0c;關于將PyTorch模型轉換為ONNX模型的作用&#xff0c;ONNX&#xff08;Open Neural Network E…

day57 集合 List Set Map

List實現類 List接口特點&#xff1a;元素有序 可重復 Arraylist 可變數組 jdk 8 以前Arraylist容量初始值10 jdk8 之后初始值為0&#xff0c;添加數據時&#xff0c;容量為10&#xff1b; ArrayList與Vector的區別&#xff1f; LinkList&#xff1a;雙向鏈表 優點&#xff1…

智慧工地物聯網云平臺APP源碼:監管端、工地端、危大工程、智慧大屏

目錄 技術說明 智慧工地 服務對象&#xff1a;項目現場 企業項目管理 服務對象&#xff1a;建設領域企業 政府工地監管 服務對象&#xff1a;全國各省建設領域政府機構 勞務實名制管理解決方案 綠色施工解決方案 視頻監控解決方案 塔機安全監控解決方案 施工升降機安…

Windows安裝Docker 容器教程(轉載)

Windows安裝Docker 容器教程 Docker Desktop - WSL distro terminated abruptlyA WSL distro Docker Desktop relies on has exited une Docker Desktop - Unexpected WSL error