(杭電 1097)A hard puzzle

来源:https://www.cnblogs.com/cafu-chino/archive/2018/12/05/10068979.html
-Advertisement-
Play Games

A hard puzzle Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 51690 Accepted Submission(s): 18916 ...


A hard puzzle

Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 51690 Accepted Submission(s): 18916

Problem Description

lcy gives a hard puzzle to feng5166,lwg,JGShining and Ignatius: gave a and b,how to know the a^b.everybody objects to this BT problem,so lcy makes the problem easier than begin.
this puzzle describes that: gave a and b,how to know the a^b's the last digit number.But everybody is too lazy to slove this problem,so they remit to you who is wise.

Input

There are mutiple test cases. Each test cases consists of two numbers a and b(0<a,b<=2^30)

Output

For each test case, you should output the a^b's last digit number.

Sample Input

7 66
8 800

Sample Output

9
6

這道題給把我整的自閉了(´-ι_-`)

一開始根本不知道快速冪的演算法,總是會TLE

(這是我之前寫的暴力代碼,直接起飛233333)

#include <stdio.h>

int main() {
    int a,b,t;
    while(scanf("%d%d",&a,&b) != EOF) {
    t=a;
    if(b > 1)
        for(int i=2; i <= b; i++) {
            t=t*a;
            t=t%10;
        }
    printf("%d\n",t);
    }
    return 0;
}

後來Dalao給我講了講快速冪,在迷茫之中終於搞懂了(順便來一句,快速冪真相);
(以下為快速冪的大體解釋)

int ksm(int a,int b)
{
    int ans=1;
    while(b)
    {
        if(b & 1)
            ans=ans*a;
        a=a*a;
        b=b >> 1;
    }
    return ans;
}
/*
總體上來講就是化成二進位後用二分法思想將一個大冪次分解為若幹個小冪次:
'a^n=[(a)*(二進位最後一位)]*[(a^2)*(二進位倒數第二位)]*[(a^4)*(二進位倒數第三位)]*[(a^8)*(二進位倒數第四位)]*[(a^16)*(二進位倒數第四位)]*[(a^32)*······';
*/
  //程式運行以'a^13'為例:
  //'13'轉化二進位'1101';
**//位運算(等價於'a%2')取二進位最後一位;
  //為'1',把二分開的項運算出來放入結果,否則只進行二分
  //位移(比如第一步'1 1 0 1'位移就相當於去掉二進位最後一位)'1 1 0 1';
  //                    ^                                 ^
  //返回**步進行,直到'b == 0';
  //據二分法,得'a^13=[(a^1)*1]*[(a^2)*0]*[(a^4)*1]*[a(a^8)*1]';

由快速冪可以得出題解(因為ans計算時要考慮溢出問題所以改用long long變數儲存)

樣例答案(剛剛接觸點c++,有點亂。。。)

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

long long ksm(long long a,long long b)  //快速冪
{
    long long ans=1;
    while(b)
    {
        if(b & 1)
            ans=ans*a%10;
        a=a*a%10;
        b=b >> 1;
    }
    return ans;
}

int main()
{
    long long a,b;
    while(scanf("%lld%lld",&a,&b) != EOF)
        printf("%lld\n",ksm(a,b));
    return 0;
}

(ps:日後我會填補快速乘的坑 ~ ヾ(=・ω・=)o)


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • js獲取月的第幾周和年的第幾周。 來自:https://blog.csdn.net/nu11_/article/details/53910724?utm_source=blogxgwz4 ...
  • 此文介紹好用的數據介面測試工具 Postman,能幫助您方便、快速、統一地管理項目中使用以及測試的數據介面。 ...
  • 2016-10-02 20:19:51 其實 設計模式 有很多人都談過,我自己認為沒有必要再去造輪子之類的,想了想算了,還是開個主題,用作自己以後查找方便。 市面上關於設計模式的書籍琳琅滿目,我自己推薦幾個(如果以後還有,會繼續在這邊文章添加): 下麵列舉的書籍都是豆瓣的鏈接,如果想買書的話,自己去 ...
  • 註解: @Cacheable // 在方法調用前,先在緩存中去找,若沒有,則在方法調用結束後,放到緩存中,屬性cacheNames、key。key中可以使用SpEl表達式,如#id,#root.args[0] @CachePut // 每次調用方法,都會刷新緩存。預設是調用方法後刷新;屬性可以使用 ...
  • 狀態模式(State Pattern)又稱為狀態對象模式,該模式允許一個對象在其內部狀態改變時改變其行為。 定義: 當一個對象內部狀態改變時允許改變行為,這個對象看起來像改變了其類型。 狀態模式的核心是封裝,狀態的變更引起行為的變動,從外部看來就好像該對象對應的類發生改變一樣。 狀態模式的類圖如下所 ...
  • 題意 "題目鏈接" 系統中有兩個數$(a, b)$,請使用$62$以內次詢問來確定出$(a, b)$ 每次可以詢問兩個數$(c, d)$ 若$a \oplus c b \oplus d$返回$1$ 若$a \oplus c = b \oplus d$返回$0$ 若$a \oplus c define ...
  • 前言 開心一刻 著火了,他報警說:119嗎,我家發生火災了。 119問:在哪裡? 他說:在我家。 119問:具體點。 他說:在我家的廚房裡。 119問:我說你現在的位置。 他說:我趴在桌子底下。 119:我們怎樣才能到你家? 他說:你們不是有消防車嗎? 119說:燒死你個傻B算了。 路漫漫其修遠兮, ...
  • HashMap 和 Hashtable 是 Java 開發程式員必須要掌握的,也是在各種 Java 面試場合中必須會問到的。 但你對這兩者的區別瞭解有多少呢? 現在,棧長我給大家總結一下,或許有你不明朗的地方,在棧長的指點下都會撥開迷霧見晴天。 1、線程安全 Hashtable 是線程安全的,Has ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...