題解 | #1002.Shortest path# 2023杭電暑期多校9

1002.Shortest path

簽到題 記憶化搜索

題目大意

給定一個正整數 n n n ,可以對其進行以下操作:

  1. 如果 n n n 能被 3 3 3 整除,則可以使 n = n / 3 n=n/3 n=n/3 ;
  2. 如果 n n n 能被 2 2 2 整除,則可以使 n = n / 2 n=n/2 n=n/2 ;
  3. 使 n = n ? 1 n=n-1 n=n?1

求使得 n n n 變成 1 1 1 的最少操作次數

解題思路

將樣例Output輸出即可

這題不難,但確實精彩()//畢竟……
《釘耙編程”中國大學生算法設計超級聯賽》是由hdu自主研發的一款全新開放世界冒險競賽。競賽發生在一個被稱作“hdu”的幻想世界,在這里,被編譯器選中的人將被授予“C++”,導引代碼之力。你將扮演一位名為“acmer”的神秘角色,在自由的打題中邂逅性格各異能力獨特的STL容器,和他們一起擊敗強題,找回AC的代碼

不鬧了,解題吧()

不難看出操作 3 3 3 的收益最低,是不滿足操作 1 , 2 1,2 1,2 的時候湊條件用的。
而由于只允許整除,操作 1 , 2 1,2 1,2 的優劣性不好評估(因為要夾雜操作 3 3 3 而不單純是減少的量的區別),因此每次對本次進行的兩種操作方案進行比較。

按以下操作遞歸處理 n n n

  1. 如果 n = 1 n=1 n=1 ,則返回 0 0 0
  2. 進行若干次(可能0次)操作 3 3 3 使得 n n n 能被 2 2 2 整除,執行操作 2 2 2
  3. 進行若干次(可能0次)操作 3 3 3 使得 n n n 能被 3 3 3 整除,執行操作 1 1 1

由于數據范圍的關系,傳統的DFS會超時,因此需要使用記憶化搜索
即每次計算完某個數(記為 x x x )的結果,將其保存下來,后續搜索 x x x 時就無需繼續搜索到底部,直接輸出這個數的結果即可
記憶化搜索可以用 map 實現,頻繁讀取而不考慮元素順序的可以使用 unordered_map ,有效降低時間空間復雜度


下面兩份使用了 map ,代碼完全一致;上面一份僅僅將 map 改為了 unordered_map

時間復雜度

O ( t log ? 2 n ) O(t\log^2n) O(tlog2n)

參考代碼

參考代碼為已AC代碼主干,其中部分功能需讀者自行實現

unordered_map<ll,ll> mp;
ll dfs(ll n){if(n<=1) return 1-n;if(mp[n]) return mp[n];ll t1,t2;t1=n%2+1+dfs(n/2);t2=n%3+1+dfs(n/3);return mp[n]=min(t1,t2);
}
void solve()
{ll n;cin >> n;cout << dfs(n) << endl;
}

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

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

相關文章

【C++】deque容器

0.前言 1.deque構造函數 #include <iostream> using namespace std; #include <deque>//deque構造函數 void printDeque(const deque<int>& d) {for (deque<int>::const_iterator it d.begin(); it ! d.end(); it){//*it 100; //加了const就不能…

go的gin和gorm框架實現切換身份的接口

使用go的gin和gorm框架實現切換身份的接口&#xff0c;接收前端發送的JSON對象&#xff0c;查詢數據庫并更新&#xff0c;返回前端信息 接收前端發來的JSON對象&#xff0c;包含由openid和登陸狀態組成的一個string和要切換的身份碼int型 后端接收后判斷要切換的身份是否低于該…

windows下dll文件的創建詳細教程

1、前言 dll文件是啥&#xff0c;就不作過多贅述了。現在直接教大家如何創建與使用dll文件。 本文基于windows系統&#xff0c;使用的編譯相關工具為visual studio 2019。 2、創建dll 2.1 創建dll工程 首先打開visual studio&#xff0c;然后選擇創建新項目&#xff0c;在搜…

Word(1):文章頁碼設置

1.需求 在文檔的封皮頁不設置頁碼&#xff0c;在目錄頁頁碼設置為羅馬數字&#xff0c;在正文使用阿拉伯數字。 2.解決方法 step1&#xff1a; 在封皮頁的最后&#xff0c;點擊”插入“-分隔符-分節符&#xff08;下一頁&#xff09; step2&#xff1a;在目錄頁的最后&…

【Java學習】System.Console使用

背景 在自學《Java核心技術卷1》的過程中看到了對System.Console的介紹&#xff0c;編寫下列測試代碼&#xff0c; public class ConsoleTest {public static void main(String[] args) {Console cs System.console();String name cs.readLine("AccountInfo: ");…

探討uniapp的數據緩存問題

異步就是不管保沒保存成功&#xff0c;程序都會繼續往下執行。同步是等保存成功了&#xff0c;才會執行下面的代碼。使用異步&#xff0c;性能會更好&#xff1b;而使用同步&#xff0c;數據會更安全。 1 uni.setStorage(OBJECT) 將數據存儲在本地緩存中指定的 key 中&#x…

html中文件上傳儲存到本地路徑

