| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1037 人关注过本帖
标题:快速幂,哪错了?
只看楼主 加入收藏
cb_1212
Rank: 1
等 级:新手上路
帖 子:126
专家分:5
注 册:2011-4-28
结帖率:66.67%
收藏
已结贴  问题点数:10 回复次数:19 
快速幂,哪错了?
计算a^k(mod m)
多组测试数据,a k m为正整数且0<a,k,m<=10^18



程序代码:
#include<cstdio>
__int64 quickpow(__int64 a,__int64 k,__int64 mod)
{
    __int64 temp=1;
    while(k>0){
        if(k&1)
            temp=a*temp%mod;  
        a=a*a%mod;      
        k/=2;
    }
    return temp;
}
int main()
{
    __int64 a,k,m;
    while(~scanf("%I64d%I64d%I64d",&a,&k,&m)){
        printf("%I64d\n",quickpow(a,k,m));
    }
    return 0;
}
搜索更多相关主题的帖子: 快速 测试 正整数 
2012-03-19 00:10
jianyuling00
Rank: 3Rank: 3
来 自:琼州学院
等 级:论坛游侠
帖 子:89
专家分:177
注 册:2012-3-17
收藏
得分:0 
头文件改为stdio.h

cstdio是标准 C++(STL),LZ是不是编着编着就混了?呵呵

[ 本帖最后由 jianyuling00 于 2012-3-19 00:16 编辑 ]
2012-03-19 00:15
cb_1212
Rank: 1
等 级:新手上路
帖 子:126
专家分:5
注 册:2011-4-28
收藏
得分:0 
回复 2楼 jianyuling00
用G++提交可以的吧,这个是C++的写法
2012-03-19 00:16
jianyuling00
Rank: 3Rank: 3
来 自:琼州学院
等 级:论坛游侠
帖 子:89
专家分:177
注 册:2012-3-17
收藏
得分:0 
那std::呢?
你也没申明use namespace std

咦?我用dev c++也可以运行啊.....

[ 本帖最后由 jianyuling00 于 2012-3-19 00:22 编辑 ]
2012-03-19 00:18
cb_1212
Rank: 1
等 级:新手上路
帖 子:126
专家分:5
注 册:2011-4-28
收藏
得分:0 
回复 4楼 jianyuling00
不需要使用命名空间啊。不是头文件的问题,我G++提交WA了,唉唉。
2012-03-19 00:21
jianyuling00
Rank: 3Rank: 3
来 自:琼州学院
等 级:论坛游侠
帖 子:89
专家分:177
注 册:2012-3-17
收藏
得分:0 
我告诉你,代码没错的dev c++下完全可以运行
2012-03-19 00:26
cb_1212
Rank: 1
等 级:新手上路
帖 子:126
专家分:5
注 册:2011-4-28
收藏
得分:0 
回复 6楼 jianyuling00
可关键是答案错,我晕
2012-03-19 00:30
jianyuling00
Rank: 3Rank: 3
来 自:琼州学院
等 级:论坛游侠
帖 子:89
专家分:177
注 册:2012-3-17
收藏
得分:0 
让高手来吧,我也是新手入门阶段,热心点罢了,呵呵
2012-03-19 00:33
cb_1212
Rank: 1
等 级:新手上路
帖 子:126
专家分:5
注 册:2011-4-28
收藏
得分:0 
回复 8楼 jianyuling00
嗯嗯~期待杨大哥进啊~~
2012-03-19 00:38
czz5242199
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:4
帖 子:660
专家分:2400
注 册:2011-10-26
收藏
得分:4 
程序代码:
#include <cstdio>

__int64 quickpow(__int64 a,__int64 k,__int64 mod)
{   
    if (k==0) return 1;
    __int64 temp=quickpow(a,k/2,mod);
    if (k&1) return temp*temp*a%mod;
    return temp*temp%mod;
}
int main()
{
    __int64 a,k,m;
    while(~scanf("%I64d%I64d%I64d",&a,&k,&m)){
        printf("%I64d\n",quickpow(a,k,m));
    }
    return 0;
}
2012-03-19 00:45
快速回复:快速幂,哪错了?
数据加载中...
 
   



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

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