hdu 4364 矩阵乘法
2012-08-18 10:06
309 查看
矩阵乘法都忘了,伤不起。是第一行和第一列每个对应的位置相乘得到第一个位置的数。忘了的结果就是肿么都看不懂为什么会有三个for。
http://zh.wikipedia.org/wiki/%E7%9F%A9%E9%99%A3%E4%B9%98%E6%B3%95
题意:
矩阵乘法里面的加改成了异或,乘法定义是:
与1相乘不变,与2相乘往左移一位,与3相乘是往左移一位之后和原来的数异或。左移后大于0xFF要和 0x1B异或。
解:
将加改成xor,乘改成相应的运算即可。
尤其要注意,矩阵中的数是8位的,所能表示的最大数为255,所以,左移后要与上255或对256取模。
http://zh.wikipedia.org/wiki/%E7%9F%A9%E9%99%A3%E4%B9%98%E6%B3%95
题意:
矩阵乘法里面的加改成了异或,乘法定义是:
与1相乘不变,与2相乘往左移一位,与3相乘是往左移一位之后和原来的数异或。左移后大于0xFF要和 0x1B异或。
解:
将加改成xor,乘改成相应的运算即可。
尤其要注意,矩阵中的数是8位的,所能表示的最大数为255,所以,左移后要与上255或对256取模。
/* Pro: 0 Sol: date: */ #include <cstdio> #include <string> #include <cstring> #include <cstdlib> #include <cmath> #include <ctime> #include <set> #include <map> #include <deque> #include <vector> #include <algorithm> #include <iostream> using namespace std; int a[4][4]={2,3,1,1,1,2,3,1,1,1,2,3,3,1,1,2}; int main(){ int t,mat[4][4],ans[4][4]; scanf("%d",&t); while(t--){ for(int i=0;i<4;i++) for(int j=0;j<4;j++){ scanf("%X",&mat[i][j]); } for(int i = 0; i < 4; i ++){//枚举行 for(int j = 0; j < 4; j ++){//枚举列 ans[i][j] = 0; for(int k = 0; k < 4; k ++){//又是枚举 int tmp = mat[k][j]; if(a[i][k] != 2) ans[i][j] ^= tmp; if(a[i][k] != 1){ if(tmp & (1 << 7))//如果移动后的值比0xff大的话 ans[i][j] ^= 27;//xor上0x1b ans[i][j] ^= (tmp << 1) & 255; } } } } for(int i=0;i<4;i++){ for(int j=0;j<3;j++) printf("%02X ",ans[i][j]); printf("%02X\n",ans[i][3]); } if(t) puts(""); } return 0; }
相关文章推荐
- hdu 4364(矩阵相乘)
- HDU 4364 Matrix operation(矩阵)
- 矩阵乘法模板之hdu——1751
- hdu 1588 Gauss Fibonacci(矩阵乘法+二分)
- HDU 4565——So Easy!(矩阵快速幂乘法)
- hdu 2276 Kiki & Little Kiki 2(矩阵构造乘法)
- HDU 3221 上海09 B题 矩阵乘法 数论
- hdu 4965(矩阵乘法 )
- hdu_1588_矩阵_求和_乘法_快速幂_斐波那契数列求前n项和
- hdu 5451 Best Solver 快速矩阵乘法 Fibonacci数列的循环节
- [HDU 5950]Recursive sequence:矩阵乘法
- PKU 2778 HDU 2243 AC自动机 + 矩阵乘法
- 【矩阵乘法实践】HDU 1575——Tr A
- HDU 1005(矩阵乘法)
- HDU 4914 Linear recursive sequence(矩阵乘法递推的优化)
- hdu 1575 Tr A(矩阵乘法)
- hdu 5451 Best Solver(矩阵乘法+数论)
- hdu 4965 Fast Matrix Calculation 矩阵乘法
- HDU 4307 Matrix 最小割 矩阵乘法展开
- hdu 4920 Matrix multiplication(矩阵乘法)