动态规划(选择)

链接:登录---专业IT笔试面试备考平台_牛客网

来源:牛客网

作为队伍的核心,forever97很受另外两个队友的尊敬。

Trote_w每天都要请forever97吃外卖,但很不幸的是宇宙中心forever97所在的学校周围只有3家forever97爱吃的外卖。

如果Trote_w给forever97买了别家的外卖,forever97就会大喊"我不吃我不吃"。

但是forever97又不喜欢连续三天吃一种外卖。

如果Trote_w哪天忘了这件事并且三天给他买了同一家外卖,那么forever97就会把Trote_w的头摁进手机屏幕里。

作为Trote_w的好朋友,你能告诉他连续请forever97吃n天饭,有多少不同的购买方法吗?


分析:

可以重复,也可以不重复,可以弄一个维度,表明与上一个重复或者不重复。

所以本位重复,那么上一位就不能重复,两者等价。

如果本为不重复,那么上一位可以重复或者不重复,所以等于(重复+不重复)*两种可能


复制代码
#include<bits/stdc++.h>
typedef long long ll;
using namespace std;
ll mod=1e9+7;
void solve()
{
  ll n;
  cin>>n;
  ll dp[n+1][3];
  memset(dp,0,sizeof dp);
  if(n==1)
  {
      cout<<3<<'\n';
      return ;
  }
  else if(n==2)
  {
      cout<<9<<'\n';
      return ;
  }
  else{
      dp[2][0]=6,dp[2][1]=3;
      for(ll i=3;i<=n;i++)
      {
          dp[i][0]=(dp[i-1][1]%mod+dp[i-1][0]%mod)*2%mod;
          dp[i][1]=dp[i-1][0];
      }
      cout<<(dp[n][0]+dp[n][1])%mod<<'\n';
      return ;
  }
}
    int main()
   {
    ios_base::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    ll t=1;
    cin>>t;
    while(t--)
    solve();
    return 0;
    }
相关推荐
-qOVOp-2 小时前
408第一季 - 数据结构 - 排序II
数据结构·算法·排序算法
小胖同学~2 小时前
快速入门数据结构--栈
算法
C++ 老炮儿的技术栈2 小时前
VSCode -配置为中文界面
大数据·c语言·c++·ide·vscode·算法·编辑器
刃神太酷啦2 小时前
聚焦 string:C++ 文本处理的核心利器--《Hello C++ Wrold!》(10)--(C/C++)
java·c语言·c++·qt·算法·leetcode·github
CoovallyAIHub2 小时前
云南电网实战:YOLOv8m改进模型攻克输电线路异物检测难题技术详解
深度学习·算法·计算机视觉
蜗牛的旷野2 小时前
华为OD机试_2025 B卷_磁盘容量排序(Python,100分)(附详细解题思路)
python·算法·华为od
Sun_light3 小时前
链表 --- 高效离散存储的线性数据结构
前端·javascript·算法
西西弗Sisyphus3 小时前
低秩分解的本质是通过基矩阵和系数矩阵的线性组合,以最小的存储和计算代价近似表示复杂矩阵
线性代数·算法·矩阵
物联网嵌入式小冉学长3 小时前
10.C S编程错误分析
c语言·stm32·单片机·算法·嵌入式
王中阳Go20 小时前
从超市收银到航空调度:贪心算法如何破解生活中的最优决策谜题?
java·后端·算法