第一步:寫html文件 <form action"/uplode" method"post" enctype"multipart/form-data">姓名:<input type"text" name"username"><br>年齡:<input type"text" name"age"><…

Python接口自動化測試之UnitTest詳解

基本概念 UnitTest單元測試框架是受到JUnit的啟發&#xff0c;與其他語言中的主流單元測試框架有著相似的風格。其支持測試自動化&#xff0c;配置共享和關機代碼測試。支持將測試樣例聚合到測試集中&#xff0c;并將測試與報告框架獨立。 它分為四個部分test fixture、TestC…

電腦提示數據錯誤循環冗余檢查怎么辦?

有些時候&#xff0c;我們嘗試在磁盤上創建分區或清理硬盤時&#xff0c;還可能會遇到這個問題&#xff1a;數據錯誤循環冗余檢查。這是如何導致的呢&#xff1f;我們又該如何解決這個問題呢&#xff1f;下面我們就來了解一下。 導致冗余檢查錯誤的原因有哪些&#xff1f; 數據…

應急響應-釣魚郵件的處理思路溯源及其反制

0x00 釣魚郵件的危害 1.竊取用戶敏感信息&#xff0c;制作虛假網址&#xff0c;誘導用戶輸入敏感的賬戶信息后記錄 2.攜帶病毒木馬程序&#xff0c;誘導安裝&#xff0c;使電腦中病毒木馬等 3.挖礦病毒的傳輸&#xff0c;勒索病毒的傳輸等等 0x01 有指紋的釣魚郵件的溯源處理…

nodejs+vue+elementui社區流浪貓狗救助救援網站_4a4i2

基于此背景&#xff0c;本研究結合管理員即時發布流浪貓狗救助救援信息與用戶的需求&#xff0c;設計并實現了流浪貓狗救助救援網站。系統采用B/S架構&#xff0c;java語言作為主要開發語言&#xff0c;MySQL技術創建和管理數據庫。系統主要分為管理員和用戶兩大功能模塊。通過…

vue 控件的四個角設置 父視圖position:relative

父視圖relative&#xff0c;子視圖 absolute <div class"bg1"> <i class"topL"></i> <i class"topR"></i> <i class"bottomL"></i> <i class"bottomR"></i> <di…

網絡編程555

上傳代碼 #include <stdio.h>//客戶端 #include <string.h> #include <stdlib.h> #include<sys/types.h> #include<sys/socket.h> #include<arpa/inet.h> #include<head.h> #define PORT 69 #define IP "192.168.124.57"…

python之列表推導式

列表推導式是一種簡潔的方式來創建列表。它允許您通過在單個表達式中定義循環和條件邏輯&#xff0c;以一種更緊湊的方式生成新的列表。使用列表推導式可以使代碼更簡潔&#xff0c;易于閱讀&#xff0c;并且通常比傳統的迭代方法更快。 列表推導式的一般語法形式為&#xff1a…

excel填數據轉json格式

定制化比較嚴重&#xff0c;按需更改 excel文件如下 代碼 # -*- coding: utf-8 -*- import oss2 import shutil import sys import xlwt import xlrd import json from datetime import datetime, timedeltafile1 "C:\\Users\\cxy\\Desktop\\generate.xls" #打開表…

使用phpunit進行單元測試

使用phpunit進行單元測試 本教程假定您使用 PHP 8.1 或 PHP 8.2。您將學習如何編寫簡單的單元測試以及如何下載和運行 PHPUnit. PHPUnit 10 的文檔 在這。 下載&#xff1a;可以用以下2種方法之一&#xff1a; 1.PHP 存檔 (PHAR) 我們分發了一個 PHP存檔&#xff08;PHAR&…

MySQL8的下載與安裝-MySQL8知識詳解

本文的內容是mysql8的下載與安裝。主要講的是兩點&#xff1a;從官方網站下載MySQL8安裝和從集成環境安裝MySQL8。 一、從官方網站下載MySQL8.0安裝 MySQL8.0官方下載地址是&#xff1a;&#xff08;見圖&#xff09; 官方正式版的最新版本是8.0.34&#xff0c;也推出了創新版…

Kafka第三課

Flume 由三部分 Source Channel Sink 可以通過配置攔截器和Channel選擇器,來實現對數據的分流, 可以通過對channel的2個存儲容量的的設置,來實現對流速的控制 Kafka 同樣由三大部分組成 生產者 服務器 消費者 生產者負責發送數據給服務器 服務器存儲數據 消費者通過從服務器取…

【C++11保姆級教程】auto和decltype

文章目錄 前言總結一、auto1.初識auto關鍵字 2.auto使用二、decltype1.初識decltype2.使用decltype 總結 前言 在C11中引入了一些新的關鍵字和特性&#xff0c;其中包括auto和decltype。這兩個關鍵字提供了更方便、更靈活的類型推斷機制&#xff0c;使得代碼編寫更加簡潔和可讀…

shell 命令 tee {..}定義循環體

tee & {..}定義循環體 tee{..} 循環體 tee 作用&#xff1a;將標準輸出流內容復制文件中&#xff0c;同時控制臺信息依然會顯示。 > 和 >> 直接將標準輸出流內容重定向&#xff0c;從而導致控制臺無法看到輸出內容。 可選參數 -a &#xff1a;追加內容&#xff1…