Python解決“數字插入”問題

Python解決“數字插入”問題

  • 問題描述
  • 測試樣例
  • 解題思路
  • 代碼

問題描述

小U手中有兩個數字 a 和 b。第一個數字是一個任意的正整數,而第二個數字是一個非負整數。她的任務是將第二個數字 b 插入到第一個數字 a 的某個位置,以形成一個最大的可能數字。

你需要幫助小U找到這個插入位置,輸出插入后的最大結果。

測試樣例

樣例1:

輸入:a = 76543, b = 4
輸出:765443

樣例2:

輸入:a = 1, b = 0
輸出:10

樣例3:

輸入:a = 44, b = 5
輸出:544

樣例4:

輸入:a = 666, b = 6
輸出:6666

解題思路

這道題目綜合運用了字符串操作和貪心算法知識,是一道典型的字符串處理問題。題目要求將數字 b 插入到數字 a 的某個位置,以形成一個最大的可能數字。核心信息是找到一個插入位置,使得插入后的數字最大。我們可以通過遍歷 a 的每一位,嘗試將 b 插入到每一個可能的位置,并比較插入后的結果,選擇最大的那個。

解題過程:

  1. 字符串轉換:將數字 a 和 b 轉換為字符串形式,便于進行插入操作。
  2. 遍歷插入位置:遍歷 a 的每一位,嘗試將 b 插入到每一個可能的位置。
  3. 生成新數字:對于每一個插入位置,生成一個新的數字,并將其轉換為整數形式。
  4. 比較結果:比較新生成的數字與當前最大值,更新最大值。
  5. 返回結果:遍歷結束后,返回最大值。

時間復雜度:O(n),其中 n 是數字 a 的長度。我們需要遍歷 a 的每一位,嘗試插入 b,并生成新的數字。
空間復雜度:O(1),我們只使用了常數級別的額外空間來存儲中間結果。

代碼

def solution(a: int, b: int) -> int:# 將數字 a 和 b 轉換為字符串str_a = str(a)str_b = str(b)# 初始化最大結果為插入到最前面的情況max_result = int(str_b + str_a)# 遍歷字符串 a 的每一個位置for i in range(len(str_a) + 1):# 嘗試將 str_b 插入到位置 inew_str = str_a[:i] + str_b + str_a[i:]# 將新字符串轉換為整數new_num = int(new_str)# 比較并更新最大結果if new_num > max_result:max_result = new_numreturn max_resultif __name__ == '__main__':print(solution(76543, 4) == 765443)print(solution(1, 0) == 10)print(solution(44, 5) == 544)print(solution(666, 6) == 6666)

法2:

def solution(a:int, b:int)->int:a = str(a)b = str(b)maxVal = 0for i in range(len(a) + 1):val = int(a[:i] + b + a[i:])if val > maxVal:maxVal = val return maxValif __name__ == '__main__':print(solution(a = 76543, b = 4) == 765443)print(solution(a = 1, b = 0) == 10)print(solution(a = 44, b = 5) == 544)print(solution(a = 666, b = 6) == 6666)

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

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

相關文章

ubuntu部署ollama+deepseek+open-webui

ubuntu部署ollamadeepseekopen-webui 全文-ubuntu部署ollamadeepseekopen-webui 大綱 Ollama部署 安裝Ollama:使用命令apt install curl和curl -fsSL https://ollama.com/install.sh | sh ollama-v網絡訪問配置:設置環境變量OLLAMA_HOST0.0.0.0:11434&…

Java的Selenium常用的元素操作API

click 觸發當前元素的點擊事件 clear() 清空內容 sendKeys(...) 往文本框一類元素中寫入內容 getTagName() 獲取元素的的標簽名 getAttribute(屬性名) 根據屬性名獲取元素屬性值 getText() 獲取當前元素的文本值 isDisplayed() 查看元素是否顯示 get(String url) 訪…

洛谷題單3-P1035 [NOIP 2002 普及組] 級數求和-python-流程圖重構

題目描述 已知: S n 1 1 2 1 3 … 1 n S_n 1\dfrac{1}{2}\dfrac{1}{3}…\dfrac{1}{n} Sn?121?31?…n1?。顯然對于任意一個整數 k k k,當 n n n 足夠大的時候, S n > k S_n>k Sn?>k。 現給出一個整數 k k k&#xff0…

CMDB平臺(進階篇):3D機房大屏全景解析

在數字化轉型的浪潮中,數據中心作為企業信息架構的核心,其高效、智能的管理成為企業競爭力的關鍵因素之一,其運維管理方式也正經歷著革命性的變革。傳統基于二維平面圖表的機房監控方式已難以滿足現代企業對運維可視化、智能化的需求。樂維CM…

小白速通:Verilog流水線實現及時序分析

目錄 題目:時序分析:時鐘頻率為50MHz數據1: a10, b20, c30, d40, e2數據2: a5, b15, c25, d35, e3數據3: a8, b12, c16, d24, e4 流水線效率分析 題目: verilog中,y(abcd)*e,時鐘頻率為50Mhz,用流水線的形式…

【RK3588 嵌入式圖形編程】-SDL2-掃雷游戲-創建網格

創建網格 文章目錄 創建網格1、概述2、更新Globals.h文件3、創建單元4、創建網格5、傳遞事件6、清空單元7、反饋單元格已清除8、測試9、完整代碼10、總結在本文中,將詳細介紹如何構建一個二維的交互式掃雷單元格網格。 1、概述 在本文中,我們將專注于構建掃雷游戲的基礎結構…

