1. Job Roadmap
  2. Home
  3. Problem Set
  4. codenotelist
  5. Forum
  6. course
  7. Shore Share Sessions
  8. Record
  1. Login
  2. Sign Up
  3. Language
    1. English
    2. 한국어
    3. 简体中文
    4. 正體中文
    ZhContent TextSol AI分析

解题思路

定义 “好数”是十进制表示中恰有一个非零位的正整数,即形如 d×10kd\times 10^kd×10k(d∈[1,9], k≥0d\in[1,9],\,k\ge0d∈[1,9],k≥0),例如 7,40,30007, 40, 30007,40,3000。

分解与独立性 对不同下标的元素操作互不影响,所以总答案是各元素独立变成好数的最小代价之和。问题归约为:给定一个正整数 xxx,用如下操作的最少次数把它变成好数:

  1. x←x+1x\leftarrow x+1x←x+1;

P3896.第2题-小美的好数

    1000ms Tried: 188 Accepted: 30 Difficulty: 7 所属公司 : 美团
    算法与标签>动态规划

题目内容

小美定义一个正整数 xxx 是 好的,当且仅当其十进制表示中仅包含一个非零有效位,例如 4000、9、204000、9、204000、9、20 都是好的数,而 110、301、6666110、301、6666110、301、6666 不是好的数,非正整数也不是好的数;

给定一个长度为 nnn 的正整数数组 {a1,a2,...,ana_1,a_2,...,a_na1​,a2​,...,an​},你可以对数组执行若干次以下三种操作中的一种:

选择一个索引 iii ,将 aia_iai​ 增加 111 ;

选择一个索引 iii ,如果 a>1a_> 1a>​1,则将 aia_iai​ 减少 111 ;

选择一个素引 iii ,如果 aia_iai​ 是 101010 的整数倍,则将 aia_iai​ 除以 101010 ,否则该操作无效;

输出将数组中所有元素都变为好的数所需的最少操作次数。

输入描述

第一行输入一个整数 n(1≤n≤2×105)n(1 ≤n≤2 × 10^5)n(1≤n≤2×105) ,表示数组的长度;

第二行输入 nnn 个整数 a1,a2,...,an(1≦ai≦n)a_1,a_2,...,a_n(1 ≦a_i≦n)a1​,a2​,...,an​(1≦ai​≦n) ,表示数组的初始元素。

输出描述

输出一个整数,表示将数组中所有元素都变为好的数的最少操作次数。

样例1

输入

3
1 2 3

输出

0

样例2

输入

11
11 1 1 1 4 5 6 7 8 9 10

输出

1

说明

将 111111 减一得 101010 ;

登录后即可使用 AI 分析。

模式
倒计时时长
:

最长 10 小时 59 分;应用后按此时长重新开始。

提示:点击提交记录在左侧题面区域查看详情
题库
AI分析设置
留空使用官方API Key,每天有次数限制(自定义API Key仅限会员和管理员使用,不限次数)
会员和管理员可切换模型;切到 Kimi/智谱/通义/豆包时需填写对应供应商 API Key
升级会员,可将运行与提交冷却时间缩短至 1 秒起

Status

  • Judging Queue
  • Service Status

Development

  • Open Source

Support

  • Help
  • Contact Us

About

  • About
  • Privacy
  • Terms of Service
  • Copyright Complaint
  1. Language
    1. English
    2. 한국어
    3. 简体中文
    4. 正體中文
  2. Legacy mode
  3. Theme
    1. Light
    2. Dark
  1. 京ICP备2025123107号-1
  2. Worker 3, 52ms
  3. Powered by Hydro v5.0.0-beta.18 Community
CLOSE


ScanQRCodePrompt

请使用微信扫描下方二维码完成注册

Forgot password or username?