一道题

请问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

相关推荐

不愿透露姓名的神秘牛友
昨天 15:57
小鹏汽车 java后端 22*15(固定13,2个月年终) 硕士211
点赞 评论 收藏
分享
11-27 16:41
门头沟学院 Java
点赞 评论 收藏
分享
10-26 13:03
已编辑
门头沟学院 物流经理
在okr拆解的小太阳...:实习待过,我待的部门氛围很好,基本不加班,双休有保证。
投递正浩创新EcoFlow等公司10个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务