SGU[105] Div 3
Description
描述
There is sequence 1, 12, 123, 1234, ..., 12345678910, ... . Given first N elements of that sequence. You must determine amount of numbers in it that are divisible by 3.
给定数列 1, 12, 123, 1234, ..., 12345678910, ...的前N个元素。你需要判断其中一共有多少个元素能够被3整除。
Input
输入
Input contains N (1<=N<=231 - 1).
输入文件包含N(1<=N<=231 - 1)。
Output
输出
Write answer in output file.
将答案输出在输出文件上。
Sample Input
样例输入
4
Sample Output
样例输出
2
Analysis
分析
由于一个数对3取模恒等于这个数各个位上数字之和对3取模。
因此,非常容易想到的方法是找规律:
项数N | 数列 | 除以3的余数 | 答案ans |
1 | 1 | 1 | 0 |
2 | 12 | 0 | 1 |
3 | 123 | 0 | 2 |
4 | 1234 | 1 | 2 |
5 | 12345 | 0 | 3 |
6 | 123456 | 0 | 4 |
7 | 1234567 | 1 | 4 |
8 | 12345678 | 0 | 5 |
9 | 123456789 | 0 | 6 |
由上述表格,我们可以大致的看出规律,即:
- N % 3 == 1 => ans不变
- N % 3 == 0, 2 => ans + 1
有了上述的讨论,我们可以很容易的写出一个暴力算法,但是考虑到N的数据范围比较大,这并不是一个非常好的选择。
我们可以推导出数学公式来求解这个问题。观察上表(下面的除法为C++意义中的整除):
- N % 3 == 0 => ans = 2 * N / 3
- N % 3 == 1 => ans = 2 * N / 3
- N % 3 == 2 => ans = 2 * N / 3 + 1
把上述公式归纳成一个公式,即为ans = 2 * N / 3 + (N % 3 == 2),此处N % 3 == 2的返回值为真、假,分别对应着1、0。
Solution
解决方案
1 2 3 4 5 6 7 8 9 10 11 | #include <iostream> using namespace std; int main() { int N; cin >> N; cout << N / 3 * 2 + (N % 3 == 2) << endl << endl; return 0; } |
这是一道较为简单的数学找规律的题目,但是找到规律以后如何推导得到最终的数学表达式还是有一定的难度的。
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
· Linux系统下SQL Server数据库镜像配置全流程详解
· Sdcb Chats 技术博客:数据库 ID 选型的曲折之路 - 从 Guid 到自增 ID,再到
· 语音处理 开源项目 EchoSharp
· 《HelloGitHub》第 106 期
· Huawei LiteOS基于Cortex-M4 GD32F4平台移植
· mysql8.0无备份通过idb文件恢复数据过程、idb文件修复和tablespace id不一致处