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

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

新手积分太少,提前谢谢大家帮助。
搜索更多相关主题的帖子: 数据 叠加 取值 范围 思路 
2018-09-30 13:02
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9025
专家分:54030
注 册:2011-1-18
收藏
得分:12 
不要 计算完毕后再模除10^9
而应该 在计算的中途就模除10^9,即 (a * b) % c == (a%c * b%c) % c。
快速幂就行了

BTW:
我的思路就是直接(n^2+1)*n^2/2
写错了吧,我怎么觉得应该是 (2^n+1) * 2^n / 2


2018-09-30 13:52
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9025
专家分:54030
注 册:2011-1-18
收藏
得分:0 
你没贴原始链接,所以不解处我是瞎猜的,以下代码仅供参考
程序代码:
#include <stdio.h>

// 计算 (a^b)%1000000007
unsigned quickpow( unsigned a, unsigned b )
{
    unsigned result = 1;
    for( unsigned t=a; b; b/=2 )
    {
        if( b%2 == 1 )
            result = (result*1ull*t)%1000000007;
        t = (t*1ull*t)%1000000007;
    }
    return result;
}

int main( void )
{
    unsigned n;
    scanf( "%u", &n );

    // 计算 (2^n+1) * 2^n / 2
    unsigned t = quickpow( 2, n-1 );
    unsigned r = unsigned r = ((2*t+1ull)*t)/1000000007;
    printf( "%u\n", r );
}



[此贴子已经被作者于2018-9-30 14:22编辑过]

2018-09-30 14:13
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.025568 second(s), 11 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved