news 2026/5/1 7:13:34

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
小红删数字【牛客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;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 6:52:30

YOLOv11魔改高效涨点 | 注意力篇 | CAA:上下文锚点注意力机制,条形卷积 + 全局先验,低成本实现 360 度全局视野,轻量化捕捉超大感受野,即插即用,彻底疯狂!!!

1、模块介绍 1.1 论文信息 论文标题:Poly Kernel Inception Network for Remote Sensing Detection 中文标题:用于遥感检测的多核 Inception 网络 (PKINet) 论文链接 论文代码 核心创新点模块:Poly Kernel Inception (PKI) 模块与上下文锚点注意力 (Context Anchor Attenti…

作者头像 李华
网站建设 2026/5/1 5:51:25

SSM278的考研互助辅导平台vue

目录 SSM278考研互助辅导平台Vue实现摘要 开发技术源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01; SSM278考研互助辅导平台Vue实现摘要 SSM278考研互助辅导平台基于Vue.js框架开发&#xff0c;整合Spring、Spring MVC和MyBatis&#x…

作者头像 李华
网站建设 2026/4/18 6:19:48

SSM279的课程思政元素收集系统 加入课程

目录SSM279课程思政元素收集系统摘要开发技术源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;SSM279课程思政元素收集系统摘要 SSM279课程思政元素收集系统旨在将思想政治教育与专业课程内容深度融合&#xff0c;通过系统化、数字化的方…

作者头像 李华
网站建设 2026/4/20 18:47:40

SSM294的农产品进销存管理vue

目录SSM294农产品进销存管理系统的Vue实现摘要开发技术源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;SSM294农产品进销存管理系统的Vue实现摘要 该系统基于SSM&#xff08;SpringSpringMVCMyBatis&#xff09;后端框架与Vue.js前端技…

作者头像 李华
网站建设 2026/5/1 6:53:14

电动汽车在电网中的能量管理与调度探索

电动汽车在电网中的能量管理和调度。 第一部分的部分图展示如下。 &#xff08;注意:四个工作写一起了&#xff0c;每一个都是单独工作&#xff09; 1/基于网损灵敏度&#xff0c;电池老化等成本实时调度策略。 包括程序和数据&#xff0c;基于cvx求解。 2/孤网支持的充电站的能…

作者头像 李华