[Algorithm][综合训练][打怪][判断是不是平衡二叉树][最大子矩阵]详细讲解

本文主要是介绍[Algorithm][综合训练][打怪][判断是不是平衡二叉树][最大子矩阵]详细讲解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 1.打怪
    • 1.题目链接
    • 2.算法原理详解 && 代码实现
  • 2.判断是不是平衡二叉树
    • 1.题目链接
    • 2.算法原理详解 && 代码实现
  • 3.最大子矩阵
    • 1.题目链接
    • 2.算法原理详解 && 代码实现


1.打怪

1.题目链接

  • 打怪

2.算法原理详解 && 代码实现

  • 自己的版本:暴力模拟
    #include <iostream>
    using namespace std;int main()
    {int t = 0;cin >> t;int h, a, H, A;while(t--){cin >> h >> a >> H >> A;if(a >= H){cout << -1 << endl;continue;}int cnt = 0, tmpH = H;while(h > 0){if((tmpH -= a) <= 0){cnt++;tmpH = H;continue;}h -= A;}cout << cnt << endl;}return 0;
    }
    
  • 优化版本:数学
    • 遇到一只怪物,怪物能抗几次?
      • m = H / a + (H % a != 0 ? 1 : 0)
    • 杀死一只怪物的时候,玩家被攻击几次
      • n = m - 1
    • 杀死一只怪物的时候,玩家掉几点血
      • x = n * A
    • 玩家一共能杀死多少怪物
      • ret = h / x - (h % x == 0 ? 1 : 0)
    #include <iostream>
    using namespace std;int h, a, H, A;int Check()
    {if(a >= H){return -1;}int m = (H / a) + (H % a != 0 ? 1 : 0); // 怪物能抗⼏次int n = m - 1; // 玩家被攻击⼏次int x = n * A; // 杀死⼀只怪物的时候,玩家会掉多少⾎int ret = h / x - (h % x == 0 ? 1 : 0);return ret;
    }int main()
    {int t = 0;cin >> t;while(t--){cin >> h >> a >> H >> A;cout << Check() << endl;}return 0;
    }
    

2.判断是不是平衡二叉树

1.题目链接

  • 判断是不是平衡二叉树

2.算法原理详解 && 代码实现

  • 优化版本
    class Solution 
    {
    public:bool IsBalanced_Solution(TreeNode* pRoot) {return DFS(pRoot) != -1;}// 返回值不是-1的话,其余的返回值表示的是树高int DFS(TreeNode* root){if(root == nullptr){return 0;}int left = DFS(root->left);if(left == -1){return -1; // 剪枝}int right = DFS(root->right);if(right == -1){return -1;}return abs(left - right) <= 1 ? max(left, right) + 1 : -1;}
    };
    

3.最大子矩阵

1.题目链接

  • 最大子矩阵

2.算法原理详解 && 代码实现

  • 解法:二维前缀和

    • 初始化⼆维前缀和矩阵
    • 枚举所有的⼦矩阵,求出最⼤⼦矩阵
  • 如何枚举所有的子矩阵?

    for(0 ~ n - 1) -> x1for(0 ~ m - 1) -> y1for(x1 ~ mn - 1) -> x2for(y1 ~ m - 1) -> y2
    
  • 如何计算矩阵中所有元素的和? --> 二位前缀和 --> 动态规划

    • 初始化二维dp表
      请添加图片描述

    • 使用二维dp表
      请添加图片描述

    #include <iostream>
    #include <vector>
    using namespace std;int main()
    {int n = 0, x = 0;cin >> n;// 动态规划 --> 求二维前缀和数组vector<vector<int>> dp(n + 1, vector<int>(n + 1, 0));for(int i = 1; i <= n; i++){for(int j = 1; j <= n; j++){cin >> x;dp[i][j] = dp[i - 1][j] + dp[i][j - 1] - dp[i - 1][j - 1] + x;}}int ret = -0x3f3f3f3f;for(int x1 = 1; x1 <= n; x1++){for(int y1 = 1; y1 <= n; y1++){for(int x2 = x1; x2 <= n; x2++){for(int y2 = y1; y2 <= n; y2++){ret = max(ret, dp[x2][y2] - dp[x1 - 1][y2] - dp[x2][y1 - 1] + dp[x1 - 1][y1 - 1]);}}}}cout << ret << endl;return 0;
    }
    

这篇关于[Algorithm][综合训练][打怪][判断是不是平衡二叉树][最大子矩阵]详细讲解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析(结合应用场景)

《nginx-t、nginx-sstop和nginx-sreload命令的详细解析(结合应用场景)》本文解析Nginx的-t、-sstop、-sreload命令,分别用于配置语法检... 以下是关于 nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析,结合实际应

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

Python设置Cookie永不超时的详细指南

《Python设置Cookie永不超时的详细指南》Cookie是一种存储在用户浏览器中的小型数据片段,用于记录用户的登录状态、偏好设置等信息,下面小编就来和大家详细讲讲Python如何设置Cookie... 目录一、Cookie的作用与重要性二、Cookie过期的原因三、实现Cookie永不超时的方法(一)

SpringBoot整合liteflow的详细过程

《SpringBoot整合liteflow的详细过程》:本文主要介绍SpringBoot整合liteflow的详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋...  liteflow 是什么? 能做什么?总之一句话:能帮你规范写代码逻辑 ,编排并解耦业务逻辑,代码

Go语言中nil判断的注意事项(最新推荐)

《Go语言中nil判断的注意事项(最新推荐)》本文给大家介绍Go语言中nil判断的注意事项,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.接口变量的特殊行为2.nil的合法类型3.nil值的实用行为4.自定义类型与nil5.反射判断nil6.函数返回的

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、