C语言优化的方法
内部或嵌套循环,调用第三方库的方法通常是导致程序运行缓慢的最主要的起因。
整形数
如果我们确定整数非负,就应该使用unsigned int而不是int。
register unsigned int variable name;
整形in的运算速度高浮点型float,并且可以被处理器直接完成运算,而不需要借助于FPU(浮点运算单元)或者浮点型运算库。
除法和取余数
除法函数消耗的时间包括一个常量时间加上每一位除法消耗的时间。
可以通过乘法表达式来替代除法。
例如,假如我们知道b是正数并且b*c是个整数,那么(a/b)>c可以改写为a>(c * b)。如果确定操作数是无符号unsigned的,使用无符号unsigned除法更好一些,因为它比有符号signed除法效率高。
合并除法和取余数
过调用一次除法操作返回除法的结果和余数。
如果既需要除法的结果又需要余数
int func_div_and_mod (int a, int b)
{return (a / b) + (a % b);
}
通过2的幂次进行除法和取余数
使用移位操作来执行除法。
typedef unsigned int uint;
uint div32u (uint a)
{return a / 32:
}int div32s (int a)
{return a / 32;
}
取余数操作符来提供算数取模。
//输入的count结余0至5