【题目链接】

  http://acm.hdu.edu.cn/showproblem.php?pid=6719


在本题中,我们只有两种方法计算两个的矩阵的乘积,第一种为定义法,需要次乘法和次加法。第二种为Strassen分治法,仅当为偶数时可以使用,需要次加法以及再计算次大小为的矩阵的乘积。这次更小矩阵的乘积也可以选择两种方法之一计算。现假设计算机计算一次加法需要单位时间,计算一次乘法需要单位时间,其他任何操作不花费时间,问计算两个的矩阵的乘积至少需要多少时间。输出答案模的余数。

定义法: A * n * n * (n-1) + B * n * n * n

Strassen:A * ( n / 2 ) * ( n / 2 ) * ( n - 1 ) +  7 * Min (定义法(n/2),Strassen(n/2))

C++

 #include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const ll mod = 1e9+;
ll A,B,x;
ll Matrix_Mul( ll n ){
n %= mod ;
ll t1 = B * n % mod * n % mod * n % mod ;
ll t2 = A * n % mod * n % mod * (n-) % mod ;
return ( t1%mod + t2%mod + mod ) % mod ;
} ll Strassen( ll n ){
if( n& )
return Matrix_Mul(n); if( n <= * A / (A+B) )
return Matrix_Mul(n); ll Half_n = n / ;
ll t1 = 18ll * Half_n % mod * Half_n % mod * A % mod ;
ll t2 = 7ll * Strassen( Half_n ) % mod ;
return ( t1 + t2 + mod ) % mod ;
}
int main()
{
ios_base :: sync_with_stdio(false);
cin.tie(NULL) , cout.tie(NULL) ; int T;
cin >> T ;
while( T-- ){
cin >> x >> A >> B ;
cout << Strassen(x) << endl;
}
return ;
}

Java

 import java.math.* ;
import java.util.*;
import java.security.MessageDigest;
public class Main{ static BigInteger Zero = new BigInteger ("");
static BigInteger One = new BigInteger ("");
static BigInteger Two = new BigInteger ("") ;
static BigInteger Four = new BigInteger ("") ;
static BigInteger Seven = new BigInteger ("");
static BigInteger Eighteen = new BigInteger ("") ;
static BigInteger Mod = new BigInteger(""); static BigInteger Martirx_Mul( BigInteger n , BigInteger a , BigInteger b ){
BigInteger Step1 = n.multiply(n).multiply(n).multiply(b) ;
BigInteger Step2 = n.subtract(One).multiply(n).multiply(n).multiply(a) ;
BigInteger Ans = Step1.add(Step2);
return Ans;
} static BigInteger Strassen( BigInteger x , BigInteger a , BigInteger b ){ if( x.equals(One) )
return Martirx_Mul( One , a , b ); BigInteger Half_x = x.divide(Two);
BigInteger Step1 = Eighteen.multiply( Half_x ).multiply(Half_x).multiply( a );
BigInteger Step2 = Seven.multiply( Strassen( Half_x , a ,b ).min(Martirx_Mul(Half_x,a,b)) ) ;
BigInteger Mul = Step1.add(Step2);
return Mul.min( Martirx_Mul(x,a,b) );
} public static void main( String[] args ){
Scanner cin = new Scanner(System.in);
int T = cin.nextInt();
while( T -- > ){
BigInteger a,b,n; n=cin.nextBigInteger();
a=cin.nextBigInteger();
b=cin.nextBigInteger();
BigInteger ans=Strassen(n,a,b).mod(Mod);
System.out.println(ans);
}
} }

