|
5 | 5 | ## 题目描述
|
6 | 6 |
|
7 | 7 | <!-- 这里写题目描述 -->
|
| 8 | + |
8 | 9 | <p>设计一个算法,算出 n 阶乘有多少个尾随零。</p>
|
9 | 10 | <p><strong>示例 1:</strong></p>
|
10 | 11 | <pre><strong>输入:</strong> 3
|
|
19 | 20 | ## 解法
|
20 | 21 |
|
21 | 22 | <!-- 这里可写通用的实现逻辑 -->
|
| 23 | + |
| 24 | +**方法一:数学** |
| 25 | + |
| 26 | +题目实际上是求 $[1,n]$ 中有多少个 5ドル$ 的因数。 |
| 27 | + |
| 28 | +我们以 130ドル$ 为例来分析: |
| 29 | + |
| 30 | +1. 第 1ドル$ 次除以 5ドル,ドル得到 26ドル,ドル表示存在 26ドル$ 个包含因数 5ドル$ 的数; |
| 31 | +1. 第 2ドル$ 次除以 5ドル,ドル得到 5ドル,ドル表示存在 5ドル$ 个包含因数 5ドル^2$ 的数; |
| 32 | +1. 第 3ドル$ 次除以 5ドル,ドル得到 1ドル,ドル表示存在 1ドル$ 个包含因数 5ドル^3$ 的数; |
| 33 | +1. 累加得到从 $[1,n]$ 中所有 5ドル$ 的因数的个数。 |
| 34 | + |
| 35 | +时间复杂度 $O(\log n),ドル空间复杂度 $O(1)$。 |
| 36 | + |
22 | 37 | <!-- tabs:start -->
|
23 | 38 |
|
24 | 39 | ### **Python3**
|
25 | 40 |
|
26 | 41 | <!-- 这里可写当前语言的特殊实现逻辑 -->
|
27 | 42 |
|
28 | 43 | ```python
|
29 | | - |
| 44 | +class Solution: |
| 45 | + def trailingZeroes(self, n: int) -> int: |
| 46 | + ans = 0 |
| 47 | + while n: |
| 48 | + n //= 5 |
| 49 | + ans += n |
| 50 | + return ans |
30 | 51 | ```
|
31 | 52 |
|
32 | 53 | ### **Java**
|
33 | 54 |
|
34 | 55 | <!-- 这里可写当前语言的特殊实现逻辑 -->
|
35 | 56 |
|
36 | 57 | ```java
|
| 58 | +class Solution { |
| 59 | + public int trailingZeroes(int n) { |
| 60 | + int ans = 0; |
| 61 | + while (n > 0) { |
| 62 | + n /= 5; |
| 63 | + ans += n; |
| 64 | + } |
| 65 | + return ans; |
| 66 | + } |
| 67 | +} |
| 68 | +``` |
| 69 | + |
| 70 | +### **C++** |
| 71 | + |
| 72 | +```cpp |
| 73 | +class Solution { |
| 74 | +public: |
| 75 | + int trailingZeroes(int n) { |
| 76 | + int ans = 0; |
| 77 | + while (n) { |
| 78 | + n /= 5; |
| 79 | + ans += n; |
| 80 | + } |
| 81 | + return ans; |
| 82 | + } |
| 83 | +}; |
| 84 | +``` |
| 85 | + |
| 86 | +### **Go** |
| 87 | + |
| 88 | +```go |
| 89 | +func trailingZeroes(n int) int { |
| 90 | + ans := 0 |
| 91 | + for n > 0 { |
| 92 | + n /= 5 |
| 93 | + ans += n |
| 94 | + } |
| 95 | + return ans |
| 96 | +} |
| 97 | +``` |
37 | 98 |
|
| 99 | +### **TypeScript** |
| 100 | + |
| 101 | +```ts |
| 102 | +function trailingZeroes(n: number): number { |
| 103 | + let ans = 0; |
| 104 | + while (n > 0) { |
| 105 | + n = Math.floor(n / 5); |
| 106 | + ans += n; |
| 107 | + } |
| 108 | + return ans; |
| 109 | +} |
38 | 110 | ```
|
39 | 111 |
|
40 | 112 | ### **...**
|
|
0 commit comments