贪心+动态规划

P5019 [NOIP2018 提高组] 铺设道路 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

思路:

原理上就是一个差分数组,例如

4 3 2 5 3 5 这个数据

我们在其前面加上一个0作为x值,也就是(0 4 3 2 5 3 5),从4开始输入作为k,若输入的值k大于x,则Sum+=k-x,不管是否大于小于,每次输入后都要将当前k值变为x值

AC:

void solve()
{int ans = 0, k = 0, t;for (int i = 1; i <= n; i++){cin >> t;if (t > k)ans += t - k;k = t;}cout << ans << endl;return;
}

P1434 [SHOI2002] 滑雪 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

思路:

虽然是贪心,但是暴力dfs也可以过,从每个点开始搜一次得到每个点的最大长度,再得到总的最长长度

AC:

#define _CRT_SECURE_NO_WARNINGS 1
#include<bits/stdc++.h>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<vector>
#include<math.h>
using namespace std;
typedef long long ll;
inline int read()
{int k = 0, f = 1; char ch = getchar();while (ch < '0' || ch>'9'){if (ch == '-')f = -1;ch = getchar();}while (ch >= '0' && ch <= '9'){k = k * 10 + ch - '0';ch = getchar();}return k * f;
}
priority_queue<int, vector<int>, greater<int>> pq;
map<int, int>mp;
int a[110][110];
int b[110][110];
int r, c;
int dfs(int x, int y)
{if (b[x][y])return b[x][y];b[x][y] = 1;int next[4][2] = { {0,1},{0,-1},{1,0},{-1,0} };for (int i = 0; i < 4; i++){int tx = x + next[i][0];int ty = y + next[i][1];if (tx >= 1 && ty >= 1 && tx <= r && ty <= c&&a[tx][ty]<a[x][y]){dfs(tx, ty);b[x][y] = max(b[x][y], b[tx][ty] + 1);}}return b[x][y];
}
int main()
{ios::sync_with_stdio(false);cin.tie(nullptr);cin >> r >> c;for (int i = 1; i <= r; i++){for (int j = 1; j <= c; j++)cin >> a[i][j];}int ans = 0;for (int i = 1; i <= r; i++){for (int j = 1; j <= c; j++){ans = max(ans, dfs(i, j));}}cout << ans << endl;return 0;
}

P4017 最大食物链计数 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

思路:

拓扑排序,从最底层开始(即不能吃别人,只能被吃),往前进行搜索,一层一层的进行,每一层搜完后删除这一层,然后把这一层的数值累加到其对应的消费者身上,一直到最高处(使用vector建图,以每个最底层为一个点进行建边,能吃它的就加到它后面)

AC:

