2019华为暑期实习机试题 Java(给定一个二维0/1矩阵,找到并返回其中由1组成的最大正方形面积。)--动态规划
发布日期:2021-06-20 05:37:10 浏览次数:2 分类:技术文章

本文共 978 字,大约阅读时间需要 3 分钟。

分析:

       这个题暴力解也能过了,最佳解法使用动态规划的思想:本题考虑的是正方形的面积,所以算出最长的边长就好。我们假设dp[i][j] 是以 [i][j] 为顶点的最大的正方形边长。我们可以写出状态转移方程:

若 [i][j] 这个点是1 :那么dp[i][j]=min{dp[i-1][j-1],dp[i-1][j],dp[i][j-1]}+1。

否则 : dp[i][j]=0

暴力解法:

       遍历矩阵每个元素,以这个元素作为正方形的左上角,寻找最大面积。复杂度为O(n*n)。这种算法存在大量的重复计算比如:\begin{bmatrix} 3 3 3 \\ 3 3 3 \\ 3 3 3 \end{bmatrix} 左上角[0][0]元素计算是有必要的,但是[1][1]元素计算就重复了。因为[1][1]元素所形成的正方形矩阵是[0][0]元素的子集。所以我们在动态规划思想里面假设dp[i][j] 是以 [i][j] 为顶点的最大的正方形边长。

 

import java.util.Scanner;/** * @author: Mr.Hu * @create: 2019-03-13 21:10 */public class Main{    public static void main(String[] args) {        Scanner sc =new Scanner(System.in);        while (sc.hasNextInt()){            int n=sc.nextInt();            char[][] a =new char[n][];            for (int i = 0; i < n; i++) {       //输入变为二维整形数组                a[i] =sc.next().toCharArray();            }            int[][] dp =new int[n][a[0].length];  //dp 存以a[i][j]结尾最长的边长  注意输入数据不一定是正方形            int max=0;            for (int i = 0; i < n; i++) {           //将字符数组变为整形数组                for (int j = 0; j 

 

转载地址:https://blog.csdn.net/h2453532874/article/details/88542850 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:剑指Offer---寻找第N个丑数 Java
下一篇:2019华为暑期实习机试题 Java(判断IP地址是否属于同一网段)

发表评论

最新留言

留言是一种美德,欢迎回访!
[***.207.175.100]2024年04月08日 19时03分55秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章

【数据结构与算法】什么是布隆过滤器?如何防止缓存穿透的问题? 2021-06-29
【Java锁体系】CopyOnWriteArrayList是什么?线程安全的arraylist是哪个? 2021-06-29
【面试题目】Java设计模式你有哪些了解?说几个常用的。 2021-06-29
【计算机操作系统】常说的死锁是什么?死锁产生的必要条件是什么?死锁的解决策略是什么? 2021-06-29
【计算机操作系统】进程管理详解?进程与线程区别是什么?进程调度的算法有哪些?进程通信有哪些? 2021-06-29
【计算机操作系统】虚拟内存是什么?分页系统地址映射?页面置换算法有哪些?分段地址映射又是什么? 2021-06-29
【计算机操作系统】设备管理?磁盘结构是怎么样的?磁盘调度算法有哪些? 2021-06-29
【多线程高并发】为什么要使用多线程?创建多少个线程合适呢? 2021-06-29
【多线程与高并发】 Java两个线程轮流打印1-100两个数?多线程轮流打印数字? 2021-06-29
【多线程与高并发】 Java两个线程轮流打印字符串? 2021-06-29
【Linux命令篇】Linux命令实践 2021-06-29
【Leetcode单调队列】Leetcode239 滑动窗口最大值 2021-06-29
【Leetcode-单调栈】单调栈相关的题目-下一个更大的元素I 每日温度 2021-06-29
【Leetcode单调队列】- 洛谷P1714切蛋糕 2021-06-29
【Leetcode优先级队列】- 数据流的中位数 2021-06-29
【Leetcode优先级队列】-合并K个升序链表 2021-06-29
【多线程与高并发】-Java如何实现一个阻塞队列呢? 2021-06-29
【多线程高并发】-Java使用阻塞队列ArrayBlockingQueue实现生产者消费者模式? 2021-06-29
【多线程高并发】-多线程实现数组的读与写 2021-06-29
【Java设计者模式】-Java实现订阅-发布者模式 2021-06-29