不知道位移是不是最快的,还是有其他更快的方式?
还有 4*4*4*4 呢?
c 编译器
计算器.......
好像是位移。这是面试题吧
从通用的角度还是位运算比较靠谱 但是针对某一个点优化直接做成常量就完了么
long long powll(long long a, long long b) { long long ret = 1; while (b) { if (b & 1) ret *= a; a *= a; b >>= 1; } return ret; }
計算機得到 4*4 答案最快的方法是預先在代碼中直接寫常數 16(不過一般編譯器會也幫你這麼幹)。
但若是 n*4 最快的方法,位移!除非 n = 0(這時候直接返回 0 纔是最快的)。
不過現代 CPU 計算乘法效率已經跟加法似的了,編譯器優化的水平也不是懂一點技巧就能藐視的了,所以,實際情況,直接寫成 4*4,放心地交給編譯器優化(計算機最懂計算機!)纔是最快的(無論從哪個角度哦)。
编译器处理结构体的原理
关于C语言中 函数重复定义的问题
如何编译一个含多个模块的 C 语言程序?
在c语言中,怎样让a ==a不成立??
pthread_create函数的第三个参数加不加&有什么区别?
关于extern函数时参数类型不匹配GCC编译如何可以生成告警或是错误的问题