
在本文中,我们将讨论找到可被 N 整除的重复单元的数量。重复单元只是 1 的重复数量,令 R(k) 为重复单元,其中 k 为 1 的长度。例如 R(4) = 1111。因此我们需要找到 R(k) 可被 N 整除的 k 的最小数量,例如 -
Input : N = 13 Output : k = 6 Explanation : R(6) i.e 111111 is divisible by 13. Input : N = 31 Output : k = 15
您可以通过检查从 1 开始的 k 的每个值来解决此问题,其中 R(k) 能否被 N 整除。但是使用此解决方案,我们将无法确定 N 是否可被 R(k) 的任何值整除。这将使程序变得过于复杂,甚至可能无法运行。
解决该程序的有效方法是,
#include <bits/stdc++.h>
using namespace std;
int main() {
int N = 31;
int k = 1;
// checking if N is coprime with 10.
if (N % 2 == 0 || N % 5 == 0){
k = 0;
} else {
int r = 1;
int power = 1;
// check until the remainder is divisible by N.
while (r % N != 0) {
k++;
power = power * 10 % N;
r = (r + power) % N;
}
}
cout << "Value for k : "<< k;
return 0;
}
Value for k : 15
在本文中,我们讨论寻找 R(k) 的 k 值,其中 R(k) 是可被给定 N 整除的重复单元。我们讨论了一种乐观的方法来找到k 的值。我们还讨论了解决这个问题的 C++ 代码。您可以使用任何其他语言(例如 Java、C、Python 等)编写此代码。我们希望本文对您有所帮助。
立即学习“C++免费学习笔记(深入)”;
以上就是重复单位可整除性(使用C++)的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号