【强训笔记】day10

news/2024/11/16 19:45:09/

NO.1
在这里插入图片描述
思路:中心扩展。从i位置开始,从i-1为左边和i+1右边进行移动,字符相等就继续移动,直到不等,更新回文串长度,让i为左边,i+1右边再移动,同样字符相等就移动,不等就更新长度。
代码实现:

class Solution {
public:int getLongestPalindrome(string A) {int n=A.size();int ret=0;for(int i=0;i<n;i++){int left=i-1,right=i+1;while(left>=0&&right<n&&A[left]==A[right]){left--;right++;}ret=max(ret,right-left-1);left=i,right=i+1;while(left>=0&&right<n&&A[left]==A[right]){left--;right++;}ret=max(ret,right-left-1);}return ret;}
};

NO.2
在这里插入图片描述
思路:定义一个前驱最小值,最大利润等于当前值减去前去最小值,前驱最小值等于当前值和它前驱最小值的最小值,利用一个循环遍历一遍就可以实现。

代码实现:

#include <iostream>
using namespace std;const int N=1e5+10;
int n;
int arr[N];int main() {cin>>n;for(int i=0;i<n;i++) cin>>arr[i];int ret=0,prevmin=arr[0];for(int i=1;i<n;i++){ret=max(ret,arr[i]-prevmin);prevmin=min(prevmin,arr[i]);}cout<<(ret<0?0:ret)<<endl;}

如果不想最后判断的话,最后调换一下ret和prevmin的最小值的顺序的就可以了。

#include <iostream>
using namespace std;const int N=1e5+10;
int n;
int arr[N];int main() {cin>>n;for(int i=0;i<n;i++) cin>>arr[i];int ret=0,prevmin=arr[0];for(int i=1;i<n;i++){prevmin=min(prevmin,arr[i]);ret=max(ret,arr[i]-prevmin);}cout<<ret<<endl;}

NO.3
在这里插入图片描述
思路:dp路径问题,分情况讨论,如果要走的点为马控制的点或马本身的点,那么dp[i][j]为0,否则dp[i][j]=dp[i][j-1]+dp[i-1][j],因为我们多开辟一行一列,所以初始化初始化的时候先x+1,y+1,保证能够关系映射,并且令dp[0][1]或者是dp[1][0]为1。

#include <iostream>
using namespace std;int n,m,x,y;
long long dp[25][25];int main() {cin>>n>>m>>x>>y;x+=1;y+=1;dp[0][1]=1;for(int i=1;i<=n+1;i++){for(int j=1;j<=m+1;j++){if(i!=x&&j!=y&&abs(i-x)+abs(j-y)==3||(i==x&&j==y)){dp[i][j]=0;}else {dp[i][j]=dp[i][j-1]+dp[i-1][j];}}}cout<<dp[n+1][m+1]<<endl;return 0;
}

http://www.ppmy.cn/news/1456072.html

相关文章

组件通信-(父子组件通信)

目录 一、什么是组件通信 二、组件关系的分类 三、组件通信解决方案 四、父传子 五、子传父 一、什么是组件通信 组件通信&#xff0c;就是指组件与组件之间的数据传递。组件的数据是独立的&#xff0c;无法直接访问其他组件的数据。如果想使用其他组件的数据&#xff0c;…

鸿蒙内核源码分析(事件控制篇) | 任务间多对多的同步方案

官方概述 先看官方对事件的描述. 事件&#xff08;Event&#xff09;是一种任务间通信的机制&#xff0c;可用于任务间的同步。 多任务环境下&#xff0c;任务之间往往需要同步操作&#xff0c;一个等待即是一个同步。事件可以提供一对多、多对多的同步操作。 一对多同步模型…

#04 构建您的第一个神经网络:PyTorch入门指南

文章目录 前言理论基础神经网络层的组成前向传播与反向传播 神经网络设计步骤1&#xff1a;准备数据集步骤2&#xff1a;构建模型步骤3&#xff1a;定义损失函数和优化器步骤4&#xff1a;训练模型步骤5&#xff1a;评估模型结论 前言 在过去的几天里&#xff0c;我们深入了解了…

2024年第七届可再生能源与环境工程国际会议(REEE 2024)即将召开!

2024年第七届可再生能源与环境工程国际会议&#xff08;REEE 2024&#xff09;将于2024 年8月28-30日在法国南特举行。共绘绿色未来&#xff0c;全球同频共振&#xff01;REEE 2024将汇聚全球可再生能源与环境工程领域的专家学者和业界精英&#xff0c;共同探讨行业发展的前沿技…

笔试强训Day15 二分 图论

平方数 题目链接&#xff1a;平方数 (nowcoder.com) 思路&#xff1a;水题直接过。 AC code&#xff1a; #include<iostream> #include<cmath> using namespace std; int main() {long long int n; cin >> n;long long int a sqrtl(n);long long int b …

Linux内核--设备驱动(六)媒体驱动框架整理(2)--视频

目录 一、引言 二、V4L2 ------>2.1、主要结构体 ------------>2.2.1、video_device ------------>2.2.2、v4l2_device ------------>2.2.3、v4l2_subdev ------>2.2、流程 ------>2.3、驱动实例 ------>2.4、V4L2的ioctl类型 ------------>…

百度语音识别开发笔记

目录 简述 开发环境 1、按照官方文档步骤开通短语音识别-普通话 2、创建应用 3、下载SDK 4、SDK集成 5、相关接口简单说明 5.1权限和key 5.2初始化 5.3注册回调消息 5.4开始转换 5.5停止转换 6、问题 简述 最近想做一些语音识别的应用&#xff0c;对比了几个大厂…

C++:多继承虚继承

在C中&#xff0c;虚继承&#xff08;Virtual Inheritance&#xff09;是一种特殊的继承方式&#xff0c;用于解决菱形继承&#xff08;Diamond Inheritance&#xff09;问题。菱形继承指的是一个类同时继承自两个或更多个具有共同基类的类&#xff0c;从而导致了多个实例同一个…