【百度之星2019】Strassen的更多相关文章

  1. 百度之星2019第一场1002 Game

    思路: 离散化之后dp,dp[i][j]表示完成前i个任务并且处在第j个点所需要的最小代价. 实现: #include <bits/stdc++.h> using namespace st ...

  2. 百度之星 2019 预赛三 A 最短路 1

    题目链接 分析 异或运算满足「三角不等式」. $\forall a, b, c \in \mathbb{Z}_{\ge 0}$,有 $a \xor b \le (a \xor c) + (c \xor ...

  3. 2019 年百度之星·程序设计大赛 - 初赛四 1001 Strassen

    比赛链接:2019 年百度之星·程序设计大赛 - 初赛四 题目链接:HDU-6719 Strassen C++ 没写出来 于是直接上 Java 暴力. 好像可以用 __int128. import j ...

  4. 2019 年百度之星·程序设计大赛 - 初赛一 C. HDU 6670 Mindis 离散化+dijkstra

    题目链接 :http://acm.hdu.edu.cn/showproblem.php?pid=6670 Mindis Time Limit: 4000/2000 MS (Java/Others) M ...

  5. 2019 年百度之星·程序设计大赛 - 初赛一Game HDU 6669 (实现,贪心)

    Game Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submissi ...

  6. 2019 年百度之星 初赛一 1002 Game

    传送门 Problem Description 度度熊在玩一个好玩的游戏.游戏的主人公站在一根数轴上,他可以在数轴上任意移动,对于每次移动,他可以选择往左或往右走一格或两格.现在他要依次完成 n 个任 ...

  7. 2016百度之星 初赛2A ABEF

    只做了1001 1002 1005 1006.剩下2题可能以后补? http://acm.hdu.edu.cn/search.php?field=problem&key=2016%22%B0% ...

  8. 2016百度之星 资格赛ABCDE

    看题:http://bestcoder.hdu.edu.cn/contests/contest_show.php?cid=690 交题:http://acm.hdu.edu.cn/search.php ...

  9. HDU 5690:2016"百度之星" - 初赛 All X

    原文链接:https://www.dreamwings.cn/hdu5690/2657.html All X Time Limit: 2000/1000 MS (Java/Others)    Mem ...

随机推荐

  1. 2018-2019-2 20165114《网络对抗技术》 Exp 8 Web基础

    Exp 8 Web基础 目录 一.实验内容 二.基础问题回答 (1)什么是表单 (2)浏览器可以解析运行什么语言. (3)WebServer支持哪些动态语言 三.实践过程记录 3.1Web前端HTML ...

  2. git 和conding.net 超详细超简单安装

    在做一下操作前,希望你能知道 1.什么是git? 可以参考https://blog.csdn.net/a909301740/article/details/81636662 如果还想多了解一下还可以参 ...

  3. 个微信小程序云开发云函数

    1. project.config.json写上云函数所在目录"cloudfunctionRoot": "cloudfunctions/",如图 2. app. ...

  4. 阿里巴巴微服务与配置中心技术实践之道 原创: 坤宇 InfoQ 2018-02-08

    阿里巴巴微服务与配置中心技术实践之道 原创: 坤宇 InfoQ 2018-02-08

  5. YApi内部部署文档

    旨在为开发.产品.测试人员提供更优雅的接口管理服务.可以帮助开发者轻松创建.发布.维护 API 1.安装Node.js环境(7.6+) 1.官网下载适合的nodejs版本放置在/usr/package ...

  6. OSError: image file is truncated (28 bytes not processed)

    解决办法: 在代码中添加两行 from PIL import ImageFile ImageFile.LOAD_TRUNCATED_IMAGES = True

  7. OSG 遍历fbx节点

    count:560 construction_worker 4294967295 osg::MatrixTransform1 Bip001 L Finger02 4294967295 osg::Mat ...

  8. 阶段5 3.微服务项目【学成在线】_day09 课程预览 Eureka Feign_09-课程详情页面静态化-静态页面测试

    4 课程详情页面静态化 4.1 静态页面测试 4.1.1 页面内容组成 我们在编写一个页面时需要知道哪些信息是静态信息,哪些信息为动态信息,下图是页面的设计图: 打开静态页面,观察每部分的内容. 红色 ...

  9. 阶段5 3.微服务项目【学成在线】_day17 用户认证 Zuul_12-用户退出-服务端

    实现退出 用户退出要以下动作: 1.删除redis中的token 2.删除cookie中的token controller内定义 spring securety config内放行 对这个url放行 ...

  10. java最简单复制文件方法,不依赖任何框架

    java最简单复制文件方法   把java2.txt内容复制到java.txt中 import java.io.File; import java.io.IOException; import jav ...