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分析

解题思路

  • 把 1…N 的数按模 d 的余数分组。若两张卡余数分别为 r 与 d−r(含 0 与 d/2 的自配对),它们之和能被 d 整除。

  • 问题等价于:求一个最大规模的集合 α(N,d),使得集合中任意两数之和都 不能 被 d 整除;则答案 K(N,d) = α(N,d) + 1(抽屉原理)。

  • 记 q = ⌊N/d⌋,rem = N % d。在 1…N 中:

    • 余数为 0 的数有 q 个;
    • 余数为 1..rem 的每个余数组有 q+1 个;
    • 余数为 rem+1..d-1 的每个余数组有 q 个。

P4454.第3题-超市盲盒选品

    1000ms Tried: 28 Accepted: 8 Difficulty: 5 所属公司 : 携程
    算法与标签>数学

题目内容

某超市举办“盲盒选品”活动,盲盒内装有编号 111 到 NNN 的 NNN 个商品卡片。活动规则要求:若选到的卡片中存在两种编号之和能被 ddd 整除,则可额外兑换一份礼品。

顾客希望知道“保底门槛”——即确定最小的选卡数量 KKK ,使得无论顾客选择哪 KKK 张不同的卡片,都必然存在两张卡片的编号之和能被 ddd 整除(触发兑换条件)。这个“保底门槛” KKK 就是需要计算的 K(N,d)K(N,d)K(N,d) 。

输入描述

每个测试文件均包含多组测试数据,第一行输入一个整数 T(1≤T≤2×105)T(1≤T≤2×10^5)T(1≤T≤2×105) 代表数据组数,每组测试数据描述如下:

接下来 TTT 行,每行输入两个整数 N,d(1<d<N≤1018)N,d(1<d<N≤10^{18})N,d(1<d<N≤1018) 。

输出描述

输出 TTT 行,每行一个整数,表示答案 K(N,d)K(N,d)K(N,d) 。

样例1

输入

3
7 3
10 2
10 3

输出

5
3
6

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


ScanQRCodePrompt

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

Forgot password or username?