当前位置: 首页 > news >正文

小红删数字【牛客tracker 每日一题】

小红删数字

时间限制:1秒 空间限制:256M

网页链接

牛客tracker

牛客tracker & 每日一题,完成每日打卡,即可获得牛币。获得相应数量的牛币,能在【牛币兑换中心】,换取相应奖品!助力每日有题做,丰盈牛币日益多!

题目描述

给定一个长度为n nn的整数数组a 1 , a 2 , … , a n a_1,a_2,…,a_na1,a2,,an。需要进行恰好n − 1 n−1n1次操作,数组最终只剩下一个数字。

每次操作只能针对当前数组的最后两个数x , y x,yx,yx xx在前,y yy在后)执行下述二选一:

请统计,在所有可能的操作序列下,最终结果为0 , 1 , … , 9 0,1,…,90,1,,9的方案数各有多少。答案对10 9 + 7 10^9+7109+7取模。

输入描述:

第一行输入整数n ( 1 ≦ n ≦ 200 000 ) n (1≦n≦200 000)n(1n200 000)——数组长度。

第二行输入n nn个整数a 1 , … , a n ( 1 ≦ a i ≦ 10 9 ) a_1,…,a_n (1≦a_i≦10^9)a1,,an(1ai109)——初始数组。

输出描述:

输出一行10 1010个整数,第i ii个数表示最终结果为i ii的方案数(按m o d 10 9 + 7 \mod\ 10^9+7mod109+7)。

示例1

输入:

4 1 2 3 4

输出:

1 0 0 0 3 3 0 0 0 1

解题思路

本题采用动态规划结合状态压缩求解,核心是利用模运算特性(加减乘模10 1010仅与数字个位相关),先将数组所有元素取模10 1010简化计算;初始化d p dpdp数组(d p [ j ] dp[j]dp[j]表示当前得到结果j的方案数),若n = 1 n=1n=1则直接标记对应数字的方案数为1 11,否则先将d p [ a [ n − 1 ] ] dp[a[n-1]]dp[a[n1]]设为1 11(初始仅最后一个元素);逆序遍历数组前n − 1 n-1n1个元素,每次新建临时数组q qq,遍历0 − 9 0-909的状态,若d p [ j ] dp[j]dp[j]有方案数,分别计算当前元素与j jj的加、乘模10 1010结果r rr,将d p [ j ] dp[j]dp[j]累加到q [ r ] q[r]q[r](两种操作对应两种方案),更新d p dpdpq qq;最终d p dpdp数组即为0 − 9 0-909的方案数,答案对1 e 9 + 7 1e9+71e9+7取模。该方法时间复杂度O ( n × 10 ) O(n×10)O(n×10),状态数固定为10 1010,完美适配n ≤ 2 × 10 5 n≤2×10^5n2×105的规模,高效统计所有操作序列的结果分布。

代码内容

#include<bits/stdc++.h>usingnamespacestd;typedeflonglongll;typedefunsignedlonglongull;typedefpair<ll,ll>pii;constll p=1e9+7;constll N=1e5+10;intmain(){ll n;cin>>n;vector<ll>dp(10,0);if(n==1){ll x;cin>>x;if(x<10)dp[x]=1;}else{vector<ll>a(n);for(ll i=0;i<n;++i){cin>>a[i];a[i]%=10;}dp[a[n-1]]=1;for(ll i=n-2;i>=0;--i){vector<ll>q(10,0);for(ll j=0;j<10;++j){if(!dp[j])continue;ll r=(a[i]+j)%10;q[r]=(q[r]+dp[j])%p;r=(a[i]*j)%10;q[r]=(q[r]+dp[j])%p;}dp=move(q);}}for(ll e:dp)cout<<e<<' ';return0;}
http://www.jsqmd.com/news/274902/

相关文章:

  • 为什么我辞去高薪开发工作?2026年反思
  • 情感分享:当代码成为我的第二语言——一位测试工程师的心路历程
  • Node.js WebAssembly零拷贝图像处理
  • 别再裸连 OpenAI 了!我用这一招,帮公司节省百万成本,还搞定了 Gemini 3.0 和 Sora 2
  • 当AI刺破泡沫:算力瓶颈、能源战争与资本主义的“物理转向”
  • 4.自注意机制__self-attention
  • 如何用ChatGPT提升开发效率?实战技巧大公开
  • Python的后端框架 - 教程
  • Springboot集成支付宝
  • 开发者社区的力量:一位测试工程师的破茧之路
  • 救命神器!8款AI论文软件测评:本科生毕业论文全攻略
  • 【闲话】i and flow - L
  • 04. 引用
  • 命令执行漏洞
  • 系统V信号量
  • 我的十年:从测试员到AI创业者的真实旅程
  • 2026年靠谱的pp管,PP风机,pp风管厂家实力推荐名录 - 品牌鉴赏师
  • SSM294的农产品进销存管理vue
  • SSM296的汽车租赁系统vue
  • Java实现——链队列(泛型)
  • 基于微信小程序的医院体检预约管理系统的设计和实现
  • 2026年上海二手房装修公司推荐,一站式服务与拎包入住交付能力横评 - 品牌鉴赏师
  • JavaScript 数组合并性能优化:扩展运算符 vs concat vs 循环 push
  • SSM291的母婴用品商城网站
  • python项目打包为镜像
  • 救命神器9个AI论文软件,专科生搞定毕业论文+格式规范!
  • 知光项目对象存储模块
  • 【路径规划】基于RRT、RRT星、RRTX、A_和D_ Lite实现机器人路径规划附matlab代码
  • fastapi里面tortoise-orm的用法
  • 【无人机三维路径规划】基于蚁群算法ACO、蜣螂算法DBO、人工蜂鸟算法AHA复杂山地模型下无人机路径规划附Matlab代码