洛谷P4133 [BJOI2012]最多的方案(記憶化搜索)

来源:https://www.cnblogs.com/zwfymqz/archive/2018/09/18/9667047.html
-Advertisement-
Play Games

題意 題目鏈接 求出把$n$分解為斐波那契數的方案數,方案兩兩不同的定義是分解出來的數不完全相同 Sol 這種題,直接爆搜啊。。。 打表後不難發現$<=1e18$的fib數只有88個 最先想到的應該是直接把$n$加入到搜索狀態里,然後枚舉能被分成哪些 但是這樣分解出來的數可能會有重覆的,因此我們還要 ...


題意

題目鏈接

求出把$n$分解為斐波那契數的方案數,方案兩兩不同的定義是分解出來的數不完全相同

Sol

這種題,直接爆搜啊。。。

打表後不難發現$<=1e18$的fib數只有88個

最先想到的應該是直接把$n$加入到搜索狀態里,然後枚舉能被分成哪些

但是這樣分解出來的數可能會有重覆的,因此我們還要把當前考慮到第幾個數也加入到狀態里。

不難得到以下代碼

但是很顯然會T飛。

優化一下,只考慮當前的fib數對答案的貢獻,

也就是搜兩種情況:

1、用該數分解

2、不用該數分解

代碼是這樣的

然而還是會T飛。

繼續剪枝。

根據斐波那契的性質$\sum_{i = 1}^n f_i = f_{n+2} -1$

因此我們想要用前$ti - 1$個合成$x$,必須滿足$x < f_{ti+1}$。

然後就A了qwq

// luogu-judger-enable-o2
#include<cstdio>
#include<iostream>
#include<map>
#define Pair pair<int, int>
#define MP(x, y) make_pair(x, y)
#define fi first
#define se second 
#define int long long
#define ull unsigned long long  
using namespace std;
const int MAXN = 1e5 + 10;
inline int read() {
    char c = getchar(); int x = 0, f = 1;
    while(c < '0' || c > '9') {if(c == '-') f = -1; c = getchar();}
    while(c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
    return x * f;
}
int f[MAXN], tot, lim, dp[MAXN], N;
map<Pair, int> mp;
int dfs(int x, int ti) {
    if(mp.find(MP(x, ti)) != mp.end()) return mp[MP(x, ti)];
    if(x == 0) return 1;
    int ans = 0;
    /*for(int i = ti; i >= 1; i--) {
        if(x - f[i] >= 0) ans += dfs(x - f[i], i - 1);
        //else break;
    }*/
    if(x - f[ti] >= 0) ans += dfs(x - f[ti], ti - 1);
    if(x < f[ti + 1]) 
        ans += dfs(x, ti - 1);
    
    return mp[MP(x, ti)] = ans;
}
main() {
    lim = 1e18;
    f[1] = 1; f[2] = 2;
    for(int i = 3; i; i++) {
        f[i] = f[i - 1] + f[i - 2];
        if(f[i] > lim) {tot = i; break;}
    }
    N = read();
    //dp[0] = 1;
    cout << dfs(N, tot - 1);
    return 0;
}

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

-Advertisement-
Play Games
更多相關文章
  • iOS10 語音播報填坑詳解(解決串列播報中斷問題) 在來聊這類需求的解決方案之前,咱們還是先來聊一聊這類需求的真實使用場景:語音播報。語音播報需求運用最為廣泛的應該是收銀對賬了,就類似於支付寶、微信、收錢吧等的收款語音提示一樣。在iOS 10 之前,蘋果沒有提供通知擴展類的時候,如果想要實現殺進程 ...
  • Appium是一個開源測試自動化框架,用於本機、混合和移動Web應用程式,它使用WebDriver 協議驅動 iOS、Android和Windows應用程式。 ...
  • 這段時間開發了一個微信小程式,雖然小程式的導航API 官方文檔寫得很詳細,但是在具體開發過程中還是會遇到很多不明白,或者一時轉不過彎的地方。 1、頁面切換傳參,參數讀取 1.1 wx.navigateTo(Object) 功能:保留當前頁面,跳轉到應用內的某個頁面,但是不能跳到 tabbar 頁面。 ...
  • 開發現狀 隨著技術的發展,移動開發設備遍地開花,各種各樣的移動設備不如人們的家庭。移動設備不局限於手機、IPA等設備。由於Android開源,可在條款允許範圍內修改代碼二次開發,結合物聯網技術的迅速普及,各種Android應用進入物聯網之中。智能手機、智能電視等各種擁有交互需求的設備大部分都是基於A ...
  • 概述 ScreenMatch是根據你的需要,生成需要適配的尺寸的文件,手機會根據屏幕相關參數自動尋找合適的尺寸文件 添加插件 如圖,打開Android Studio的Settings設置,找到Plugins,點擊Browse Repositories,在彈出的輸入框里填入screenMatch,就可 ...
  • https://www.cnblogs.com/chenqf/p/6386163.html 前言 Http 緩存機製作為 web 性能優化的重要手段,對於從事 Web 開發的同學們來說,應該是知識體系庫中的一個基礎環節,同時對於有志成為前端架構師的同學來說是必備的知識技能。但是對於很多前端同學來說, ...
  • 1)名字VS值 名字和記憶體(存儲)位置相關聯。 名字—(環境)———>位置——(狀態)——>值 這兩個映射都在隨著程式的運行而改變。 2)環境VS狀態 環境是指一個名字到存儲位置映射,也可以說是名字到變數(左值)的映射,環境的改變需要遵守語言的作用於與規則; 狀態是一個從記憶體位置到它的值的映射,即把 ...
  • 上篇介紹了Util的開發環境,並讓你把Demo運行起來。本文將介紹該Demo的前端Angular運行機制以及目錄結構。 目錄結構 在VS上打開Util Demo,會看見如下的目錄結構。 現代前端通常採用VS Code開發,不過我們為了使用TagHelper,需要採用VS開發,這為你提供了更多的選擇。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...