文章目录
- 栈的操作
- 题目描述
- 输入格式
- 输出格式
- 样例 #1
- 样例输入 #1
- 样例输出 #1
- 提示
- AC代码
栈的操作
题目描述
现在有四个栈,其中前三个为空,第四个栈从栈顶到栈底分别为 1 , 2 , 3 , ⋯ , n 1,2,3,\cdots ,n 1,2,3,⋯,n。每一个栈只支持一种操作:弹出并压入。它指的是把其中一个栈 A 的栈顶元素 x x x 弹出,并马上压入任意一个栈 B 中。但是这样的操作必须符合一定的规则才能进行。
- 规则 1 1 1:A 栈不能为空。
- 规则 2 2 2:B 栈为空或 x x x 比 B 栈栈顶要小。
对于给定的 n n n,请你求出把第四个栈的 n n n 个元素全部移到第一个栈的最少操作次数。
由于最少操作次数可能很多,请你把答案对 1 0 6 + 7 10^6+7 106+7 取模。
输入格式
一行,一个整数 n n n。
输出格式
一行,一个正整数,为把最少操作次数 m o d ( 1 0 6 + 7 ) \bmod (10^6+7) mod(106+7) 的值。
样例 #1
样例输入 #1
2
样例输出 #1
3
提示
- 对于 30 % 30\% 30% 的数据, n ≤ 8 n\le 8 n≤8。
- 对于 60 % 60\% 60% 的数据, n ≤ 60 n\le 60 n≤60。
- 对于 100 % 100\% 100% 的数据, n ≤ 2 × 1 0 9 n\le 2\times 10^9 n≤2×109。
AC代码
#include<bits/stdc++.h>
using namespace std;
long long n,k=1,v=1,ans,mo=1e6+7;
int main() {
cin>>n;
for(k=1,v=1;n>k;n-=k,k++,v=(v+v)%mo){
ans=(ans+k*v)%mo;
}
cout<<(ans+n*v)%mo;
return 0;
}