当前位置: 首页 > news >正文

日常算法刷题

👨‍💻 关于作者:会编程的土豆

“不是因为看见希望才坚持,而是坚持了才看见希望。”

你好,我是会编程的土豆,一名热爱后端技术的Java学习者。

📚正在更新中的专栏:

  • 《数据结构与算法》😊😊😊

  • 《leetcode hot 100》🥰🥰🥰🤩🤩🤩

  • 《数据库mysql》

💕作者简介:后端学习者

1.

#include<iostream> #include<vector> #include<algorithm> using namespace std; int main() { string s; cin >> s; int n = s.size(); vector<vector<int>>dp(n + 1, vector<int>(n + 1)); string t = s; reverse(s.begin(), s.end()); for (int i = 1; i <= n; i++) { for (int j = 1; j <= n; j++) { if (s[i - 1] == t[j - 1]) { dp[i][j] = dp[i - 1][j - 1] + 1; } else { dp[i][j] = max(dp[i - 1][j],dp[i][j - 1]); } } } cout << n - dp[n][n] << endl; return 0; }

经典 LCS(最长公共子序列),所谓公共子序列,就是可以不连续的,两个字符串中相同的部分,比如Ab3bd和db3bA,公共子序列就是b3b;

那么这个题为什么要使用公共子序列呢,诶,很有意思,这个题要求回文字串,回文子串就是正反一样的那种,他问要几个字母才能构成,非常有意思,咱们把原来的字符串反过来,然后求这个字符串和原来的字符串的公共子序列,这个公共子序列就是回文一样的,咱们用总字符串大小减去这个大小就是答案;

2.

#include<iostream> #include<vector> #include<algorithm> using namespace std; int main() { vector<int>arr; int x; while (cin >> x) { arr.push_back(x); } reverse(arr.begin(), arr.end()); vector<int>tail; for (int i = 0; i < arr.size(); i++) { int x = arr[i]; auto it = upper_bound(tail.begin(), tail.end(), x); if (it == tail.end()) { tail.push_back(x); } else { *it = x; } } cout << tail.size() << endl; reverse(arr.begin(), arr.end()); vector<int>g; for (int i = 0; i < arr.size(); i++) { int x = arr[i]; auto it = lower_bound(g.begin(), g.end(), x); if (it == g.end()) { g.push_back(x); } else *it = x; } cout << g.size() << endl; return 0; }

这个需要注意的是用while作为输入,那么结束的时候就需要Ctrl+Z一下;

两个小问,第一问要求求出最长的那个导弹长度,题目要求递减,咱们倒过来就是求递增,因为算法只会求递增哈;

第二问求有几个递减序列,咱们把原始数组递增的个数求出来,就是有几个递减的;

3.

#include<iostream> #include<vector> #include<algorithm> using namespace std; typedef struct node { int u, v, w; }node; vector<int>parent; vector<node>arr; vector<bool>enemy; int find(int x) { if (parent[x] != x) { parent[x] = find(parent[x]); } return parent[x]; } bool f(node a, node b) { return a.w > b.w; } int main() { int N, K; cin >> N >> K; enemy.resize(N + 1, false); parent.resize(N + 1); for (int i = 1; i <= N; i++) parent[i] = i; for (int i = 1; i <= K; i++) { int mmm; cin >> mmm; enemy[mmm] = true; } long long ssum = 0; for (int i = 1; i <= N - 1; i++) { int u, v, w; cin >> u >> v >> w; ssum += w; arr.push_back({ u,v,w }); } sort(arr.begin(), arr.end(), f); long long sum = 0; for (int i = 0; i < arr.size(); i++) { int u = arr[i].u; int v = arr[i].v; int w = arr[i].w; int rootu = find(u); int rootv = find(v); if (!(enemy[rootu] && enemy[rootv])) { if (rootu != rootv) { parent[rootu] = rootv; sum += w; enemy[rootv] = enemy[rootu] || enemy[rootv]; } } } cout << ssum - sum << endl; return 0; }
http://www.jsqmd.com/news/636784/

相关文章:

  • 2026宜宾石膏板公司技术指南:正品鉴别与潮湿环境适配 - 优质品牌商家
  • 2026年4月更新:安徽市场备受关注的护栏网实力厂商——安平县亿旭丝网制品有限公司测评 - 2026年企业推荐榜
  • 飞连策略锁定壁纸无法修改怎么办?一文讲清注册表残留清理与恢复方法
  • 监管倒计时60天:AIAgent可解释性设计必须满足的5项ISO/IEC 23894-2023强制条款
  • 告别数据孤岛:用IPC CFX SDK快速打通SMT产线与MES系统(C#实战)
  • LangChain Agent避坑实录:我用create_react_agent做中文电商助手,遇到的3个‘坑’和解决方案
  • 从0到1搭建Multi-Agent分析平台:LangGraph完整实战
  • 【数据结构与算法】哈希表
  • Windows 搜索不能使用怎么办?一文讲清 PowerShell 修复方法与排查思路
  • 2026北京渐变玻璃厂商诚信度评估:聚焦北京晶彩华阳装饰玻璃有限公司的专业解析 - 2026年企业推荐榜
  • DAMO-YOLO在智能相册管理中的应用:快速分类人物车辆照片
  • Windows远程连接Ubuntu 22.04桌面终极指南:解决xrdp卡顿、分辨率异常和QtGUI问题
  • Multi-Agent 任务分解框架:从目标到子任务的可执行清单
  • 技术判断力之AI三问等
  • c++如何将程序运行日志通过Socket实时同步到远程服务器【进阶】
  • 奇点大会闭门论坛实录:AIAgent生成代码的“可信边界”首次定义——5大不可逾越红线、2种强制熔断机制与1套开源合规审计工具链
  • Blender新手必学(1):建模系统核心快捷键全解析
  • Udio任务API的集成与使用教程
  • 注意力机制模块:将 SimAM 无参注意力加入 ConvNeXt Block,无需额外参数即可涨点
  • JavaUninstallTool:高效清理Java残留文件的终极指南
  • MySQL入门实战:从零学写SQL,口语化生动讲解,新手也能轻松学会
  • 计算机毕业设计:Python降水量分析可视化与预测预警 Flask框架 可视化 数据分析 大数据 大模型 机器学习 时间序列 爬虫(建议收藏)✅
  • EasyPOI数据导入中空白行的智能检测与处理方案
  • 别让AI代码,变成明天的技术债狙
  • RK35663568通过ADB命令快速切换第三方输入法实战指南
  • 多模态世界模型的终局:从内容生成到物理世界交互
  • 鸿蒙运动健康实战:自定义定位箭头跟随手机方向旋转
  • 聊城白酒回收市场2026年四月深度分析:高价变现指南与服务商五强榜单 - 2026年企业推荐榜
  • [开发者指南] WSL2 高效开发环境搭建与性能优化全攻略
  • 国产大模型突围战:2026年市场格局与未来竞争核心