[笔试训练](十八)

news/2024/9/23 10:17:10/

目录

052:字符串压缩

053:chika和蜜柑

054:01背包


052:字符串压缩

压缩字符串(一)_牛客题霸_牛客网 (nowcoder.com)

题目: 

题解:

双指针模拟

class Solution {
public:string compressString(string param) {int n=param.size();string ret;int num=1;int left=0,right=0;ret+=param[0];while(left<n-1){right+=1;if(param[left]==param[right]){num++;}else if(param[left]!=param[right] || right==n-1){if(num!=1){if(num<=9){ret+=num+'0';}else{ret+=to_string(num);}     num=1;}ret+=param[right];left=right;}        }return ret;       }
};

053:chika和蜜柑

chika和蜜柑 (nowcoder.com)

题目:

题解:

将每个橘子按甜度从大到小排序,相同甜度的橘子按酸度从小到大排序,从排序好的橘子中取前k个就是最优解。

有两个影响元素的排序需要二元组的思想排序:

// 使用lambda表达式对二元组进行排序  
// 排序规则:先按第二个元素从大到小排序,如果第二个元素相同,则按第一个元素从小到大排序  

sort(arr, arr + n, [&](const PII & a, const PII & b) {
        if (a.second != b.second) return a.second > b.second;
        else return a.first < b.first;
    });

#include <iostream>
#include<algorithm>
using namespace std;
typedef long long LL;
typedef pair<int,int> PII;
const int N = 2e5 + 10;
PII arr[N];
int n = 0, k = 0;
int main() {cin >> n >> k;for (int i = 0; i < n; i++) cin >> arr[i].first;for (int i = 0; i < n; i++) cin >> arr[i].second;sort(arr, arr + n, [&](const PII & a, const PII & b) {if (a.second != b.second) return a.second > b.second;else return a.first < b.first;});long long s = 0, t = 0;for (int i = 0; i < k; i++) {s += arr[i].first;t += arr[i].second;}cout << s << " " << t << endl;return 0;}

054:01背包

01背包_牛客题霸_牛客网 (nowcoder.com)

题目:

题解:

01背包模板题:
1. 状态表⽰:
dp[i][j] 表⽰从前 i 个物品中挑选,总体积不超过 j 的情况下,最⼤重量是多少。
2. 状态转移⽅程:
根据「最后⼀步」的状况,来分情况讨论:
i. 不选第i 个物品:相当于就是去前 i - 1 个物品中挑选,并且总体积不超过 j 。此时dp[i][j] = dp[i - 1][j] ;

ii. 选择第 i 个物品:那么我就只能去前 i - 1 个物品中,挑选总体积不超过 j - v[i] 的物品。此时 dp[i][j] = dp[i - 1][j - v[i]] + w[i] 。但是这种状态不⼀定存在,因此需要特判⼀下。
综上,状态转移⽅程为: dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - v[i]] + w[i])

 

class Solution {
public:int knapsack(int V, int n, vector<vector<int> >& vw) {    int dp[1010][1010];for(int i=1;i<=n;i++){for(int j=0;j<=V;j++){dp[i][j]=dp[i-1][j];if(j>=vw[i-1][0]) dp[i][j]=max(dp[i][j],dp[i-1][j-vw[i-1][0]]+vw[i-1][1]);} }return dp[n][V];}
};//**空间优化版**
class Solution {
public:int knapsack(int V, int n, vector<vector<int> >& vw) {int dp[1010]={0};for(int i=0;i<n;i++){for(int j=V;j>=vw[i][0];j--){dp[j]=max(dp[j],dp[j-vw[i][0]]+vw[i][1]);}}return dp[V];}
};

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

相关文章

Middle for Mac:简洁高效的文本编辑软件

追求简洁与高效&#xff1f;Middle for Mac将是您文本编辑的最佳选择。这款Mac平台上的文本编辑器&#xff0c;以其独特的魅力和实用的功能&#xff0c;赢得了众多用户的喜爱。 Middle注重用户体验&#xff0c;采用简洁直观的界面设计&#xff0c;让您能够迅速上手并享受高效的…

IIS部署vue项目 IIS重写URL

【第一步】安装IIS {1&#xff09;打开控制面板 -> 打开程序和功能 -> 打开启用或关闭windows功能 &#xff08;2&#xff09;找到 Internet Information Services 勾选【web管理工具】和【万维网服务】&#xff0c;然后 确定 【第二步】安装URL重写模块 1). 安装URL …

【Web前端】jquery_json

1.jquery 1.1jquery简介 jquery是一个快速、简洁的javascript框架&#xff0c;于2006年1月份发布。jquery设计的宗旨是"write less,domore"&#xff0c;倡导写更少的代码&#xff0c;做更多的事情。封装了javascript常用的一些功能代码&#xff0c;提供一种简便的j…

软件应用开发安全设计指南

1.1 应用系统架构安全设计要求 设计时要充分考虑到系统架构的稳固性、可维护性和可扩展性&#xff0c;以确保系统在面对各种安全威胁时能够稳定运行。 在设计系统架构时&#xff0c;要充分考虑各种安全威胁&#xff0c;如DDoS攻击、SQL注入、跨站脚本攻击&#xff08;XSS&…

【编程向导】Docker-常用命令

常用命令 管理命令 管理命令说明builder管理构建config管理配置container管理容器context管理上下文engine管理引擎image管理镜像network管理网络node管理 Swarm 节点plugin管理插件secret管理 Docker secretsservice管理服务stack管理 Docker stacksswarm管理 Swarm 集群sys…

我的创作纪念日1460天(4年)

机缘 作为一名技术爱好者&#xff0c;我最初成为创作者的初心源于对知识的渴望和对分享的热情。在参与多个实战项目的过程中&#xff0c;我积累了丰富的经验&#xff0c;这些经验不仅仅是代码和解决方案&#xff0c;更多的是对问题本质的理解和解决问题的思维方式。我意识到&a…

爬虫-无限debug场景 解决方式

解决无限debug 场景1 1. 鼠标右键 选择 continue to here&#xff08;此处不停留&#xff09;2. 鼠标右键 选择 edite breakpoint 设置 10 保证条件不成立 这行永远不执行3.方法置空 1. 方法调用加断点2. 控制台 setInterval function name() {}4. 替换文件 5. hoo…

Java入门基础学习笔记13——数据类型

数据类型的分类&#xff1a; 基本数据类型 引用数据类型 基本数据类型&#xff1a;4大类8种类型&#xff1a; 定义整形用int&#xff0c;再大的数用long。 package cn.ensource.variable;public class VariableDemo2 {public static void main(String[] args) {//目标&#x…