首页 > 其他分享 >刺激的矩阵

刺激的矩阵

时间:2022-11-22 19:01:37浏览次数:38  
标签:cnt 矩阵 sum 刺激 样例 ans exciting


刺激的矩阵(exciting)

 

【题目背景】

丁爷爷是一名长者,他喜欢寻找刺激的东西。

 

【题目描述】

丁爷爷非常喜欢取最值运算,他认为取最值运算很刺激。

有一天,丁爷爷获得了一个 n × m 的矩阵。他决定在这个矩阵中找乐子。

首先,对于各行,丁爷爷求出了每行内元素的最小值(第 i 行的最小值被存在 ri 中)。同样地,对于各列,丁爷爷又求出了每列内元素的最大值(第i 列的最大值被存在ci 中)。

然后,丁爷爷将所有 ri 取最大值,存放在 R 中;将所有 ci 取最小值,存放在 C 中。这样,刺激的运算就全部做完了。

然而,丁爷爷认为,最终 R C 相等的矩阵才是真正刺激的矩阵。如果最终他发现 R C 不相等,那么他就会十分生气。为了不得罪丁爷爷,他的粉丝 Yazid 不得不把这个矩阵改成一个刺激的矩阵。

而你,需要帮助 Yazid 最小化他修改的次数。也就是说,Yazid 需要修改尽可能少的位置来使这个矩阵变得刺激。

形式化地描述,不妨假设这个矩阵为 An×m。那么:


你需要修改尽可能少的数,使得 R =C

 

【输入格式】

从文件 exciting.in 中读入数据。

第一行 3 个整数 n, m, type,分别表示矩阵的行数、列数和数据类型。(数据类型的作用会在下面描述)

接下来 n 行,每行 m 个用空格隔开的整数,描述这个矩阵。其中第 i + 1 行的第 j

个数表示 Ai, j

 

【输出格式】

输出到文件 exciting.out 中。

输出一行一个整数,表示需要修改的最少的数的个数。


【样例 1 输入】

3 3 2

10 20 30

20 10 30 

10 5 35

【样例 1 输出】 

1

 

【样例 2 输入】

3 3 1

1 2 1

2 1 0

3 3 4

 

【样例 2 输出】 

0

 

【样例 3 输入】

4 4 0

1 1 3 4

5 1 1 8 

9 10 1 1

1 14 15 1

【样例 3 输出】

2

【样例 4】

见选手目录下的 exciting/exciting4.inexciting/exciting4.ans

【样例 5】

见选手目录下的 exciting/exciting5.inexciting/exciting5.ans


 

【样例 6】

见选手目录下的 exciting/exciting6.inexciting/exciting6.ans

 

【提示】

样例 1 解释:Yazid 可以把第 1 行第 2 个元素修改为 7,这样这个矩阵就是刺激的了。

 

【子任务】

对于8% 的数据,保证 n,m ≤ 3,且type = 1。对于另外8% 的数据,有 type= 2。

对于另外 4%的数据,有 n, m ≤5。对于另外 12% 的数据,保证 n ≤10。对于 44% 的数据,保证n, m ≤35。对于 56% 的数据,保证 n, m ≤60。对于 64% 的数据,保证n, m ≤100。对于 72% 的数据,保证 n, m ≤300。对于 88% 的数据,保证n, m ≤1, 000。对于92% 的数据,保证 n, m ≤1, 500。

对于100% 的数据,保证 1 ≤ n, m ≤2, 000,0 ≤ Ai,j ≤ 3 × 106。对于没有说明 type 取值的数据类型,都有type= 0。

对于 type = 1 的数据,保证存在一种最优的修改方案,使得最终得到的刺激矩阵的每个元素都是不超过 5 的非负整数。

对于 type = 2 的数据,保证答案不超过 1。

 

题解:我们可以发现R与C所代表的点是相等的。将所有数据进行排序,先从小到大存入,在列上减去对应的数,再从大到小存入,在行上减去对应的数。将两者相加求最小值就是答案。

Code:

var
ans,f,x,y,b:array[0..4000005] of longint;
a:array[0..2005,0..2005] of longint;
n,m,t,i,j,sum,cnt,minans,min,l,r:longint;
procedure sort(l,r:longint);
var i,j,v,t:longint;
begin
i:=l;j:=r;v:=f[random(r-l+1)+l];
repeat
while f[i]<v do inc(i);
while f[j]>v do dec(j);
if not(i>j) then
begin
t:=f[i];f[i]:=f[j];f[j]:=t;
t:=x[i];x[i]:=x[j];x[j]:=t;
t:=y[i];y[i]:=y[j];y[j]:=t;
inc(i);dec(j);
end;
until i>j;
if l<j then sort(l,j);
if i<r then sort(i,r);
end;
begin
assign(input,'exciting.in');reset(input);
assign(output,'exciting.out');rewrite(output);
randomize;
readln(n,m,t);
for i:=1 to n do
for j:=1 to m do
begin
read(a[i,j]);
inc(sum);
f[sum]:=a[i,j];
x[sum]:=i;
y[sum]:=j;
end;
sort(1,sum);
for i:=1 to m do b[i]:=n;
min:=n;
for i:=1 to sum do
begin
dec(b[y[i]]);
if b[y[i]]<min then min:=b[y[i]];
if (f[i]<>f[i+1])or(i=sum) then
begin
inc(cnt);
ans[cnt]:=min;
end;
end;
for i:=1 to n do b[i]:=m;
min:=m;minans:=maxlongint;
inc(cnt);
for i:=sum downto 1 do
begin
dec(b[x[i]]);
if b[x[i]]<min then min:=b[x[i]];
if (f[i]<>f[i-1])or(i=1) then
begin
dec(cnt);
ans[cnt]:=ans[cnt]+min;
if ans[cnt]<minans then minans:=ans[cnt];
end;
end;
writeln(minans);
close(input);close(output);
end.

 

标签:cnt,矩阵,sum,刺激,样例,ans,exciting
From: https://blog.51cto.com/u_15888102/5878363

相关文章