【洛谷2258】子矩阵

2023-11-07 19:08
文章标签 矩阵 洛谷 2258

本文主要是介绍【洛谷2258】子矩阵,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目链接:https://www.luogu.org/problem/show?pid=2258
题解
这貌似是普及组的题诶
如果行和列都爆搜的话, O(2n+m×r×c)
剪剪枝或许可以(hhh我都不信)
枚举组合时,如果当前搜出的1的个数大于要求,剪枝;如果即使剩下的数的个数全选1也不足以凑齐要求,剪枝,然后根据数学推导(比较麻烦懒得写了)和杨辉三角大约可以推出来枚举每一个组合可以是O(1)的
O(Crn×Ccm×r×c)

正解
套路的爆搜行DP列,F[i][j]表示选了i列最后一列是j的最优解
f[i][j]=min{f[i-1][k]+calc(j,k)}
复杂度差不多是 O(2n×m2)

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;const int inf=(1<<30);
int m,n,r,c,ans=inf;
int a[20][20],p[20],f[20][20],sum[20],g[20][20];void dp()
{memset(sum,0,sizeof(sum));memset(g,0,sizeof(g));memset(f,0x7f,sizeof(f));for(int i=1;i<=m;i++)for(int j=1;j<r;j++)sum[i]+=abs(a[p[j+1]][i]-a[p[j]][i]);for(int i=1;i<=m;i++)for(int j=i+1;j<=m;j++)for(int k=1;k<=r;k++)g[i][j]+=abs(a[p[k]][j]-a[p[k]][i]);for(int i=1;i<=m;i++) f[1][i]=sum[i];for(int i=1;i<=c;i++)       for(int j=1;j<=m-(c-i);j++)for(int k=0;k<=j-1;k++)f[i][j]=min(f[i][j],f[i-1][k]+sum[j]+g[k][j]);  for(int i=c;i<=m;i++)ans=min(ans,f[c][i]);           
}void dfs(int x,int y)
{if(y==r+1) {dp();return;}if(x>n) return;dfs(x+1,y); p[y]=x;dfs(x+1,y+1);
}int main()
{cin>>n>>m>>r>>c;for(int i=1;i<=n;i++)for(int j=1;j<=m;j++)cin>>a[i][j];dfs(1,1);printf("%d\n",ans);return 0;
}

ps:n和m输反调了半个小时,hhh

这篇关于【洛谷2258】子矩阵的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/365679

相关文章

hdu 4565 推倒公式+矩阵快速幂

题意 求下式的值: Sn=⌈ (a+b√)n⌉%m S_n = \lceil\ (a + \sqrt{b}) ^ n \rceil\% m 其中: 0<a,m<215 0< a, m < 2^{15} 0<b,n<231 0 < b, n < 2^{31} (a−1)2<b<a2 (a-1)^2< b < a^2 解析 令: An=(a+b√)n A_n = (a +

hdu 6198 dfs枚举找规律+矩阵乘法

number number number Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Problem Description We define a sequence  F : ⋅   F0=0,F1=1 ; ⋅   Fn=Fn

线性代数|机器学习-P35距离矩阵和普鲁克问题

文章目录 1. 距离矩阵2. 正交普鲁克问题3. 实例说明 1. 距离矩阵 假设有三个点 x 1 , x 2 , x 3 x_1,x_2,x_3 x1​,x2​,x3​,三个点距离如下: ∣ ∣ x 1 − x 2 ∣ ∣ 2 = 1 , ∣ ∣ x 2 − x 3 ∣ ∣ 2 = 1 , ∣ ∣ x 1 − x 3 ∣ ∣ 2 = 6 \begin{equation} ||x

【线性代数】正定矩阵,二次型函数

本文主要介绍正定矩阵,二次型函数,及其相关的解析证明过程和各个过程的可视化几何解释(深蓝色字体)。 非常喜欢清华大学张颢老师说过的一段话:如果你不能用可视化的方式看到事情的结果,那么你就很难对这个事情有认知,认知就是直觉,解析的东西可以让你理解,但未必能让你形成直觉,因为他太反直觉了。 正定矩阵 定义 给定一个大小为 n×n 的实对称矩阵 A ,若对于任意长度为 n 的非零向量 ,有 恒成

python科学计算:NumPy 线性代数与矩阵操作

1 NumPy 中的矩阵与数组 在 NumPy 中,矩阵实际上是一种特殊的二维数组,因此几乎所有数组的操作都可以应用到矩阵上。不过,矩阵运算与一般的数组运算存在一定的区别,尤其是在点积、乘法等操作中。 1.1 创建矩阵 矩阵可以通过 NumPy 的 array() 函数创建。矩阵的形状可以通过 shape 属性来访问。 import numpy as np# 创建一个 2x3 矩阵mat

高精度计算(代码加解析,洛谷p1601,p1303)除法待更新

目录 高精度加法 高精度减法 高精度乘法 高精度加法 我们知道在c++语言中任何数据类型都有一定的表示范围。当两个被加数很大时,正常加法不能得到精确解。在小学,我们做加法都采用竖式方法。那么我们也只需要按照加法进位的方式就能得到最终解。 8 5 6+ 2 5 5-------1 1 1 1 加法进位: c[i] = a[i] + b[i];if(c[i] >=

【UVA】10003-Cutting Sticks(动态规划、矩阵链乘)

一道动态规划题,不过似乎可以用回溯水过去,回溯的话效率很烂的。 13988658 10003 Cutting Sticks Accepted C++ 1.882 2014-08-04 09:26:49 AC代码: #include<cstdio>#include<cstring>#include<iostream>#include<algorithm>#include

洛谷 凸多边形划分

T282062 凸多边形的划分 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 先整一个半成品,高精度过两天复习一下补上 #include <iostream>#include <algorithm>#include <set>#include <cstring>#include <string>#include <vector>#include <map>

算法练习题17——leetcode54螺旋矩阵

题目描述 给你一个 m 行 n 列的矩阵 matrix ,请按照 顺时针螺旋顺序 ,返回矩阵中的所有元素。  代码 import java.util.*;class Solution {public List<Integer> spiralOrder(int[][] matrix) {// 用于存储螺旋顺序遍历的结果List<Integer> result = new ArrayList

能量项链,洛谷

解释:  环形dp问题还是考虑将环拉直,可以参考我上一篇文章:环形石子合并 [2 3 5 10 2] 3 5 10 将环拉直,[]内是一个有效的区间,可以模拟吸收珠子的过程,         如[2 3 5] <=>(2,3)(3,5)    2是头,3是中间,5是尾 len >= 3:因为最后[2 10 2]是最小的可以合并的有效区间 len <= n + 1因为[2 3