matlab测试函数效率

问题遇到的现象和发生背景

我们matlab要测试函数运行效率,说算法一和算法二时间应该差10000倍左右,说我主程序有问题

问题相关代码,请勿粘贴截图

clc;clear
n=input('正整数n=');
b=f1(n);
c=f2(n);
d=f3(n);
disp(['由f1计算的',num2str(n),'的全部公因数之和=',num2str(b)])
disp(['由f2计算的',num2str(n),'的全部公因数之和=',num2str(c)])
disp(['由f3计算的',num2str(n),'的全部公因数之和=',num2str(d)])
tic
for n=1:2
f1(1e8+n);
end
t1=toc/2;
disp(['算法1平均运行时间=',num2str(t1),'秒'])
for n=1:1000
f2(1e8+n);
end
t2=toc/1000;
disp(['算法2平均运行时间=',num2str(t2),'秒'])
for n=1:10000
f3(1e8+n);
end
t3=toc/10000;
disp(['算法3平均运行时间=',num2str(t3),'秒'])

运行结果及报错内容

正整数n=12
由f1计算的12的全部公因数之和=28
由f2计算的12的全部公因数之和=28
由f3计算的12的全部公因数之和=28
算法1平均运行时间=1.3786秒
算法2平均运行时间=0.003396秒
算法3平均运行时间=0.00045904秒

我的解答思路和尝试过的方法
我想要达到的结果

怎么改啊qaq

你好,一般0.00几秒的时间消耗,都是不精确的,那种理论计算的是可以接受的,但是实际操作的时间都是不能用理论估算的,除非你的时间都是秒级别
你的主程序计算时间是有问题的,现在给你更正,错误主要来源于(1)每一段计时区间都要有tic开头toc结尾,(2)计时间隔用toc-tic即可

clc;clear
n=input('正整数n=');
b=f1(n);
c=f2(n);
d=f3(n);
disp(['由f1计算的',num2str(n),'的全部公因数之和=',num2str(b)])
disp(['由f2计算的',num2str(n),'的全部公因数之和=',num2str(c)])
disp(['由f3计算的',num2str(n),'的全部公因数之和=',num2str(d)])
tic
for n=1:2
    f1(1e8+n);
end
t1=(toc-tic)/2; % 这里用toc-tic才是运行时间
disp(['算法1平均运行时间=',num2str(t1),'秒'])
tic % 这里重新弄tic
for n=1:1000
    f2(1e8+n);
end
t2=(toc-tic)/1000;  % 这里用toc-tic才是运行时间
disp(['算法2平均运行时间=',num2str(t2),'秒'])
tic % 这里重新弄tic
for n=1:10000
    f3(1e8+n);
end
t3=(toc-tic)/10000; % 这里用toc-tic才是运行时间
disp(['算法3平均运行时间=',num2str(t3),'秒'])