当前位置: 首页 > news >正文

洛谷题单指南-进阶数论-P4942 小凯的数字

原题链接:https://www.luogu.com.cn/problem/P4942

题意解读:l(l+1)(l+2)...(r1)r​的数字模9的结果。

解题思路:

l(l+1)(l+2)...(r1)r​ 展开成l * 10^? + (l+1)*10^? + (l + 2)*10^? + ... + (r - 1) * 10^? + r

  ( l * 10? + (l+1)*10? + (l + 2)*10? + ... + (r - 1) * 10? + r ) % 9

= ( l * 10?%9 + (l+1)*10?%9 + (l + 2)*10?%9 + ... + (r - 1) * 10? + r ) % 9

由于10% 9 = 1,上式进一步简化为:

(l + l+1 + l+2 + ... + r-1 + r) % 9

= ((l + r) * (r - l + 1) / 2) % 9

根据模的性质,除以2模9转化成乘以2模9的逆元,2模9的逆元根据定义可以计算:2x ≡ 1 (mod 9),x = 5

因此上式转化为:

((l + r) * (r - l + 1)  * 5) % 9

= (((l + r)%9) * ((r - l + 1)%9)  * 5) % 9

这样就不会超出longlong的范围了

当然,如果不了解逆元,直接用高精度乘法和除法来做也完全是ok的。

100分代码:

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;LL l, r, ans;int main()
{int t;cin >> t;while(t --){cin >> l >> r;ans = ((l + r) % 9) * ((r - l + 1) % 9) * 5; cout << (ans % 9) << endl;}return 0;
}

 

http://www.hskmm.com/?act=detail&tid=13791

相关文章:

  • 【炼石计划NOIP】第八套 赛后总结
  • 下载了idea
  • vite7-webos网页版os管理|Vue3+Vite7+ArcoDesign搭建pc端os后台系统
  • 三门问题的多种解法,总有一个你看得懂
  • hbase学习——创建springboot+hbase项目
  • python_Day22笔记
  • .NET周刊【9月第1期 2025-09-07】
  • SUDO提权
  • 2025.9.19 总结
  • 2025.9.18 总结
  • 越南文识别技术:将纸质文档和信息快速、准确地转化为可编辑、可检索的数字数据
  • 23
  • 9.22日总结
  • 9.16 总结
  • Halcon抛出异常日志
  • [PaperReading] Mind Search: Mimicking Human Minds Elicits Deep AI Searcher
  • 穷举法(c语言版)
  • ZYNQ PS 端 UART 接收数据素材帧(初学者友好版)嵌入式编程 C语言 c++ 软件开发
  • 详细介绍:深入理解Kafka事务
  • 能碳园区 / 工厂系统 - 智慧园区
  • 代码随想录算法训练营第五天 |242.有效的字母异位词、349. 两个数组的交集、第202题. 快乐数、1. 两数之和
  • Photoshop 2025 v26.0(PS2025)下载安装教程(含一键安装包下载)
  • 网络加速原理
  • 循环依赖问题
  • 无意中在应用层瞥见了一个微内核的操作系统调度器
  • 数据结构思维题选做(长期更新)
  • 政治笔记/错题
  • 9.22模拟赛总结
  • 莫队 n的序列,多次查询一段区间内的数字的个数
  • 【mysql】mysql客户端中文显示乱码