| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1618 人关注过本帖
标题:数据叠加超过取值范围。
取消只看楼主 加入收藏
Jeff_
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2018-3-25
结帖率:75%
收藏
已结贴  问题点数:16 回复次数:1 
数据叠加超过取值范围。
图片附件: 游客没有浏览图片的权限,请 登录注册

我的思路就是直接(n^2+1)*n^2/2;
但是当输入超过2^63后,超过了数据类型的取值范围,取模的数就不准确。
换个思路,使用每次几个数相加超过10^9就取模,但是循环次数太多,需要条多时间。
论坛找老哥求个解题思路。

新手积分太少,提前谢谢大家帮助。
搜索更多相关主题的帖子: 数据 叠加 取值 范围 思路 
2018-09-30 13:02
Jeff_
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2018-3-25
收藏
得分:0 
回复 3楼 rjsp
#include<iostream>
#include<math.h>
using namespace std;
int main()
{
    long int  n, s, t;
    cin >> n;
      
    s = pow( 2 ,  (long double) n ) * ( 1 + pow( 2, (long  double) n )) / 2 ;
    t = ( pow( (long double) 10, (long double) 9 ) + 7 );
    s = (unsigned)s % (unsigned)t;
    cout << s << endl;
    return 0;
}
这是我第一次写的,发现超过范围,我就想着在1+2+3+....一旦超过范围就取模,但是循环了太多超时了
#include<iostream>
#include<math.h>
using namespace std;
 
int main()
{
    int  num=0;
    double n;
    const double ou=9;
    cin >> n;
    for(int i=0; num<(pow(2,n)+1)*pow(2,n)/2 ; i++)
    {
        if(num>pow(2,ou)+7)
         num=num%(num<pow(2,ou)+7);
        num +=i;
     
    }
    cout << num << endl;
 
    return 0;
}



现在问题是a*b%c变成了(a%c*b%c)但是a超过了范围。 就像我第一次写的  2^n,n输入100,n>63 longlong的取值就超过了 ,然后被取了近似,即使取模得到的也不是准确的数据而是被取近似后的数据。

@ ——!
2018-09-30 17:10
快速回复:数据叠加超过取值范围。
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.033783 second(s), 10 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved