:底座和奇怪的问题算法执行另外、乘法、不加区分除法性能?
2015-06-18 08:28
351 查看
底座和奇怪的问题:算法执行加法、乘法、不加区分除法性能? 计算机分析人士认为原则:加法、乘法和除法,以减少计算性能,然而,到什么程度降低?
写C使用程序30乘以一百万计算的数据来测试时间差,码,如以下:
结果例如以下:
百万数据加法用时:0.157051 秒
百万数据乘法用时:0.184712 秒
百万数据除法用时:0.161014 秒
-----------------------------------------
当加入数百万的数据与:0.156099 第二
乘法万个数据点与时间:0.184023 第二
当数以百万计的数据除以:0.159588 第二
这说明了什么问题?
应该说算法不再区分基本操作?
写C使用程序30乘以一百万计算的数据来测试时间差,码,如以下:
#include <stdio.h> #include <stdlib.h> #include <time.h> #define N 1000000 void add(float x[], long n) { float sum = 0; for(long i = 0; i < n; i++) sum += x[i]; } void prod(float x[], long n) { float sum = 1; for(long i = 0; i < n; i++) sum *= (x[i]); } void div(float x[], long n) { for(long i = 0; i < n; i++) { x[i] /= 3.0; } } int main() { float x ; clock_t t1 = clock(); for(int i = 0; i < 50; i++) add(x, N); clock_t t2 = clock(); printf("百万数据加法用时:%f 秒\n", (double)(t2 - t1)/ CLOCKS_PER_SEC); t1 = clock(); for(int i = 0; i < 50; i++) prod(x, N); t2 = clock(); printf("百万数据乘法用时:%f 秒\n", (double)(t2 - t1)/ CLOCKS_PER_SEC); t1 = clock(); for(int i = 0; i < 50; i++) div(x, N); t2 = clock(); printf("百万数据除法用时:%f 秒\n", (double)(t2 - t1)/ CLOCKS_PER_SEC); return 0; }
结果例如以下:
百万数据加法用时:0.157051 秒
百万数据乘法用时:0.184712 秒
百万数据除法用时:0.161014 秒
-----------------------------------------
当加入数百万的数据与:0.156099 第二
乘法万个数据点与时间:0.184023 第二
当数以百万计的数据除以:0.159588 第二
这说明了什么问题?
应该说算法不再区分基本操作?
相关文章推荐
- 今天才发现,自已犯了一个低级的逻辑错误,不可原谅
- 遇事不要表现出抗拒,是你的事情,迟早要解决
- Docker play <含安装后出现panic kernel解决方案,亲身体验>
- 随笔1
- 水文概念之:runoff 和streamflow
- ASP 运行结果显示空白 --- 是编码的原因。
- Linux而不必进入password登陆自己主动sshserver方法
- 用c#开发微信 (18) 多客服
- 运行vb写的程序,有些电脑上会弹出一个与office相关的窗口
- Bmob失物招领教程即源代码
- handsontable 和 echarts都定义了require方法,初始化时冲突了,怎么办?
- 再谈一次关于Java中的 AIO(异步IO) 与 NIO(非阻塞IO)
- hdu 1047 (big integer sum, fgets or scanf, make you func return useful infos)
- Android 进行单元测试难在哪-终
- jquery实战---标签页效果
- jquery实战---标签页效果
- C++实现快速排序
- QT编译遇到的初级问题整理 gnu-libstdc++\4.9\include\cstdlib:72: error: stdlib.h: No such file or directory
- mysql导入出现MySQL Error 1153 - Got a packet bigger than 'max_allowed_packet' bytes
- SQL SERVER 使用T-SQL还原Bak数据库到指定位置