九进制转十进制
cpp
#include <iostream>
#include<math.h>
using namespace std;
int main()
{
cout << 2*pow(9,3)+0*pow(9,2)+2*pow(9,1)+2*pow(9,0) << endl;
return 0;
}
顺子日期
cpp
#include <iostream>
using namespace std;
int main()
{
// 请在此输入您的代码
cout<<14;
//01.20~01.29
//11.23\10.12\12.30\12.31
return 0;
}
只比较后面四位就可以,如果代码算的话直接后面几位差值为1与求就ok,思考的时候写着写着就出答案了
修剪灌木
cpp
#include <iostream>
using namespace std;
int main()
{
int n;
cin>>n;
for(int i=1;i<=n;i++)
{
cout<<max(i-1,n-i)*2<<endl;
}
return 0;
}
妙
X进制减法
cpp
#include <iostream>
using LL=long long;
using namespace std;
const LL MOD=1000000007;
const LL N=1e5+5;
int a[N],b[N];
int main()
{
ios::sync_with_stdio(false);
cin.tie(0),cout.tie(0);
int n; cin>>n;//进制min 2 max n
int ma; cin>>ma;//A的位数
for(int i=ma-1;i>=0;i--) cin>>a[i]; //A每一位的十进制表示
int mb; cin>>mb;//B位数
for(int j=mb-1;j>=0;j--) cin>>b[j]; //B的每一位表示
LL cnt=1,res=0,rgb;//cnt不能等于0
for(int i=0;i<ma;i++)
{
rgb=max(max(a[i],b[i])+1,2);
//进制越小差距越小,二进制最高位只能是0,十进制是9,所以数字加一取最小进制
res=(res+(a[i]-b[i])*cnt)%MOD;
cnt=(cnt*rgb)%MOD;
//cnt放后面是因为 从0次方开始乘
//多次取模为了防止越界
} cout<<res%MOD;
// 请在此输入您的代码
return 0;
}