此代码需要很长时间才能运行(超过10分钟)。有什么方法可以优化它,以便在不到一分钟内完成?优化MATLAB代码
clear all;
for i = 1:1000000
harmonicsum = 0;
lhs = 0;
for j = 1:i
% compute harmonic sum
harmonicsum = harmonicsum + 1/j;
% find sum of factors
if (mod(i,j)==0)
lhs = lhs + j;
end
end
%define right hand side (rhs) of Riemann Hypothesis
rhs = harmonicsum + log(harmonicsum) * exp(harmonicsum);
if lhs > rhs
disp('Hypothesis violated')
end
end
关键是不要问“ N“的因素是什么,但是”什么数字有'j作为因素“,这更容易。 –