【算法】快速冪

算法-快速冪


前置知識
  • 倍增

思路

我們要求 a n a^n an
簡單的方法是 a n = a n ? 1 ? a a^n=a^{n-1}\cdot a an=an?1?a
但是我們不妨使用倍增的思想
2 ∣ n 2\mid n 2n,則 a n = a n 2 2 a^n={a^{\frac n 2}}^2 an=a2n?2
2 ? n 2\nmid n 2?n,則 a n = a ? n 2 ? 2 ? a a^n={a^{\lfloor{\frac n 2}\rfloor}}^2\cdot a an=a?2n??2?a


算法參數
  • 時間復雜度: O ( log ? n ) O(\log n) O(logn)
  • 空間復雜度: O ( 1 ) O(1) O(1)

實現代碼
  • 基礎版本
int pow(int x,int y){int res=1;while (y){if (y&1) res=res*x;x=x*x;y>>=1;}return res;
}
  • 取模版本
int pow(int x,int y,int M){int res=1;while (y){if (y&1) res=res*x%M;x=x*x%M;y>>=1;}return res;
}

練習
  • P1226

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

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

相關文章

【AI】設計師人人必備的Ai課程,AIGC實戰教學

課程介紹 專為設計師定制的AI繪畫視覺課程,包含排版、插畫、海報和動漫等。共43節課程,2.06G視頻,教授AI應用技巧,提高設計效率和質量。內容涵蓋詞生圖方法、AI風格設計等,幫助學員在設計領域取得成就。 1_01-ai課程…

Flutter 中的 SliverPersistentHeader 小部件:全面指南

Flutter 中的 SliverPersistentHeader 小部件:全面指南 Flutter 是一個功能強大的 UI 工具集,用于創建美觀、高性能的移動和 web 應用。在 Flutter 的滾動組件中,SliverPersistentHeader 是一個特殊的組件,它用于在 CustomScroll…

zustand修改一個object對象的嵌套屬性,會觸發更新嗎

在 Zustand 狀態管理庫中,當使用 set 方法來更新一個對象的嵌套屬性時,并不會觸發整個對象的更新操作。相反,Zustand 使用了淺比較來檢測狀態的變化,只有當狀態內部的引用發生變化時,才會觸發更新操作。 因此&#xf…

jrt落地deepin

經過昨天一晚上的努力,把deepin和win10的雙系統安裝好了。同時把jrt開發需要的svn,jdk,idea安裝好里,代碼也checkout里。 首先安裝系統碰到安裝deepin后啟動時候無法選擇win10,在宏偉兄幫助下找到資料執行sudo update-grub解決了。 然后程…

糖果促銷【百度之星】/思維

糖果促銷 思維 大佬的解法&#xff1a; #include<bits/stdc.h> using namespace std; typedef long long ll; int main() {ll t;cin>>t;for(int i0;i<t;i){ll p,k;cin>>p>>k;if(k0) cout<<0<<endl;else{k-(k-1)/p;cout<<k<…

v-for中key的作用

v-for中key的作用 例如我們用v-for渲染一個列表[1, 2, 4 ,5]&#xff0c;然后在中間插入一個3變成[1,2,3,4,5]。v-for寫了key和沒有寫key&#xff0c;Vue是怎么處理的呢&#xff1f; Vue對有key的會調用patchKeyedChildren方法&#xff1b;沒有key的調用patchUnkeyedChildren方…

Vue3 -Computed計算屬性

前言&#xff1a; Computed屬性屬于Vue3中的響應式核心(與之共同說明的還有ref&#xff0c;reactive&#xff0c;watch...) 接受一個 getter 函數&#xff0c;返回一個只讀的響應式 ref 對象。該 ref 通過 .value 暴露 getter 函數的返回值。它也可以接受一個帶有 get 和 set…

AI搜索,圍攻百度

圖片&#xff5c;電影《雙子殺手》截圖 ©自象限原創 作者丨程心 國內的大模型廠商落地C端&#xff0c;都盯上了AI搜索。 隨著5月30號&#xff0c;騰訊宣布推出基于混元大模型的APP“騰訊元寶”&#xff0c;并基于搜狗搜索引擎&#xff0c;上線AI搜索功能。幾乎當下所有…

【Qt】Qt Style Sheets (QSS) 指南:打造個性化用戶界面

文章目錄 前言&#xff1a;1. QSS 選擇器2. 子控件選擇器&#xff08;Sub-Controls&#xff09;2.1. 示例&#xff1a;給 QComboBox 給下拉按鈕加上圖標2.2. 示例&#xff1a;修改進度條顏色 3. 偽類選擇器3.1. 代碼示例: 設置按鈕的偽類樣式.3.2. 代碼示例: 使用事件方式實現同…

