博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
2015 HDU 多校联赛 5363 Key Set
阅读量:6088 次
发布时间:2019-06-20

本文共 747 字,大约阅读时间需要 2 分钟。


题目: 

pid=5363

依据前面给出的样例,得出求解公式 fn = 2^(n-1) - 1, 数据量大,实际就是求幂次方。

 

可用分治法求解。复杂度O(nlogn)

// 分治法求高速幂#include 
using namespace std;typedef unsigned long long ull;const int MOD = 1000000007;ull getAns(ull a, int n){ if (n==0) return 1; if (n==1) return a; else { a %= MOD; ull res = a*a; res %= MOD; if (n%2 == 0) { return getAns(res, n/2)%MOD; } else { return (getAns(res, n/2)*a)%MOD; } }}int main(void){ //freopen("in.txt", "r", stdin); int t = 0; scanf("%d", &t); ull a = 2; while(t--) { int n = 0; scanf("%d", &n); printf("%lld\n", getAns(a, n-1)-1); // 2^(n-1) - 1 } return 0;}

转载地址:http://repwa.baihongyu.com/

你可能感兴趣的文章
Flux OOM实例
查看>>
07-k8s-dns
查看>>
Android 中 ListView 分页加载数据
查看>>
oracle启动报错:ORA-00845: MEMORY_TARGET not supported on this system
查看>>
Go方法
查看>>
Dapper丶DapperExtention,以及AbpDapper之间的关系,
查看>>
搞IT的同学们,你们在哪个等级__那些年发过的帖子
查看>>
且谈语音搜索
查看>>
MySQL数据库导入导出常用命令
查看>>
低版本Samba无法挂载
查看>>
Telegraf+Influxdb+Grafana构建监控平台
查看>>
使用excel 展现数据库内容
查看>>
C#方法拓展
查看>>
MySql.Data.dll的版本
查看>>
Linux系统磁盘管理
查看>>
hdu 2191 (多重背包+二进制优化)
查看>>
home.php
查看>>
neo4j---删除关系和节点
查看>>
redis分布式锁redisson
查看>>
什么样的企业可以称之为初创企业?
查看>>