目錄
概念理解
演算法說明
範例
輸出
測試案例範例
時間與空間複雜度
結論
首頁 後端開發 C++ 使一個數能被4整除,最少需要刪除的數字個數

使一個數能被4整除,最少需要刪除的數字個數

Sep 15, 2023 pm 01:49 PM
整除 刪除 數學運算

使一個數能被4整除,最少需要刪除的數字個數

在本文中,我們將探討一個有趣的計算問題 - 「使一個數字能被 4 整除所需刪除的最少位數」。這個問題是編碼競賽和基於演算法的面試中的常見問題,為提高您的問題解決能力提供了極好的練習。

首先,讓我們理解問題陳述:我們有一個數字,我們的任務是刪除最少數量的數字,使得剩餘的數字能被 4 整除。

概念理解

問題出在數論領域。需要理解的一個關鍵事實是,當且僅當一個數字的最後兩位數字能被 4 整除時,數字才能被 4 整除。這一事實對於解決我們的問題至關重要。

演算法說明

解決這個問題的演算法涉及以下步驟 -

  • 將數字轉換為字串。

  • 從字串結尾開始檢查最後兩個字元組成的數字是否能被 4 整除。

  • 如果是,則傳回刪除的位數。如果不是,則刪除最後一個字元並增加計數。

  • 重複此動作,直到數字能被 4 整除或只剩下一位數字。

範例

這是該演算法的 C 實作 -

#include<bits/stdc++.h>
using namespace std;

int minRemovals(string num) {
   int n = num.size();
   int count = 0;
   
   for (int i = n - 1; i > 0; i--) {
      if ((num[i] - '0' + (num[i - 1] - '0') * 10) % 4 == 0) {
         return count;
      }
      count++;
   }
   
   return n - 1;
}

int main() {
   string num = "1351";
   cout << "Minimum number of digits to be removed to make the number divisible by 4 is: ";
   cout << minRemovals(num) << endl;
   
   return 0;
}
登入後複製

輸出

Minimum number of digits to be removed to make the number divisible by 4 is: 3
登入後複製

在 minRemovals 函數中,我們將計數器計數初始化為 0,這將追蹤刪除的位數。然後我們從數字(字串)的末尾開始迭代,檢查最後兩位數字組成的數字是否能被 4 整除。如果是,我們返回計數;否則,我們返回計數。如果沒有,我們增加計數並繼續下一次迭代。

main 函數作為我們程式的入口點,我們在其中定義輸入數字並列印要刪除的最小位數,以使數字能被 4 整除。

測試案例範例

我們以號碼 1351 為例。當我們檢查最後兩位數字(51)時,我們發現它不能被 4 整除。因此,我們刪除最後一位數字(1),得到數字 135。我們再次檢查,發現最後兩位數字(35) ) 仍然不能被 4 整除。因此,我們刪除最後一位數字 (5),留下數字 13。最後兩位數字 (13) 不能被 4 整除,所以我們刪除最後一位數字 (3)。現在,我們只剩下數字 1,它不能被 4 整除,但我們無法刪除更多的數字。因此,需要刪除的最少位數為 3。

時間與空間複雜度

此演算法的時間複雜度為O(n),其中n是數字的位數。空間複雜度為 O(1),因為我們在演算法中沒有使用任何額外的資料結構。

結論

在本文中,我們深入研究了一個常見的計算問題 - 確定使數字能被 4 整除所需刪除的最小位數。我們利用數論的關鍵見解開發了一個簡潔的 C 解決方案。

以上是使一個數能被4整除,最少需要刪除的數字個數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
威爾R.E.P.O.有交叉遊戲嗎?
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

inetpub資料夾可以刪除嗎?快速刪除C盤inetpub資料夾的方法 inetpub資料夾可以刪除嗎?快速刪除C盤inetpub資料夾的方法 Mar 13, 2024 pm 02:00 PM

  電腦C盤發現有個inetpub資料夾佔用極大的內存,這個inetpub是什麼資料夾?可以直接刪除嗎?其實inetpub是IIS服務端的一個資料夾,IIS全名為InternetInformationServices,也就網路資訊服務,是可以搭建網站、調試網站用的,如果不需要的話,可以將其卸載掉。  具體方法如下:  1、右鍵點選開始選單,選擇「程式與功能」。  2、開啟後點選「啟用或關閉Windows功能」。  3、在Windows功能清單中,取消勾選II

小紅書筆記怎麼刪除 小紅書筆記怎麼刪除 Mar 21, 2024 pm 08:12 PM

