前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >程序员圣诞节烧脑谈

程序员圣诞节烧脑谈

作者头像
tyrchen
发布2019-11-12 09:55:38
4210
发布2019-11-12 09:55:38
举报
文章被收录于专栏:程序人生程序人生

今天不光是万圣节,31 OCT,也就是 25 DEC,所以也是程序员圣诞节。

。。。

好吧,OCT 代表八进制,八进制的 31,是十进制的 25,而十进制是 DEC。嗯,标准的程序员冷笑话,认真你就输了。

(我仿佛听到了郭德纲的相声在我耳边想起:你有病吧,你有药啊)

进制这个东西,很有意思。我们要感谢进化过程中,人类进化出的是五根手指,如果是 7 根手指,那么我们日常生活的进制就是 14 进制,小学数学的难度大概率要陡增 —— 因为要背 13x13 乘法表。

平日生活中,除了占绝对优势的十进制外,我们还使用十二进制(买袜子鸡蛋什么的),六十进制(计时以及角度的分和秒),三百六十进制(角度),三百六十五进制(计日)。有些文化中会使用二十进制,比如 84 非要说成四个二十和一个四,自己给自己找麻烦。在程序员的生活中,十进制不是主流,二进制,十六进制和八进制才是王道。衍生出来的 64 进制,二十六个字母大小写加十个数字再加两个符号,也堂而皇之出现在主流圈子里,之后,为了解决 IlO0 傻傻分不清的问题,比特币又从 64 进制中衍生出来 58 进制。

我们讲进制,比如二进制,是逢二进一,所以自最低位起,往上是 21,22,一路走上去。对于一个 x 进制数,我们以此类推:

这就有意思了,原来一个多项式代表的是一个进制未知的数!那么我们是否可以把多项式的乘除用我们惯用的十进制乘除来表述呢?

比如 x3 + 3x2 + 5x + 15 除以 x + 3 怎么算?在初高中的时候,我们需要对这个多项式进行因式分解,分解起来并不容易。而我们将其看做十进制的数字,就是 135(15),也就是 1365,除以13,得 105,再把 10 进制转换成 x 进制,得到:x2 + 5。完美。乘法也是如此 —— 只是要注意进位写成 135(15) 的形式,不要往上进。

列位可能要问了,那 x2 − 1 这样含有负数的多项式除以 x − 1 怎么办?x2 − 1 放成十进制来看,是 (100-1),而 x − 1 是 (10-1),除出来的结果是 11,换算回来是 x + 1。轻松搞定!注意这里有借有还,比如 x − 1 乘以 x3 + x2 + x + 1,是 (10-1) 乘以 1111,得 9999,我们需要将其还原成 (10000-1),也就是 x4 − 1。

既然进位系统可以是 2,3,5,10,60,365,那么可不可以是 0.5 呢?哈,0.5 进位意味着个位数置一,十位数就进二,然后百位数进四,一路无穷下去。这是个奇怪的进位系统,任何数都无穷无尽。

那么 1.5 进制呢?也就是说逢三进二?1.5 进制的 20 代表十进制 3,2100 代表十进制的 9。这个进制写成表达式是 2 × 1.53 + 1.52。

所以逢 x 进 y 的进制的一个数 1234,代表 (x/y)3 + 2 × (x/y)2 + 3 × (x/y) + 4。很好很奇葩。有什么用?似乎没用。数学上的东西就是这样,就像庄子所谓「有用之无用」:今子有大树,患其无用,何不树之於无何有之乡,广莫之野?

扯了一堆有的没的,有些是给小宝讲数学时她傻乎乎问的,有些是我看了网上的视频琢磨的。程序员圣诞节本不该扯这些玩意的,伤脑。

祝大家节日快乐!

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-11-01,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 程序人生 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档