news 2026/1/25 8:47:52

小红删数字【牛客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/1/22 19:56:30

开发者社区的力量:一位测试工程师的破茧之路

迷雾中的测试新人 2018年夏&#xff0c;当我手持手工测试用例文档站在网易大楼前时&#xff0c;从未想到三年后会在谷歌开发者大会分享《AI赋能的混沌工程实践》。作为日均执行200重复测试的"点点工程师"&#xff0c;我陷入职业困局&#xff1a;自动化脚本无从下手&…

作者头像 李华
网站建设 2026/1/24 2:44:51

基于微信小程序的付费自习室系统源码文档部署文档代码讲解等

课题介绍本课题聚焦付费自习室行业数字化需求&#xff0c;设计并实现一款基于微信小程序的付费自习室系统&#xff0c;解决传统自习室预约繁琐、计费不透明、座位管理低效等痛点。系统以微信小程序为前端交互入口&#xff0c;采用Node.js搭建后端服务&#xff0c;搭配MySQL数据…

作者头像 李华
网站建设 2026/1/24 19:23:23

PMSM电机负载观测转矩前馈Simulink探索

PMSM电机负载观测转矩前馈simulink 基于Luenberger降阶状态观测器&#xff0c;包含PMSM数学模型&#xff0c;PMSM双闭环PI矢量控制&#xff0c;并添加了前馈控制&#xff0c;采用SVPWM调制。在电机控制领域&#xff0c;永磁同步电机&#xff08;PMSM&#xff09;因其高效、高功…

作者头像 李华
网站建设 2026/1/24 1:54:33

Kiro教程(二)| Kiro 核心功能完全指南

Kiro教程&#xff08;二&#xff09;| Kiro 核心功能完全指南Kiro 核心功能完全指南1. 开发模式选择2. Vibe 模式深度解析2.1 核心概念2.2 提示词技巧2.3 多轮对话3. Spec 模式深度解析3.1 核心概念3.2 三阶段流程3.3 需求文档&#xff08;requirements.md&#xff09;3.4 设计…

作者头像 李华