这题 的确是个好题~ 当时 只觉得应该用贪心做...
后来 人家给我证明了下 不应该是用贪心 局部最优解 与 全局最优解之间的关系不是严格成立的~
慢慢 静心下来 总是有解决的方法的=-=
1 #include <iostream> 2 #include <cstdio> 3 #include <queue> 4 using namespace std; 5 6 typedef long long LL; 7 const int size = 1000010; 8 const LL inf = 1e18; 9 LL a[1010] , b[1010]; 10 LL row[size] , col[size]; 11 priority_queue<LL>rowQu,colQu; 12 13 int main() 14 { 15 cin.sync_with_stdio(false); 16 LL n , m , k , p , i , j , num , ans , temp; 17 while( cin >> n >> m >> k >> p ) 18 { 19 for( i = 1 ; i<=n ; i++ ) 20 { 21 for( j = 1 ; j<=m ; j++ ) 22 { 23 cin >> num; 24 a[i] += num; 25 b[j] += num; 26 } 27 rowQu.push(a[i]); 28 } 29 for( j = 1 ; j<=m ; j++ ) 30 { 31 colQu.push(b[j]); 32 } 33 ans = -inf; 34 for( i = 1 ; i<=k ; i++ ) 35 { 36 temp = rowQu.top(); 37 rowQu.pop(); 38 row[i] = row[i-1] + temp; 39 rowQu.push(temp-m*p); 40 41 temp = colQu.top(); 42 colQu.pop(); 43 col[i] = col[i-1] + temp; 44 colQu.push(temp-n*p); 45 } 46 for( i = 0 ; i<=k ; i++ ) 47 { 48 temp = row[i] + col[k-i]; 49 temp -= (i)*(k-i)*p; 50 if( temp>ans ) 51 ans = temp; 52 } 53 cout << ans << endl; 54 } 55 return 0; 56 }
这里 因为数据很大 用到64位 那么 ans就要设置得足够小... 一开始 我就用自己惯用的0x3f3f3f3f 会wa的~
以后 做好每场cf 一般感觉我以后cf要贴出来的 都是后来看别人的解题报告才学会的~
//今天 睡到下午2点半才醒 好累..... 世界杯 终于结束了
today:
这是一个流行离开的世界 但是我们都不擅长告别~
你终于活得如同一般人类学行为规范 去掉了表情 隐藏了情绪 不带一丝人气 成了 橡皮人~
时间: 2024-10-15 19:05:36