首页 > 其他 > 详细

HDOJ 5671 Matrix

时间:2016-04-29 17:34:24      阅读:267      评论:0      收藏:0      [点我收藏+]

Matrix

Time Limit: 3000/1500 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)
Total Submission(s): 780    Accepted Submission(s): 330


Problem Description
There is a matrix M技术分享 that has n技术分享 rows and m技术分享 columns (1n1000,1m1000)技术分享.Then we perform q(1q100,000)技术分享 operations:

1 x y: Swap row x and row y (1x,yn)技术分享;

2 x y: Swap column x and column y (1x,ym)技术分享;

3 x y: Add y to all elements in row x (1xn,1y10,000)技术分享;

4 x y: Add y to all elements in column x (1xm,1y10,000)技术分享;
 

Input
There are multiple test cases. The first line of input contains an integer T(1T20)技术分享 indicating the number of test cases. For each test case:

The first line contains three integers n技术分享, m技术分享 and q技术分享.
The following n技术分享 lines describe the matrix M.(1M技术分享i,j技术分享10,000)技术分享 for all (1in,1jm)技术分享.
The following q技术分享 lines contains three integers a(1a4)技术分享, x技术分享 and y技术分享.
 

Output
For each test case, output the matrix M技术分享 after all q技术分享 operations.
 

Sample Input
2 3 4 2 1 2 3 4 2 3 4 5 3 4 5 6 1 1 2 3 1 10 2 2 2 1 10 10 1 1 1 2 2 1 2
 

Sample Output
12 13 14 15 1 2 3 4 3 4 5 6 1 10 10 1
Hint
Recommand to use scanf and printf
 


中文题面:BC Round #81 (div.2)1002  


代码如下:

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int map[1010][1010];
int row[1010],col[1010];
int hx[1010],hy[1010]; 
int main()
{
	int t,n,m,q,i,j,a,x,y;
	scanf("%d",&t);
	while(t--)
	{
		scanf("%d%d%d",&n,&m,&q);
		for(i=1;i<=n;++i)
		{
			for(j=1;j<=m;++j)
			{
				scanf("%d",&map[i][j]);
				row[i]=i; 
				hx[i]=0;
			}
		}
		for(j=1;j<=m;++j)
		{
			col[j]=j;
			hy[j]=0;
		}
		while(q--)
		{
			scanf("%d%d%d",&a,&x,&y);
			if(a==1)
				swap(row[x],row[y]);
			else if(a==2)
				swap(col[x],col[y]);
			else if(a==3)
				hx[row[x]]+=y;
			else 
				hy[col[x]]+=y; 
				
		}
		for(i=1;i<=n;++i)
		{
			for(j=1;j<=m;++j)
			{
				if(j==m)
					printf("%d\n",map[row[i]][col[j]]+hx[row[i]]+hy[col[j]]);
				else
					printf("%d ",map[row[i]][col[j]]+hx[row[i]]+hy[col[j]]);
			}
		} 
	} 
	return 0;
} 




HDOJ 5671 Matrix

原文:http://blog.csdn.net/zwj1452267376/article/details/51254278

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!