Strassen __128int

你说的曾经没有我的故事 提交于 2019-11-28 13:18:29

题目链接

题意思路很简单,递归求最小就好了。但__128int没见过。故写博客记下。__128int如果输入输出就要自己写函数。

#include<bits/stdc++.h>
using namespace std;
const int mo=1e9+7;
typedef __int128 lll;
int T,a,b;long long n;
lll calc(lll n)
{
    lll ans=n*n*n*b+(n-1)*n*n*a;
    if(n%2==0)
    ans=min(ans,18*(n/2)*(n/2)*a+7*calc(n/2));
    return ans;
}
int main(){
    scanf("%d",&T);
    while(T--)
    {
        cin>>n>>a>>b;
        printf("%d\n",int(calc(n)%mo));
    }
    return 0;
}

 

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!