小紅書筆記怎麼刪除?在小紅書APP中是可以編輯筆記的,多數的用戶不知道小紅書筆記如何的刪除,接下來就是小編為用戶帶來的小紅書筆記刪除方法圖文教程,有興趣的用戶快來一起看看吧!小紅書使用教學小紅書筆記怎麼刪除1、先打開小紅書APP進入到主頁面,選擇右下角【我】進入到專區;2、之後在我的專區,點擊下圖所示的筆記頁面,選擇要刪除的筆記;3、進入到筆記頁面,右上角【三個點】;4、最後下方會展開功能欄,點選【刪除】即可完成。

微信拉黑再刪除永久加不上是真的嗎 微信拉黑再刪除永久加不上是真的嗎 Apr 08, 2024 am 11:41 AM

1.首先,拉黑再刪除永久加不上是假的,拉黑刪除後想要再加對方,只要對方同意即可。 2.如果用戶將某人封鎖,對方將無法向用戶發送訊息、查看用戶的朋友圈、與用戶通話。 3.封鎖並不意味著將對方從用戶的微信聯絡人清單中刪除。 4.如果用戶在封鎖後又將對方從用戶的微信聯絡人清單中刪除,那麼在刪除後是沒有辦法恢復的。 5.如果用戶想再加入對方為好友,需要對方同意並重新新增使用者。

Go語言中的整除運算及餘數計算方法詳解 Go語言中的整除運算及餘數計算方法詳解 Mar 23, 2024 pm 06:00 PM

Go語言中的整除運算及餘數計算方法詳解在Go語言中,整除運算和餘數計算是常見的數學運算運算。本文將介紹如何在Go語言中進行整除運算和餘數計算,同時提供具體的程式碼範例。整除運算在Go語言中,整除運算使用的是/符號。整除運算指的是取兩個數相除的商,結果為整數部分,即忽略小數部分,不會進行四捨五入操作。整除運算通常用於計算除法後的整數商。程式碼範例:package

found.000是什麼資料夾? found.000資料夾可以刪除嗎? found.000是什麼資料夾? found.000資料夾可以刪除嗎? Mar 13, 2024 pm 08:52 PM

  日常使用電腦的過程中,可能會收到found.000檔案遺失損壞的錯誤提示,這個found.000是什麼資料夾?如果沒有用的話,可以刪除嗎?既然有這麼多人不認識這個文件,下面小編就來跟大家仔細說說found.000文件夾吧~  一、found.000是什麼文件夾當電腦出現因非法關機導致的文件部分或全部丟失時,可以在位於系統分割區中指定目錄下找到名為「found.000」的特殊資料夾及其內部所包含的以「.chk」為副檔名的檔案。  這個「fo

小紅書發怎麼刪除?發布刪除怎麼恢復? 小紅書發怎麼刪除?發布刪除怎麼恢復? Mar 21, 2024 pm 05:10 PM

小紅書作為一個受歡迎的社群電商平台,吸引了大量用戶分享生活點滴和購物心得。有時候我們可能會不經意發布一些不合適的內容,這時候需要及時刪除,這樣可以更好地維護個人形像或遵守平台規定。一、小紅書發布怎麼刪除? 1.登入小紅書帳號,進入個人首頁。 2.在個人主頁下方,找到「我的創作」選項,點選進入。 3.在「我的創作」頁面,你可以看到所有發布的內容,包括筆記、影片等。 4.找到需要刪除的內容,點選右側的「...」按鈕。 5.在彈出的選單中,選擇“刪除”選項。 6.確認刪除後,該條內容將從你的個人主頁和公開頁面消失

hiberfil.sys是什麼檔案? hiberfil.sys可以刪除嗎? hiberfil.sys是什麼檔案? hiberfil.sys可以刪除嗎? Mar 15, 2024 am 09:49 AM

  最近有很多網友問小編,hiberfil.sys是什麼文件? hiberfil.sys佔用了大量的C碟空間可以刪除嗎?小編可以告訴大家hiberfil.sys檔是可以刪除的。下面就來看看詳細的內容。 hiberfil.sys是Windows系統中的隱藏文件,也是系統休眠文件。通常儲存在C盤根目錄下,其大小與系統安裝記憶體大小相當。這個檔案在電腦休眠時被使用,其中包含了當前系統的記憶體數據,以便在恢復時快速恢復到先前的狀態。由於其大小與記憶體容量相等,因此它可能會佔用較大的硬碟空間。  hiber

抖音聊天記錄怎麼徹底消除乾淨 抖音聊天記錄怎麼徹底消除乾淨 May 07, 2024 am 11:14 AM

1.開啟抖音app,點選介面底部的【訊息】,點選需要刪除的聊天對話入口。 2.長按任一聊天記錄,點選【多選】,勾選想要刪除的聊天記錄。 3.點選右下角的【刪除】按鈕,在彈出的視窗中選擇【確認刪除】即可將這些記錄永久刪除。

See all articles