[itint5]两数积全为1
这一题,首先如果直接去算的话,很容易就超出int或者long的表示范围了。那么要利用%的性质,(num * 10 + 1) % a = 10 * (num % a) + 1 % a。除了a为1的情况,都是10 * (num % a) + 1。然后计算的时候,先去掉是2和5的倍数的情况。也可以直接做,如果余数出现过,就不用继续了。
int findMinAllOne(int a) { if (a % 2 == 0 || a % 5 == 0) return -1; if (a == 1) return 1; int num = 1; int ans = 1; while (true) { if (num % a == 0) { return ans; } else { num %= a; num = num * 10 + 1; ans++; } } }