E

茜茜的计算器

https://ac.nowcoder.com/acm/contest/84851/E

一共可以分成两部分:

  1. 只考虑1,3,8,0 四个数字,对于横对称轴有4^n种情况;对于纵对称轴有8,0两个数字,有2^n种情况;而同时满足横轴和纵轴的也只有0,8两个数字,所以抵消纵对称的情况。第一部分只有4^n种。

  2. 考虑2和5两个数字,假设一个位置放了2(5),另一边必须放上5(2),而对称位置有 m = n / 2 个,从m个位置中选择1,2,3,...,m个位置来放2或者5,每个位置有2种情况,其他位置只能放8或者0,每个位置也有2种情况,来保持纵轴对称,于是有表达式 alt 如果 n 是奇数,中间位置可以放8或者0两个数字,要多*2。

#include <bits/stdc++.h>
using namespace std;
using ll = long long;
ll n, m;
int mod = 1e9 + 7;
ll qm(ll x, ll y){
    ll ret = 1;
    while(y){
        if(y&1) ret = ret * x % mod;
        x = x * x % mod;
        y >>= 1;
    }
    return ret;
}
void solve()
{
    cin >> n;
    ll res = 0;
    res = (res + qm(4, n)) % mod; 
    m = n / 2;    
    if(n % 2 == 1) {
        res = (res + 2*(qm(2, m) - 1 + mod) * qm(2, m) % mod) % mod;
    }
    else {
        res = (res + (qm(2, m) - 1 + mod) * qm(2, m) % mod) % mod;
    }
    cout << res;
}
int main()
{
  // 请在此输入您的代码
    ios::sync_with_stdio(0);
    cin.tie(0);
    int _ = 1;
//     cin >> _;
    while(_--) solve();
}
全部评论

相关推荐

10-09 00:50
已编辑
长江大学 算法工程师
不期而遇的夏天:1.同学你面试评价不错,概率很大,请耐心等待;2.你的排名比较靠前,不要担心,耐心等待;3.问题不大,正在审批,不要着急签其他公司,等等我们!4.预计9月中下旬,安心过节;5.下周会有结果,请耐心等待下;6.可能国庆节前后,一有结果我马上通知你;7.预计10月中旬,再坚持一下;8.正在走流程,就这两天了;9.同学,结果我也不知道,你如果查到了也告诉我一声;10.同学你出线不明朗,建议签其他公司保底!11.同学你找了哪些公司,我也在找工作。
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务