OD C卷 - 宽度最小的子矩阵

宽度最小的子矩阵 (100)

  • 给定一个n行 * m列的矩阵;
  • 给定一个k个整数的数组k_list;
  • 在n*m的矩阵中找一个宽度最小的子矩阵,该子矩阵包含k_list中所有的整数;
    输入描述:
    第一行输入n,m 两个整数;
    后续n行每行输入 m个数据;
    输入k值;
    输入个整数
    输出描述:
    最小宽度值,若找不到,则输出-1

示例1

输入:

2 5

1 2 2 3 1

2 3 2 3 2

3

1 2 3

输出:

2

说明,

矩阵第0、3列包含了1、2、3;

矩阵第3、4列包含了1、2、3

示例2

输入:

2 5

1 2 2 3 1

1 3 2 3 4

3

1 1 4

输出:

5
思路:

  • 滑动的子矩阵
  • 从第一列起始,找一个宽度最小的子矩阵;
  • 从第二列开始,找一个宽度最小的子矩阵;
  • 依次到最后一列...
  • 以上的宽度每次取最小值
python 复制代码
 
class MinWidth:
    def solution(self, n, m, matrix, k_list):
        k_dict = self.to_dict(k_list)
        min_width = float("inf")
        # 类似双指针
        for start_idx in range(m):
            for end_idx in range(start_idx, m):
                temp_list = []
                # 获取当前子矩阵的所有元素
                for i in range(n):
                    temp_list.extend(matrix[i][start_idx:end_idx+1])
                temp_dict = self.to_dict(temp_list)
                # 集合操作
                flag = True
                for key in k_dict:
                    if key in temp_dict and k_dict[key] <= temp_dict[key]:
                        continue
                    else:
                        flag = False
                        break

                if flag:
                    min_width = min(min_width, end_idx - start_idx + 1)
                    break
        print(min_width)

    def to_dict(self, alist):
        dict_ = {}
        for i in alist:
            dict_[i] = dict_.get(i, 0) + 1
        return dict_


if __name__ == '__main__':
    min_width = MinWidth()

    while True:
        try:
            n, m = list(map(int, input().strip().split()))
            matrix = []
            for i in range(n):
                matrix.append(list(map(int, input().strip().split())))
            k = int(input().strip())
            k_list = list(map(int, input().strip().split()))
            min_width.solution(n, m, matrix, k_list)

        except KeyboardInterrupt:
            break

&nbsp

相关推荐
邂逅岁月2 天前
【网络原理】Tcp 常用提升效率机制——滑动窗口,快速重传,流量控制, 拥塞控制, 建议收藏 !!!
网络·tcp/ip·php·滑动窗口·流量控制·拥塞控制·快速重传
敲上瘾7 天前
滑动窗口——优选算法
数据结构·c++·算法·大模型·aigc·哈希算法·滑动窗口
hnjzsyjyj8 天前
LeetCode 209:长度最小的子数组 ← 滑动窗口
leetcode·滑动窗口
sweetheart7-713 天前
LeetCode438. 找到字符串中所有字母异位词(2024秋季每日一题 11)
数据结构·算法·字符串·滑动窗口·子串
此去经年ToT16 天前
1004.最大连续1的个数Ⅲ
数据结构·算法·leetcode·双指针·滑动窗口
ZZZ_O^O16 天前
Leetcode每日刷题之438.找到字符串中所有字符异位词
c++·算法·leetcode·职场和发展·滑动窗口
2的n次方_17 天前
滑动窗口详解
算法·leetcode·哈希算法·滑动窗口
laufing24 天前
OD C卷 - 幼儿园篮球游戏
双指针·python算法
laufing25 天前
OD C卷 - 结对编程
python算法·条件计算
ZZZ_O^O1 个月前
Leetcode每日刷题之904.水果成篮
c++·算法·leetcode·职场和发展·滑动窗口