Codeforces 337C Quiz 贪心+快速幂
来源:互联网 发布:2017软件行业利润 编辑:程序博客网 时间:2024/05/03 16:28
点击打开链接
题意:n个题目,答对m次,答对1次+1分,连续答对k次,则当前分数翻倍,n,m,k<=1e9,求最低得分
分数最小,则尽量不翻倍令b=n/k,r=n%k 则每次连续答对k-1次 然后错一次,分数不翻倍时最多能答对y=b*(k-1)+r道题目
若m>y 则分数肯定会翻倍 选分数较小时翻倍 则有x=m-y次翻倍 翻倍的分数为 t=(((k*2+k)*2)+k)*2...
t=2^x*k+2^(x-1)*k...k=k*2^(1+...x)=k*(2^(x+1)-2)(没有2^0) n<=1e9,用快速幂计算即可
#include <bits/stdc++.h>using namespace std;typedef unsigned long long ll;const ll mod=1e9+9;const int N=2e5+20;ll n,m,k;ll quick_pow(ll a,ll b){ll s=1;while(b){if(b&1)s=(s*a)%mod;a=(a*a)%mod;b>>=1;}return s;}int main(){while(cin>>n>>m>>k){ll b=n/k;ll r=n%k;ll y=b*(k-1)+r;if(y>=m)cout<<m<<endl;else{ll x=m-y;ll ans=(k*((quick_pow(2,x+1)-2+mod)%mod))%mod;ans=(ans+m-x*k)%mod;//减去前x组每组k个cout<<ans<<endl;}}return 0;}
0 0
- Codeforces 337C Quiz 贪心+快速幂
- Codeforces 337C Quiz【贪心+快速幂】
- codeforces 337C-quiz 贪心加矩阵快速幂
- Codeforces 337C:Quiz(贪心+规律+快速幂)
- codeforces 337C Quiz(快速幂+推公式+贪心)
- codeforces - 337c Quiz【贪心】
- 【codeforces 337C Quiz】 + 贪心
- CodeForces - 337 C. Quiz【贪心】
- 【CodeForces】337C - Quiz(贪心,思维)
- Codeforces Round #196 (Div. 2) / 337C Quiz (贪心&快速幂取模)
- Codeforces Round #196 (Div. 2) C--Quiz(快速幂+贪心)
- codeforces 337C Quiz
- CodeForces 337C. Quiz
- CodeForces 337C. Quiz
- CodeForces 337C Quiz(二分,快速幂,答题得分最小值)
- CodeForces 337C Quiz(1等比数列找规律)
- 337C - Quiz
- cf-337C Quiz
- 周末教育交流游记
- 常见JedisConnectionException异常分析
- 用户切换头像,可以选择相册和相机,也可以发送到服务器
- Java位运算
- 手机设计公司最基本的六个部门:ID、MD、HW、SW、PM、Sourcing、QA
- Codeforces 337C Quiz 贪心+快速幂
- 在一个千万级的数据库查寻中,如何提高查询效率?
- 王爽 汇编语言 第三版 实验15 安装新的int 9中断例程
- Android知识点之JNI与NDK
- 破解金山ocr文字识别软件
- javascript Date format(js日期格式化)
- angular之表单验证
- Android开发 解决AlertDialog中的EditText无法调出输入法的问题
- linux 物理内存和虚拟内存