HDU 4920 Matrix multiplication (硬件优化)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4920
解题报告:求两个800*800的矩阵的乘法。
参考这篇论文:http://wenku.baidu.com/link?url=261XeEzH-AZkFGPiN63t1nnojoQF50yiuMoviHroGjVXjjRlxFcvWLcws0jgQcmZo4oA9BJcjnPxVreWRu-XXa9zb6r5gUUTxmBXn_qWSsu&qq-pf-to=pcqq.group
我看过了,只是简单的了解了一下,本来暴力是会超时的,但是因为C和C++的二维数组都是优先存储行,也就是说在一行元素是存储在相邻位置的,
所以如果把第二个相乘的矩阵转置一下,就可以直接是A[i][k] * B[j][k]了,这样就不会超了,具体的原因自己去看吧。在这篇论文里面有详细介绍。
其次,最好用C提交,因为C还是要比C++快一点的。
#include<stdio.h>
int A[][],B[][],tot,i,j,k;
void Swap(int* a,int* b)
{
int temp = *a;
*a = *b;
*b = temp;
}
int main()
{
int n;
while(scanf("%d",&n)!=EOF)
{
for(i = ;i < n;++i)
for(j = ;j < n;++j)
{
scanf("%d",&A[i][j]);
A[i][j] %= ;
}
for(i = ;i < n;++i)
for(j = ;j < n;++j)
{
scanf("%d",&B[i][j]);
B[i][j] %= ;
}
for(i = ;i < n;++i)
for(j = ;j < i;++j)
Swap(&B[i][j],&B[j][i]);
for(i = ;i < n;++i)
for(j = ;j < n;++j)
{
tot = ;
for(k = ;k < n;++k)
tot += (A[i][k] * B[j][k]);
printf(j == n-? "%d\n":"%d ",tot % );
}
}
return ;
}
HDU 4920 Matrix multiplication (硬件优化)的更多相关文章
- hdu 4920 Matrix multiplication bitset优化常数
		Matrix multiplication Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/ ... 
- HDU 4920 Matrix multiplication(bitset)
		HDU 4920 Matrix multiplication 题目链接 题意:给定两个矩阵,求这两个矩阵相乘mod 3 思路:没什么好的想法,就把0的位置不考虑.结果就过了.然后看了官方题解,上面是用 ... 
- HDU 4920 Matrix multiplication(bitset优化)
		题目链接 Matrix multiplication 求矩阵A和B相乘的结果. 因为答案只要对3取模,所以我们可以通过一些方法来加速计算. 我们对两个矩阵各开两个bitset,分别存储模3余1和模3余 ... 
- hdu 4920 Matrix multiplication(矩阵乘法)2014多培训学校5现场
		Matrix multiplication Time ... 
- HDU 4920 Matrix multiplication 矩阵相乘。稀疏矩阵
		Matrix multiplication Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/ ... 
- HDU 4920 Matrix multiplication(矩阵相乘)
		各种TEL,233啊.没想到是处理掉0的情况就能够过啊.一直以为会有极端数据.没想到居然是这种啊..在网上看到了一个AC的奇妙的代码,经典的矩阵乘法,仅仅只是把最内层的枚举,移到外面就过了啊...有点 ... 
- hdu - 4920 - Matrix multiplication(缓存优化+开挂)
		题意:求两个n x n的矩阵相乘后模3的结果,n <= 800. 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4920 -->>呀呀 ... 
- 2014多校第五场1010 ||  HDU 4920 Matrix multiplication(矩阵乘法优化)
		题目链接 题意 : 给你两个n*n的矩阵,然后两个相乘得出结果是多少. 思路 :一开始因为知道会超时所以没敢用最普通的方法做,所以一直在想要怎么处理,没想到鹏哥告诉我们后台数据是随机跑的,所以极端数据 ... 
- hdu 4920 Matrix multiplication (矩阵计算)
		题目链接 题意:给两个矩阵a, b, 计算矩阵a*b的结果对3取余. 分析:直接计算时间复杂度是O(n^3),会超时,但是下面第一个代码勉强可以水过,数据的原因. #include <iostr ... 
随机推荐
- JavaScript实现Ajax小结
			置顶文章:<纯CSS打造银色MacBook Air(完整版)> 上一篇:<TCP的三次握手和四次挥手> 作者主页:myvin 博主QQ:851399101(点击QQ和博主发起临 ... 
- session放到mongo里边
			为了session的共享和保存,常常把session放数据库里边,但是很多时候都放redis里边,今天看了一个放Mongo中的记录下,说不懂什么时候就用到了. app.use(session({ se ... 
- Web Service 小练习
			对于网站与网站之间数据互动,这是我的说法,不是专家说的,不要相信.应该有专业的说法. 从他人的网站通过一个接口获取数据,这一直是我感到神奇的事,怎么实现的,一直萦绕于心,想要弄过究竟,怎么是实现的啊! ... 
- 配置域主DNS服务器
			一.DNS服务器的类型 ①Primary DNS Server(Master) 一个域的主服务器保存着该域的zone配置文件,该域所有的配置.更改都是在该服务器上进行,本篇随笔要讲解的也是如何配置一个 ... 
- Javascript继承机制的设计
			写软工作业时各种蛋疼:主要在于Javascript没有“子类”“父类”“接口”的概念,只能使用prototype来实现,看了下面一篇文章,感觉写得很不错~ http://www.ruanyifeng. ... 
- 传智168期JavaEE就业班 day03-js
			* 课程回顾: * CSS * CSS的简介 * 层叠样式表. * CSS与HTML的结合(4种) * HTML的标签提供了属性 style="CSS的代码" * HTML提供了标 ... 
- Java设计模式-工厂方法模式(Factory Method)
			工厂方法模式(Factory Method) 工厂模式适合:凡是出现了大量的产品需要创建,并且具有共同的接口时,可以通过工厂方法模式进行创建.在以下的三种模式中,第一种如果传入的字符串有误,不能正确创 ... 
- 曲线行驶s弯道技巧图解【转】
			s弯道怎么走?在走S弯的时候,最主要的就是控制车的速度,在做每个动作的时候要保持一样的速度,不要一会快一会慢的,在开的时候,因为每个人的身高,体型不一样,每个人看的点位都是不一样的,每次在开的时候要找 ... 
- CodeMap
			CodeMap 这是在博客园看到的一位朋友文章介绍的,很好用的插件,所有的方法,注释块在右边一目了然,找代码方便极了,还能设置代码段的高亮,给代码段设置标识 
- C#图片读取和保存
			using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ... 
