求平均数的几种方法
来源:互联网 发布:tcl网络电视如何看直播 编辑:程序博客网 时间:2024/05/29 02:15
平均数:给定两个数a和b,求其平均值;
分析:数学运算中一贯的算法是(a+b)/2,但在c语言中这种算法存在着一定的缺陷,当a和b足够大时,a和b的和就会存在溢出,从而得不到我们想要的结果。c语言中有相应的操作符可达到求平均数的效果,例如:>>(右移),&按为与,^(按位异或)。
1、存在缺陷的算法(a+b)/2
例:
int main(){int a=4,b=2;int ret=0;ret=(a+b)/2;printf("a+b=%d\n",ret);return 0;}
这个程序运行的结果是3,没有问题,满足数学运算里面求平均数的算法,但当我们将a和b的赋值为2147483647,输出的结果为-1;此时,a和b的和为2147483647的2倍,但是编译器中所存放的最大数为2147483647,故发生了溢出,输出的结果为-1。
2、a+(b-a)/2
例:
int main(){int a=2147483647,b=2147483647;/*int a=2,b=4;*/int ret=0;ret=a+(b-a)/2;printf("a+b=%d\n",ret);return 0;}
这个程序首先将b与a的差值求出并且除以2,在加上a;这样的算法保证了程序在运算过程中不会发生溢出现象。即使当a和b的值较大时,也会求得平均数。
3、运用>>右移操作符
例:
int main(){int a=2,b=4;int ret=0;ret=(a+b)>>1;printf("a+b=%d\n",ret);return 0;}此程序利用左移操作符来达到除2的目的以此来求得a和b的平均数。右移操作符是将一个数的所有位向右移动若干位,在这里我们将a和b的和向右移动1位,其高位来到低位,从而达到除2的目的。来看一下实现过程:
3、运用 & 按位与和 >> 按位异或
例:
int main(){int a=2,b=4;int ret=0;ret=(a&b)+((a^b)>>1);printf("a+b=%d\n",ret);return 0;}
按位与操作符规律为:两数的二进制位,相同为1,不同为0。此时按位与的结果可将相同的二进制位留下,不同二进制位置0,达到相同二进制位相加除2的结果;按位异或操作符:两数的二进制位,不同为1,相同为0。此时按位异或的结果将不同的二进制位留下,相同二进制位置0,并且右移1位,达到不同二进制位相加除2的结果。实现过程:
运行结果:
阅读全文
0 0
- 求平均数的几种方法
- 递归的方法求平均数
- 求平均数的简单方法
- 计算两个数的平均数的几种方法解读
- 求十亿个数的平均数的方法
- 整型数据求平均数方法的探讨
- 多种方法求平均数
- 神奇的求平均数
- 求平均数的算法
- 求平均数的方法以及数的移位
- 使用多种方法求两个数的平均数
- 求三个数的平均数
- 求多个数的平均数
- 求若干个数的平均数
- 求两个数的平均数
- 求输入数的平均数
- 求n个数的平均数
- 求几个数的平均数
- java应用MongoDB简单操作
- Ones and Zeroes 问题及解法
- LightOJ 1094 Farthest Nodes in a Tree(dfs)
- getopt、getopt_long和getopt_long_only
- C# 钉钉api接口开发(三) 免登录及自动刷新AccessToken
- 求平均数的几种方法
- ElasticSearch基础
- BZOJ1827 [Usaco2010 Mar]gather 奶牛大集会
- Uiautomator的基础对象
- Android图片加载库的封装实战
- 数据结构实验之链表一:顺序建立链表
- HDU 2196 Computer 树形dp
- JAVA 异常
- RxJava + httpURLConnectionde 的简单测试demo,可以拿来处理一般的android访问网络的线程问题