免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: isnowran
打印 上一主题 下一主题

[C] 华丽的循环, 太强悍了 [复制链接]

论坛徽章:
0
11 [报告]
发表于 2009-05-13 09:12 |只看该作者
一个取模的问题,搞成while了.

论坛徽章:
0
12 [报告]
发表于 2009-05-13 09:21 |只看该作者
COM_INDEX_BUF_SIZE * sub_count + com_id

这个和 最开始传进来的 com_id有什么区别。。。

论坛徽章:
0
13 [报告]
发表于 2009-05-13 09:23 |只看该作者
高深,没看懂- -'

论坛徽章:
4
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:57:09IT运维版块每日发帖之星
日期:2015-09-14 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-16 16:34:21
14 [报告]
发表于 2009-05-13 10:06 |只看该作者
fun(0) = -483139584;
fun(1) = -483138552;
fun(1000) = -482107584;
fun(2000) = -481077584;
fun(400000000) = 0;
fun(400001000) = 1032000;
fun(400002000) = 2064000;

论坛徽章:
0
15 [报告]
发表于 2009-05-13 10:18 |只看该作者
真累啊这个,无语了,循环用来干这个,貌似一般只有数值不够存才这样,一般是高精度计算

论坛徽章:
0
16 [报告]
发表于 2009-05-13 14:03 |只看该作者
呵呵, 楼上诸位都看出了问题
1: 用循环减法, 干了除法运算的事 (我还问他, 你怎么不用循环加来做?那就更牛了)
2: 前面减去的, 后面又加了回来

其实就是一句话

  1. return sizeof(_company_index_t) * ( com_id - 400000000 )
复制代码


这个例子告诉我们, 写代码时保持头脑清醒时多么重要啊

论坛徽章:
0
17 [报告]
发表于 2009-05-13 14:58 |只看该作者
说个现实的笑话,求最大公约数:

有人用辗转相除法,
也有人用辗转相减法,
用减法的人就是这种华丽的家伙,搞不好还在窃喜呢。

论坛徽章:
0
18 [报告]
发表于 2009-05-13 15:07 |只看该作者

回复 #17 styleplus 的帖子

当超出可以表示的数值的时候,貌似就要用减,用数组模拟一个大数值,然后慢慢减代替取余
个人意见

论坛徽章:
0
19 [报告]
发表于 2009-05-15 09:06 |只看该作者
原帖由 daybreakcx 于 2009-5-13 15:07 发表
当超出可以表示的数值的时候,貌似就要用减,用数组模拟一个大数值,然后慢慢减代替取余
个人意见


一根筋到底啊
数组上模拟实现除法,应该也比减法效率高的。

论坛徽章:
0
20 [报告]
发表于 2009-05-15 10:05 |只看该作者
原帖由 styleplus 于 2009-5-15 09:06 发表


一根筋到底啊
数组上模拟实现除法,应该也比减法效率高的。

真是不好意思,数组上模拟除法和我们平时手工算除法是一个道理,我们平时常常是根据经验猜的或者是一个个商去试的,在被除数和除数都很大以至于要利用数组存储时候,数组上实现的话常用的是一次次减去(最多试9次对于十进制)后移位,当然特殊模运算除外(例如2的幂)
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP