免费注册 查看新帖 |

Chinaunix

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

求平均值 [复制链接]

论坛徽章:
0
21 [报告]
发表于 2008-07-06 09:45 |只看该作者
原帖由 luojiannx 于 2005-9-30 23:41 发表
整数?
也就是说INT类型的?32位的整数?
好办得很啊
32位整数最大才多少?
gcc不是有long long 类型么?好象C99标准要求至少是64位的

/* Minimum and maximum values a `signed int' can hold.   ...

同意这个

论坛徽章:
0
22 [报告]
发表于 2008-07-06 10:08 |只看该作者
我还是觉得 不停的运算和,如果和要一旦溢出的话,就马上计算平均值并保存起来,知道计算完成

时间复杂度o(n)
double vAverageGet(int *iInputData, int iTotalNum)
{
    double dAverage;
    int iSum;
    int iCounter;
    int *iTempDataPtr;
   
    dAverage = 0;
    iCounter = 0;
    iTempDataPtr = iInputData;
   
    while (iCounter < iTotalNum)
    {
        iSum = 0;
        
        while ((iSum + *iTempDataPtr) <= (pow(2, 31) - 1)
            && ((iSum + *iTempDataPtr) >= (int)((pow(2, 31) * (-1)))))
        {
            iSum += *iTempDataPtr;
            iCounter++;
            iTempDataPtr++;
        }
        
        dAverage += (double)iSum / iTotalNum;
    }
   
    return dAverage;
}
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP