一道题

请问1和2谁效率更高?
A=1000
B=100
n=0
/*
1
*/
while(A>0){
while(B>0){
++n;
--B;
}
--A;
}

/*
2
*/
while(B>0){
while(A>0){
++n;
--A;
}
--B;
}

全部评论
2效率高,大循环放内层。看汇编,大循环在内层,指令数少一些。
点赞 回复 分享
发布于 2017-09-24 13:31
感觉这题想考行扫描和列扫描 如果内存按行存储 那先扫描行比较快 如果按列存储 那先扫描列比较快 一般编程内存都是按行存储 所以2效率高一点 (如果是matlab这样按列存储 那1比较快) 个人见解
点赞 回复 分享
发布于 2017-09-24 13:33
答案应该是2 有兴趣可以了解。 http://blog.sina.com.cn/s/blog_549941cb01013qgx.html
点赞 回复 分享
发布于 2017-09-24 13:30
1  效率高   两者A都减了1000次 B减了100次  没有区别 但是1的n加了100次  2的n加了1000次  因此  1效率要高一些
点赞 回复 分享
发布于 2017-09-24 13:24
分支优化原则,2
点赞 回复 分享
发布于 2017-09-24 14:31
2吧
点赞 回复 分享
发布于 2017-09-24 13:22

相关推荐

04-09 09:47
门头沟学院 Java
Arbelite_:2-3k,这工资还不如去摇奶茶
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务