高精度矢量內積計算方法 (單精度浮點, 超長矢量)

高精度矢量內積計算方法 (單精度浮點, 超長矢量) 對于單精度浮點類型的超長矢量(超過1億元素)內積計算,累加誤差確實是一個重要問題。以下是幾種減少誤差的方法: 1. Kahan求和算法 這是最常用的補償求和算法,可以有效減少累加誤差&#xf…

Java基礎:Logback日志框架

什么是日志 日志技術 可以將系統執行信息,方便的記錄到指定位置(控制臺,文件中,數據庫中) 可以隨時可以開關的形式控制日志的啟停,無需侵入到源代碼中去進行修改 LogBack日志框架 LogBack快速入門 logb…

MessageQueue --- RabbitMQ WorkQueue and Prefetch

MessageQueue --- RabbitMQ WorkQueue and Prefetch 什么是WorkQueue分發機制 --- RoundRobin分發機制 --- PrefetchSpring example use prefetch --- Fair Dispatch 什么是WorkQueue Work queues,任務模型。簡單來說就是讓多個消費者綁定到一個隊列,共同…

RNN模型與NLP應用——(9/9)Self-Attention(自注意力機制)

聲明: 本文基于嗶站博主【Shusenwang】的視頻課程【RNN模型及NLP應用】,結合自身的理解所作,旨在幫助大家了解學習NLP自然語言處理基礎知識。配合著視頻課程學習效果更佳。 材料來源:【Shusenwang】的視頻課程【RNN模型及NLP應用…

詳解AI采集框架Crawl4AI,打造智能網絡爬蟲

大家好,Crawl4AI作為開源Python庫,專門用來簡化網頁爬取和數據提取的工作。它不僅功能強大、靈活,而且全異步的設計讓處理速度更快,穩定性更好。無論是構建AI項目還是提升語言模型的性能,Crawl4AI都能幫您簡化工作流程…

從零開始玩python--python版植物大戰僵尸來襲

大家好呀,小伙伴們!今天要給大家介紹一個超有趣的Python項目 - 用pygame制作植物大戰僵尸游戲的進階版本。相信不少小伙伴都玩過這款經典游戲,今天我們就用Python來實現它,讓編程學習變得更加有趣!🌟 一、…

圖解AUTOSAR_SWS_FlashTest

AUTOSAR Flash Test模塊詳解 基于AUTOSAR 4.4.0規范的Flash測試模塊分析與圖解 目錄 概述 1.1 Flash Test模塊的作用 1.2 工作原理架構設計 2.1 整體架構 2.2 依賴關系狀態管理 3.1 狀態轉換圖 3.2 前臺與后臺測試模式配置結構 4.1 配置類圖 4.2 關鍵配置參數交互流程 5.1 序列…

【mongodb】mongodb的字段類型

目錄 1. 基本數據類型1.1 String1.2 Number1.3 Boolean1.4 Date1.5 Null1.6 ObjectId1.7 Array1.8 Binary Data1.9 Object 2. 特殊數據類型2.1 Regular Expression2.2 JavaScript2.3 Symbol2.4 Decimal1282.5 Timestamp2.6 MinKey/MaxKey2.7 DBPointer 3. 常用字段類型示例4. 注…

MySQL篇(五)MySQL主從同步原理深度剖析

MySQL篇(五)MySQL主從同步原理深度剖析 MySQL篇(五)MySQL主從同步原理深度剖析一、引言二、MySQL主從同步基礎概念主庫(Master)從庫(Slave)二進制日志(Binary Log&#x…

論文學習16:Learning Transferable Visual Models From Natural Language Supervision

代碼來源 Learning Transferable Visual Models From Natural Language Supervisionhttps://arxiv.org/pdf/2103.00020 模塊作用 當前最先進的計算機視覺系統被訓練用于預測一組固定的、預先定義的目標類別。這種受限的監督方式限制了它們的通用性和可用性,因為要…

[MySQL初階]MySQL(9)事務機制

標題:[MySQL初階]MySQL(9)事物機制 水墨不寫bug 文章目錄 一、認識事務1、多線程訪問數據庫出現的問題2、對CURD的限制是通過事務機制實現的3、事務的四個屬性4、哪些引擎支持事務 二、事務的提交與autocommit設置三、事務的隔離性和隔離級別…

spring-cloud-alibaba-nacos-config使用說明

一、核心功能與定位 Spring Cloud Alibaba Nacos Config 是 Spring Cloud Alibaba 生態中的核心組件之一,專為微服務架構提供動態配置管理能力。它通過整合 Nacos 的配置中心功能,替代傳統的 Spring Cloud Config,提供更高效的配置集中化管理…

SonarQube數據庫配置

SonarQube部署完成后,在瀏覽器地址欄輸入http://IP:9000可以進入登錄頁面,以本機運行為例,地址為http://127.0.0.1:9000/,默認登錄名:admin,登錄密碼也是admin。登錄后會要求設置密碼: 按要求設…

醫藥檔案區塊鏈系統

1. 醫生用戶模塊?? ??目標用戶??:醫護人員 ??核心功能??: ??檢索檔案??:通過關鍵詞或篩選條件快速定位患者健康檔案。??請求授權??:向個人用戶發起檔案訪問權限申請,需經對方確認。??查看檔案?…