Recursive sequence(HDU5950 矩陣快速冪)

来源:https://www.cnblogs.com/sykline/archive/2018/10/10/9769878.html
-Advertisement-
Play Games

題目: Farmer John likes to play mathematics games with his N cows. Recently, they are attracted by recursive sequences. In each turn, the cows would sta ...


題目:HDU5954

題意:

奶牛報數,先給兩個數a和b,分別是f[n-2],f[n-1],之後每頭奶牛i報數為f[i-1] + 2 * f[i-2] + i^4;給出n,求din頭奶牛要報的數字,對2147493647取餘。

思路:

看到這個式子知道這是一個矩陣快速冪,然後開始推式子,在我給隊友寫出平方差公式來隊友看到楊輝三角形式後後,就去推7*7的矩陣快速冪了,但因為剛剛學這個,但結束就掛死在這個題上了。

式子:

 

 之後就是套裸的矩陣快速冪就好了,個人感覺做題補題真的是長知識最快的方法啊。補題的時候自己直接用矩陣來寫麻煩的要死,就把矩陣放在一個結構體中,順便方便很多。

代碼:

#include <iostream>
#include <cstring>
#include <cstdio>
#include <algorithm>
#include <queue>
#include <map>
#include <set>
#include <vector>
using namespace std;
typedef long long ll;
const ll MOD = 2147493647;
struct Maxt {
    ll mp[8][8];
    Maxt() {
        for(int i = 1; i<=7; i++) {
            for(int j = 1; j<=7; j++) {
                mp[i][j] = 0;
            }
        }
    }
} fp,tmp;
int n,a,b,T;
int read() {
    int res = 0;
    char op;
    op = getchar();
    if(op>='0' && op<='9') {
        res = op-'0';
        op = getchar();
    }
    while(op>='0' && op<='9') {
        res = res*10 + op-'0';
        op = getchar();
    }
    return res;
}

void init() {
    for(int i = 1; i<=7; i++) {
        for(int j =1; j<=7; j++) {
            fp.mp[i][j] = 0;
            tmp.mp[i][j] = 0;
        }
    }
    fp.mp[1][1] = 1,fp.mp[2][1] = 1,fp.mp[2][2] = 1,fp.mp[7][6] = 1;
    fp.mp[3][1] = 1,fp.mp[3][2] = 2,fp.mp[3][3] = 1,fp.mp[4][1] = 1;
    fp.mp[4][2] = 3,fp.mp[4][3] = 3,fp.mp[4][4] = 1,fp.mp[5][1] = 1;
    fp.mp[5][2] = 4,fp.mp[5][3] = 6,fp.mp[5][4] = 4,fp.mp[5][5] = 1;
    fp.mp[6][5] = 1,fp.mp[6][6] = 1,fp.mp[6][7] = 2;
    tmp.mp[1][1] = 1,tmp.mp[2][1] = 3,tmp.mp[3][1] = 9,tmp.mp[4][1] = 27,tmp.mp[5][1] = 81,tmp.mp[6][1] = b,tmp.mp[7][1] = a;
}

Maxt Maxtcalc(const Maxt& a,const Maxt& b) {
    Maxt t;
    for(int i = 1; i<=7; i++) {
        for(int j = 1; j<=7; j++) {
            t.mp[i][j] = 0;
            for(int k = 1; k<=7; k++) {
                t.mp[i][j] = (t.mp[i][j] + (a.mp[i][k]*b.mp[k][j]) % MOD) % MOD;
            }
        }
    }
    return t;
}

Maxt qcalc(int x,Maxt s) {
    Maxt tmp;
    for(int i = 1; i<=7; i++) {
        tmp.mp[i][i] = 1;
    }
    while(x) {
        if(x&1) {
            tmp = Maxtcalc(tmp, s);
        }
        s = Maxtcalc(s, s);
        x>>=1;
    }
    return tmp;
}

int main() {
    T = read();
    while(T--) {
        n = read();
        a = read();
        b= read();
        if(n == 1) {
            printf("%d\n",a);
            continue;
        }
        if(n == 2) {
            printf("%d\n",b);
            continue;
        }
        if(n == 3) {
            printf("%d\n",81+2*a+b);
            continue;
        }
        n = n-2;
        init();
        fp = qcalc(n,fp);
        Maxt ans =  Maxtcalc(fp, tmp);
        printf("%lld\n",ans.mp[6][1]%MOD);
    }
    return 0;
}
/*
樣例輸入:
2
3 1 2
4 1 10
樣例輸出:
85
369
*/
View Code

 


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

-Advertisement-
Play Games
更多相關文章
  • 在賬戶表的基礎上,我新建了一個賬戶account_session表,用來記錄登錄賬戶的account_id和最新一次登錄成功用戶的session_id,然後首先要修改登錄方法:每次登錄成功後,要將登錄用戶信息寫入Session的同時還要更新account_session表裡相應賬戶的session_ ...
  • 本次和大家分享的主要是docker搭建es和springboot操作es的內容,也便於工作中或將來使用方便,因此從搭建es環境開始到代碼插入信息到es中;主要節點如下: 1.elasticsearch啟動 我本機環境是windows10,要掛載es的配置文件需要在本機上創建配置文件,因此這裡創建配置 ...
  • 直接gdb pgname 參數1 這種方式,參數1是不會帶到gdb里的 1,首先啟動程式 2,設置程式的參數 ...
  • 在上文 設計一個百萬級的消息推送系統 中提到消息流轉採用的是 Kafka 作為中間件。 其中有朋友咨詢在大量消息的情況下 Kakfa 是如何保證消息的高效及一致性呢? ...
  • spring-boot-starter-web:spring-boot-starter:spring-boot場景啟動器;幫我們導入了web模塊 正常運行所依賴的組件; Spring Boot將所有的功能場景都抽取出來,做成一個個的starters(啟動器), 只需要在項目裡面引入這些starter ...
  • springboot多數據源配置,代碼如下 配置文件 application.properties 測試代碼如下 在運行的時候會出現如下異常問題,運行失敗,報出java.lang.IllegalArgumentException: jdbcUrl is required with driverCla ...
  • 1.Comparable介面 這個介面顧名思義就是用於排序的,如果要對某些對象進行排序,那麼該對象所在的類必須實現 Comparabld介面。Comparable介面只有一個方法CompareTo(),這個方法可以看做是指定的排序規則。 內置類已經實現了CompareTo方法,例如long 小於返回 ...
  • 關於出現 idclass mapping 運行錯誤 @IdClass 註釋通常用於定義包含複合鍵id的Class。即多個屬性的關鍵複合。 @IdClass(CountrylanguageEntityPK.class) 則CountrylanguageEntityPK如下所示: 使用註解 @IdCla ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...