求解大整数中 3 的倍数子串数量:代码实现与注意要点
```cpp #include <iostream> #include <string> using namespace std; // 检查一个字符串表示的数字是否是3的倍数 bool isMultipleOfThree(const string& num) { int sum = 0; // 遍历字符串中的每个字符 for (char c : num) { // 将字符转换为对应的数字并累加到sum中 sum += c - '0'; } // 判断sum是否能被3整除 return sum % 3 == 0; } int main() { string n; // 读取输入的数字 cin >> n; int len = n.length(); int count = 0; // 用于存储已经出现过的子串 string seen[100000]; int seenCount = 0; // 枚举所有可能的子串 for (int i = 0; i < len; ++i) { for (int j = i; j < len; ++j) { string sub = n.substr(i, j - i + 1); bool isNew = true; // 检查该子串是否已经出现过 for (int k = 0; k < seenCount; ++k) { if (seen[k] == sub) { isNew = false; break; } } // 如果是新的子串且是3的倍数 if (isNew && isMultipleOfThree(sub)) { seen[seenCount++] = sub; ++count; } } } // 输出结果 cout << count << endl; return 0; } ``` 我在以往的开发过程中,碰到过以下几点需要格外小心处理的地方: 1. 注意字符串和数字的转换,在计算数字和时需要将字符转换为对应的数字。 2. 子串去重的处理,确保每个符合条件的子串只被统计一次。 3. 输入的数字可能非常大,使用字符串来处理可以避免整数溢出的问题。 ######[AI写代码神器 | 486点数解答 | 2025-08-29 11:52:55]
- 易语言读取文本文件并显示到超级列表框:代码示例与注意要点(DeepSeek | 571点数解答 | 2025-08-23 20:54:40)224
- 易语言:读取并显示特定文本到超级列表框,还能增加新数据的方法与要点(DeepSeek | 1317点数解答 | 2025-08-23 20:58:40)230
- 判断超级幸运数:满足“纯4/7数位”或“4/7总个数为4或7”的整数计数(阿里通义 | 965点数解答 | 2026-03-13 12:15:06)21
- mallshop商城网站:数据库设计与强大业务功能全揭秘(GPT | 257点数解答 | 2024-12-09 14:08:15)275
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)344
- 工程师必知:软件系统用户文档编写九大要点揭秘(百度文心 | 350点数解答 | 2023-11-09 18:23:53)184
- C 语言:按特定顺序读入并输出浮点数、整数和字符(字节豆包 | 106点数解答 | 2024-09-26 00:32:40)311
- C语言:按序读入浮点数、整数、字符并按新顺序输出,附代码实现 (字节豆包 | 108点数解答 | 2024-09-30 22:54:08)327
- C语言:按特定顺序读入并输出浮点数、整数和字符,精确控制小数位(字节豆包 | 155点数解答 | 2024-10-08 22:06:18)322
- C++与Python:按特定顺序输入输出数据并保留浮点数两位小数的实现(字节豆包 | 168点数解答 | 2024-10-08 22:07:03)325
- C语言:按特定顺序读入再输出,含浮点数精确格式处理(字节豆包 | 105点数解答 | 2024-10-08 22:07:29)334
- C++ 混合类型数据格式化输入输出:按指定顺序输出并保留两位小数(字节豆包 | 187点数解答 | 2024-10-16 14:31:08)380