蓝桥杯国赛子串2023动态规划,暴力

复制代码
#include <bits/stdc++.h>
using namespace std;
// string ss;
#define int long long
string s;
//该方法通过动态规划,找到2023字串,而2023等于202加3,202等于20+2,20等于2+0;
int f2()
{
  int dp[4]={0};
  //dp[0]代表2的数量,dp[1]代表20的数量d[2]代表202的数量,dp[3]等于2023的数量,考察对动态规划的理解
  for(int i=0;i<s.size();i++)
  {
    if(s[i]=='2')
    {
      //第一个二加加第二个二等于加上20字串的数量
      dp[0]++;
      dp[2]+=dp[1];
    }
    if(s[i]=='0') dp[1]+=dp[0];
    if(s[i]=='3') dp[3]+=dp[2];
  }
  return dp[3];
}
int f1()
{
  int cnt=0;
  for(int i=0;i<s.size();i++)
  {
    if(s[i]!='2') continue;
    for(int j=i+1;j<s.size();j++)
    {
      if(s[j]!='0') continue;
      for(int k=j+1;k<s.size();k++)
      {
        if(s[k]!='2') continue;
        for(int l=k+1;l<s.size();l++)
        {
          if(s[l]!='3') continue;
          cnt++;
        }
      }
    }
  }
  return cnt;
}
signed main()
{
//   for(int i=0;i<=2023;i++)
//   {
//     s+=to_string(i);
//   }
  for(int i=1;i<=2023;i++)
  {
    string ss=to_string(i);
    for(auto ch:ss)
    {
      if(ch=='2') s+='2';
      if(ch=='0') s+='0';
      if(ch=='3') s+='3';
    }
  }
  // cout<<f2();
  cout<<f1();
  // int cont=0;
  // // cout<<s;
  // for(int i=0;i<s.size();i++)
  // {
  //   if(s[i]!='2') continue;
  //   for(int j=i+1;j<s.size();j++)
  //   {
  //     if(s[j]!='0') continue;
  //     for(int k=j+1;k<s.size();k++)
  //     {
  //       if(s[k]!='2') continue;
  //       for(int l=k+1;l<s.size();l++)
  //       {
  //         if(s[l]!='3') continue;
  //         cont++;
  //       }
  //     }
  //   }
  // }
  // cout<<cont;
  return 0;
}
相关推荐
dayuOK63075 天前
写作卡壳怎么办?我的“5分钟启动法”
人工智能·职场和发展·自动化·新媒体运营·媒体
枫子有风5 天前
LLM-Agent智能体(大厂面试常问)
面试·职场和发展·llm·agent
-森屿安年-5 天前
63. 不同路径 II
c++·算法·动态规划
重生之后端学习5 天前
Java入门
java·开发语言·职场和发展
AIHR数智引擎5 天前
KPI物理失效:AI原生组织的效能重构与技能度量
人工智能·经验分享·职场和发展·重构·ai-native·aihr
想吃火锅10055 天前
【leetcode】121.买卖股票的最佳时机js/c++
算法·leetcode·职场和发展
程序员小远5 天前
自动化测试基础知识总结
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
嘿黑嘿呦5 天前
chap 8排序
算法·蓝桥杯·排序算法·软件工程
小欣加油5 天前
leetcode3612 用特殊操作处理字符串I
数据结构·c++·算法·leetcode·职场和发展
旧曲重听15 天前
2026前端技术从「夯」到「拉」
前端·程序人生·职场和发展·软件工程