我想用代数方式简化整数的平方根,而不是用数字计算它,即√800应该20√2,而不是 28.2842712474619 < /强>
我无法通过编程找到解决方法:(
答案 0 :(得分:29)
对根数下的数字进行因式分解,挑出成对出现的因子,并将其余部分留在根目录下。
√800=√(2 x 2 x 2 x 2 x 5 x 2 x 5)=√(2 2 x 2 2 x 5 2 x 2)= (2 x 2 x 5)√2=20√2。
为了完整起见,这里有一些简单的代码:
outside_root = 1
inside_root = 800
d = 2
while (d * d <= inside_root):
if (inside_root % (d * d) == 0): # inside_root evenly divisible by d * d
inside_root = inside_root / (d * d)
outside_root = outside_root * d
else:
d = d + 1
当算法终止时,outside_root和inside_root包含答案。
这里运行800:
inside outside d
800 1 2 # values at beginning of 'while (...)'
200 2 2
50 4 2
50 4 3
50 4 4
50 4 5
2 20 5 # d*d > 2 so algorithm terminates
== ==
答案20√2在最后一行。
答案 1 :(得分:0)
#include<stdio.h>
#include<conio.h>
int main() {
int i, n, n2, last, final;
last = 0, final = 1;
printf("Enter number to calculate root: ");
scanf("%d", & n);
n2 = n;
for (i = 2; i <= n; ++i) {
if (n % i == 0) {
if (i == last) {
final = final * last;
last = 0;
} else {
last = i;
}
n /= i;
i--;
}
}
n = n2 / (final * final);
printf("\nRoot: (%d)^2 * %d", final, n);
getch();
return 0;
}