#define _CRT_SECURE_NO_WARNINGS 1
#include<bits/stdc++.h>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<vector>
#include<math.h>
using namespace std;
typedef long long ll;
priority_queue<int, vector<int>, greater<int>> pq;
map<int, int>mp;
int n, m;
const int mod = 80112002;
const int N = 5e5 + 10;
int in[N], out[N], num[N];
vector<int>v[N];
queue<int>q;
int main()
{ios::sync_with_stdio(false);cin.tie(nullptr);cin >> n >> m;for (int i = 1; i <= m; i++){int x, y;cin >> x >> y;++in[y], ++out[x];v[x].push_back(y);}for (int i = 1; i <= n; i++){if (!in[i]){num[i] = i;q.push(i);}}while (!q.empty()){int top = q.front();q.pop();int len = v[top].size();for (int i = 0; i < len; i++){int next = v[top][i];--in[next];num[next] = (num[next] + num[top]) % mod;if (in[next] == 0)q.push(v[top][i]);}}int ans = 0;for (int i = 1; i <= n; i++){if (!out[i]){ans = (ans + num[i]) % mod;}}cout << ans << endl;return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/43789.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SpringBoot + MyBatisPlus 实现多租户分库

一、引言 在如今的软件开发中&#xff0c;多租户(Multi-Tenancy)应用已经变得越来越常见。多租户是一种软件架构技术&#xff0c;它允许一个应用程序实例为多个租户提供服务。每个租户都有自己的数据和配置&#xff0c;但应用程序实例是共享的。而在我们的Spring Boot MyBati…

vscode运行java中文乱码,引发的mac配置问题

文章目录 问题 vscode 安装 java环境之后 public class Main{ public static void main(String[] args) { System.out.println(“哈哈”); } } ➜ .leetcode cd “/Users/leesin/.leetcode/.vscode/” && javac -encoding utf-8 Main.java && java Main &am…

Celery,一个实时处理的 Python 分布式系统

大家好&#xff01;我是爱摸鱼的小鸿&#xff0c;关注我&#xff0c;收看每期的编程干货。 一个简单的库&#xff0c;也许能够开启我们的智慧之门&#xff0c; 一个普通的方法&#xff0c;也许能在危急时刻挽救我们于水深火热&#xff0c; 一个新颖的思维方式&#xff0c;也许能…

【高校科研前沿】中国农业大学姚晓闯老师等人在农林科学Top期刊发表长篇综述:深度学习在农田识别中的应用

文章简介 论文名称&#xff1a;Deep learning in cropland field identification: A review&#xff08;深度学习在农田识别中的应用&#xff1a;综述&#xff09; 第一作者及单位&#xff1a;Fan Xu&#xff08;中国农业大学土地科学与技术学院&#xff09; 通讯作者及单位&…

39 线程库

目录 thread类的简单介绍线程函数参数锁线程交替打印原子性操作库无锁CAS智能指针的线程安全单例模式的线程安全 1. thread类的简单介绍 在c11之前&#xff0c;涉及到多线程问题&#xff0c;都是和平台相关的&#xff0c;如windows和linux下各有自己的接口&#xff0c;这使得…

【STM32 ARM】区分MCU,MPU与AP

文章目录 前言微控制器&#xff08;MCU&#xff09;微处理器&#xff08;MPU&#xff09;应用处理器&#xff08;AP&#xff09; 总结 前言 在嵌入式系统的世界中&#xff0c;我们经常会听到MCU、MPU和AP这些术语。这些都是微处理器的类型&#xff0c;它们在功能、性能和用途上…

PTA - sdut-使用函数求a+aa+aaa++⋯+aa.....aaa(n个a)之和

题目描述&#xff1a; 给定两个均不超过9的正整数a和n&#xff0c;要求&#xff1a;编写函数fn(a,n)&#xff0c; 求aaaaaa⋯aa⋯aa(n个a&#xff09;之和&#xff0c;fn须返回的是数列之和。 函数接口定义&#xff1a; def fn(a,n):其中&#xff0c; a 和 n 都是传入的参数…

《RWKV》论文笔记

原文出处 [2305.13048] RWKV: Reinventing RNNs for the Transformer Era (arxiv.org) 原文笔记 What RWKV(RawKuv):Reinventing RNNs for the Transformer Era 本文贡献如下&#xff1a; 提出了 RWKV 网络架构&#xff0c;结合了RNNS 和Transformer 的优点&#xff0c;同…

Java文件操作和IO的小案例

文章目录 案例1案例2案例3 案例1 要求&#xff1a; 扫描指定目录&#xff0c;并找到名称中包含指定字符的所有普通文件&#xff08;不包含目录&#xff09;&#xff0c;并且后续询问用户是否要删除该文件。 代码实现&#xff1a; package shixun;import java.io.File; import…

动手学深度学习54 循环神经网络

动手学深度学习54 循环神经网络 1. 循环神经网络RNN2. QA 1. 循环神经网络RNN h t h_t ht​ 与 h t − 1 h_{t-1} ht−1​ x t − 1 x_{t-1} xt−1​有关 x t x_t xt​ 与 h t h_t ht​ x t − 1 x_{t-1} xt−1​ 有关 怎么把潜变量变成RNN–假设更简单 潜变量和隐变量的区…

Spring Boot中处理同名Bean冲突的解决办法

核心问题&#xff1a;在Spring Boot项目中&#xff0c;同名Bean的冲突可能导致ConflictingBeanDefinitionException异常。 解决策略&#xff1a; 更换类名&#xff1a; 当两个类未手动设置Bean名称时&#xff0c;修改其中一个类名以避免冲突。 手动设置Bean的名称&#xff1a…

数据结构和算法,双向链表的实现增删改查(kotlin版)

数据结构和算法&#xff0c;双向链表的实现增删改查(kotlin版) 1.定义接口&#xff0c;我们需要实现的方法 interface LinkedListAction<E> {fun push(e: E)fun size(): Intfun getValue(index: Int): E?fun insert(index: Int,e: E)fun remove(index: Int) }2.定义节…

【动态规划Ⅴ】二维数组的动态规划——0/1矩阵、最大正方形

二维数组的动态规划——0/1矩阵、最大正方形 最大正方形1277. 统计全为 1 的正方形子矩阵221. 最大正方形 01矩阵542. 01 矩阵 最大正方形 下面两个题目是非常相似的&#xff0c;只是一个统计正方形数目&#xff0c;一个统计最大正方形的面积。 1277. 统计全为 1 的正方形子矩…

java树状结构 list 如何判断是第几级

解决方案 算法思路 为了判断树状结构中的列表是第几级&#xff0c;我们可以采用递归的方式遍历每个节点&#xff0c;计算其深度。具体来说&#xff0c;对于每个节点&#xff0c;我们可以向上遍历其父节点&#xff0c;直到根节点&#xff0c;同时累计深度值。最终得到的深度值就…

MySQL中记录(Documents)的基本操作——添加记录和查找记录

在MySQL中&#xff0c;我们通常不称数据表中的记录为“文档”&#xff0c;而是称之为“行”或“记录”。记录表示为JSON对象。在内部&#xff0c;它们以高效的二进制格式存储&#xff0c;从而实现快速查找和更新。 添加记录 使用add&#xff08;&#xff09;方法可以将一个记…

[C++基础]C++ 10个常用案例

1. Hello World 这是每个编程语言学习者都会遇到的第一个程序&#xff0c;用于展示如何在屏幕上打印“Hello, World!”。 #include<iostream> int main() { std::cout << "Hello, World!\n"; return 0; } 2. 变量声明与赋值 展示如何在C中声明…

打卡第7天-----哈希表

继续坚持✊,我现在看到leetcode上的题不再没有思路了,真的是思路决定出路,在做题之前一定要把思路梳理清楚。 一、四数相加 leetcode题目编号:第454题.四数相加II 题目描述: 给定四个包含整数的数组列表 A , B , C , D ,计算有多少个元组 (i, j, k, l) ,使得 A[i] + B[j…

MVC拦截器、ThreadLocal来进行登录拦截

MVC拦截器、ThreadLocal来进行登录拦截 1. 对登录进行拦截1.1 什么是ThreadLocal1.2 定义UserHolder 类&#xff0c;来封装ThreadLocal方法1.3 拦截器WebMvcConfigurer 的配置1.4 登录的配置&#xff0c;当碰到拦截的方法的时候调用1.5 UserServiceImpl1.6 controller&#xff…

RoPE旋转位置编码从复数到欧拉公式

第二部分 从复数到欧拉公式 先复习下复数的一些关键概念 我们一般用表示复数&#xff0c;实数a叫做复数的实部&#xff0c;实数b叫做复数的虚部 复数的辐角是指复数在复平面上对应的向量和正向实数轴所成的有向角 的共轭复数定义为&#xff1a;&#xff0c;也可记作&#xff0…

分布式计算中的数据分片和副本机制

分布式计算中的数据分片和副本机制 在分布式计算中&#xff0c;数据分片&#xff08;Data Sharding&#xff09;是指将大量数据分割成较小的、独立的部分&#xff0c;每个部分存储在一个单独的节点或机器上。这种技术主要用于数据库系统中&#xff0c;比如哈希分区或范围分区&…