數模混合芯片設計中的修調技術是什么?

一、修調目的 數模混合芯片需要修調技術主要是因為以下幾個原因&#xff1a; 工藝偏差&#xff08;Process Variations&#xff09;&#xff1a; 半導體制造過程中存在不可避免的工藝偏差&#xff0c;如晶體管尺寸、閾值電壓、電阻和電容值等&#xff0c;這些參數的實際值與…

阿里云計算之linux入門命令學習筆記(三)

Linux 提供了豐富的命令行工具&#xff0c;用于系統管理、文件操作、網絡管理、進程控制等。以下是一些常用的 Linux 命令及其簡要說明&#xff1a; 切換用戶 su 命令 su (substitute user) 命令用于切換用戶。 su - username # 切換到指定用戶&#xff0c;并加載…

【學習Day5】操作系統

?&#x1f3fb;記錄學習過程中的輸出&#xff0c;堅持每天學習一點點~ ??希望能給大家提供幫助~歡迎點贊&#x1f44d;&#x1f3fb;收藏?評論?&#x1f3fb;指點&#x1f64f; 學習編輯文章的時間不太夠用&#xff0c;先放思維導圖&#xff0c;后續復習完善細節。

【C++】6-6 你好,輸出的格式控制(對齊)

6-6 你好&#xff0c;輸出的格式控制&#xff08;對齊&#xff09; 分數 10 全屏瀏覽 切換布局 作者 向訓文 單位 惠州學院 完善程序&#xff1a;按示例格式輸出所有分數&#xff0c;分數保留2位小數&#xff0c;分數左對齊輸出在兩根豎線之間 裁判測試程序樣例&#xff1…

vsto與vba的優缺點

VSTO&#xff08;Visual Studio Tools for Office&#xff09;和VBA&#xff08;Visual Basic for Applications&#xff09;都是用于擴展和定制Microsoft Office應用程序的開發工具。它們各有優缺點&#xff0c;適用于不同的場景。以下是對它們優缺點的詳細比較&#xff1a; V…

基于jeecgboot-vue3的Flowable流程-我的任務(三)

因為這個項目license問題無法開源&#xff0c;更多技術支持與服務請加入我的知識星球。 這一部分主要講我的任務里的詳情&#xff0c;看流程情況 1、主要調用record/index.vue&#xff0c;調用參數如下&#xff1a; /*** 詳情*/function handleDetail(record: Recordable) {c…

構建一個文字冒險游戲:Python 編程實戰

在本文中&#xff0c;我們將探索如何使用 Python 創建一個簡單的文字冒險游戲。通過這個項目&#xff0c;你將了解到基礎的編程技術&#xff0c;包括條件語句、函數和基本的用戶輸入處理&#xff0c;同時也能體會到文本游戲的魅力和設計的挑戰。 項目概述 文字冒險游戲是一種…

python-最接近target的值

【問題描述】&#xff1a;給定一個數組&#xff0c;在數組中找到兩個數&#xff0c;使它們的和最接近目標值的值但不超過目標值&#xff0c;然后返回它們的和。 【問題示例】&#xff1a;輸入target15,array[1,3,5,11,7],輸出14&#xff0c;31114。 完整代碼如下&#xff1a; …

童夢奇緣,味你而來 —— 蒙自源六一兒童節特別活動

在六月的暖陽下&#xff0c;孩子們的歡笑聲如同最美妙的樂章&#xff0c;奏響了夏日的序曲。在這個充滿童真與夢想的季節&#xff0c;蒙自源精心策劃了一場別開生面的六一兒童節特別活動&#xff0c;邀請每一位小朋友和大朋友&#xff0c;一同踏上一段奇妙的味蕾之旅。 從5月25…

【深入學習Redis丨第二篇】Redis集群部署詳解

文章目錄 Redis集群部署Redis4 Cluster部署 Redis集群部署 1 Redis各節點部署 使用源碼安裝各節點&#xff0c;不過與非cluster方式不同的是&#xff0c;配置文件中需啟動cluster相關的配置。 因本次為偽分布式部署&#xff0c;生產環境部署時建議至少3臺機器部署&#xff0…

列表和列表項

一、列表和列表項簡介 列表是 FreeRTOS 中的一個數據結構&#xff0c;列表被用來跟蹤 FreeRTOS中的任務&#xff08;任務當前的狀態&#xff09;&#xff0c;列表項就是存放在列表中的項目 列表相當于鏈表&#xff0c;列表項相當于節點&#xff0c;FreeRTOS 中的列表是一個雙向…