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 video solution AI分析

思路

  • 设 xxx 的十进制位为 d0d1…dn−1d_0d_1\ldots d_{n-1}d0​d1​…dn−1​(从高位到低位)。总数位和为 SSS。

  • 想要 y<xy<xy<x 且数位和等于 SSS,一种稳定构造是:在某个位置 iii(0≤i≤n−20 \le i \le n-20≤i≤n−2)把高位 did_idi​ 减去 111(要求 di≥1d_i \ge 1di​≥1),然后把后缀位置 i+1…n−1i+1\ldots n-1i+1…n−1 的数位重新分配,使后缀的和增加 111。这样整体和不变,且由于第 iii 位变小,必有 y<xy<xy<x。

  • 若记原后缀和为 R=∑j=i+1n−1djR=\sum_{j=i+1}^{n-1} d_jR=∑j=i+1n−1​dj​,新后缀目标和为 R+1R+1R+1。只要后缀长度 L=n−i−1L=n-i-1L=n−i−1 满足

    R+1≤9L,R+1 \le 9L, R+1≤9L,

P3497.第1题-bigbong的数组

    1000ms Tried: 45 Accepted: 8 Difficulty: 5 所属公司 : 饿了么
    算法与标签>构造

题目内容

BingbongBingbongBingbong 给定xxx,构造一个非负整数y(y<x) y(y < x)y(y<x),使得xxx和yyy的数位和相等。

输入描述

一个整数x(0≦x≤10100000)x(0≦x≤10^{100000})x(0≦x≤10100000),表示给定的整数。

输出描述

若存在满足条件的YYY,输出任意一个,否则输出"−1-1−1"。

样例1

输入

0

输出

-1

说明

样例2

输入

123

输出

6

开通会员即可查看完整视频题解: 1.题目讲解 2.思路分析 3.逐行代码手写

登录后即可使用 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 0, 37ms
  3. Powered by Hydro v5.0.0-beta.18 Community
CLOSE


ScanQRCodePrompt

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

Forgot password or username?