蓝桥杯国赛子串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;
}
相关推荐
是苏浙2 小时前
蓝桥杯备战day3
蓝桥杯
月明长歌3 小时前
【码道初阶】一道经典简单题:多数元素(LeetCode 169)|Boyer-Moore 投票算法详解
算法·leetcode·职场和发展
CoderYanger4 小时前
动态规划算法-简单多状态dp问题:15.买卖股票的最佳时机含冷冻期
开发语言·算法·leetcode·动态规划·1024程序员节
无名修道院7 小时前
渗透测试新手面试高频 50 题:原理 + 标准答案(2025)- 第三篇
网络安全·面试·职场和发展·渗透测试·内网渗透·免杀
CoderYanger8 小时前
动态规划算法-斐波那契数列模型:2.三步问题
开发语言·算法·leetcode·面试·职场和发展·动态规划·1024程序员节
天才测试猿8 小时前
Postman接口测试:如何导入swagger接口文档?
自动化测试·软件测试·python·测试工具·职场和发展·接口测试·postman
CoderYanger8 小时前
动态规划算法-简单多状态dp问题:16.买卖股票的最佳时机含手续费
开发语言·算法·leetcode·动态规划·1024程序员节
Rock_yzh9 小时前
LeetCode算法刷题——54. 螺旋矩阵
数据结构·c++·学习·算法·leetcode·职场和发展·矩阵
什么时候才能变强9 小时前
k6面试高频问题
面试·职场和发展·k6
CoderYanger10 小时前
动态规划算法-路径问题:9.最小路径和
开发语言·算法·leetcode·动态规划·1024程序员节