【优选算法必刷100题】第41-42题(模拟):Z 字形变换,外观数列

【优选算法必刷100题】第41-42题(模拟):Z 字形变换,外观数列

🔥个人主页:Cx330🌸

❄️个人专栏:《C语言》《LeetCode刷题集》《数据结构-初阶》《C++知识分享》

《优选算法指南-必刷经典100题》《Linux操作系统》:从入门到入魔

《Git深度解析》:版本管理实战全解

🌟心向往之行必能至


🎥Cx330🌸的简介:


前言:

聚焦算法题实战,系统讲解三大核心板块:“精准定位最优解”——优选算法,“简化逻辑表达,系统性探索与剪枝优化”——递归与回溯,“以局部最优换全局高效”——贪心算法,讲解思路与代码实现,帮助大家快速提升代码能力

41. Z 字形变换

题目链接:

6. Z 字形变换 - 力扣(LeetCode)

题目描述:

题目示例:

算法原理(模拟):
思路:

找规律,用 row 代替行数,row = 4 时画出的 N 字形如下:
0 2row - 2 4row - 4
1 2row - 3 2row - 1 4row - 5 4row - 3
2 2row-4 2row 4row - 6 4row - 2
3 2row + 1 4row - 1

不难发现,数据是以 2row - 2 为⼀个周期进行规律变换的。将所有数替换成用周期来表示的变量:
第一行的数是:0, 2row - 2, 4row - 4;

第二行的数是:1, (2row - 2) - 1, (2row - 2) + 1, (4row - 4) - 1, (4row - 4) + 1;

第三行的数是:2, (2row - 2) - 2, (2row - 2) + 2, (4row - 4) - 2, (4row - 4) + 2;

第四行的数是:3, (2row - 2) + 3, (4row - 4) + 3。

可以观察到,第一行、第四行为差为 2row - 2 的等差数列;第二行、第三行除了第⼀个数取值为行数,每组下标为(2n - 1, 2n)的数围绕(2row - 2)的倍数左右取值。
以此规律,我们可以写出迭代算法。

模拟解法代码(C++):
class Solution { public: string convert(string s, int numRows) { string ret; int d=2*numRows-2,n=s.size(); //如果n=1直接返回原字符串 if(numRows==1) return s; //处理第一行 for(int i=0;i<n;i+=d) ret+=s[i]; //处理中间行 for(int k=1;k<numRows-1;k++) { for(int i=k,j=d-k;i<n||j<n;i+=d,j+=d) { if(i<n) ret+=s[i]; if(j<n) ret+=s[j]; } } //处理最后一行 for(int i=numRows-1;i<n;i+=d) ret+=s[i]; return ret; } };
博主手记(字体还请见谅哈):

42. 外观数列

题目链接:

38. 外观数列 - 力扣(LeetCode)

题目描述:

题目示例:

算法原理(模拟):
思路:

所谓【外观数列】,其中只是依次统计字符串中连续且相同的字符的个数。依据题意,依次模拟即可。

模拟解法代码(C++):
class Solution { public: string countAndSay(int n) { string ret="1"; for(int i=1;i<n;i++)//解释n-1次ret { string tmp; int len=ret.size(); for(int left=0,right=0;right<len;) { while(right<len&&ret[left]==ret[right]) right++; //to_string获取元素个数 tmp+=to_string(right-left)+ret[left]; left=right; } ret=tmp; } return ret; } };
博主手记(字体还请见谅哈):

总结:

结语:本文分享了两个算法题的解题思路和C++实现。首先针对"Z字形变换"问题,通过观察字符排列规律,采用周期模拟法将字符串按特定顺序重组。其次解决"外观数列"问题,通过统计连续相同字符个数生成新字符串。两题均采用模拟解法,文章以实战为导向,简洁明了地展示了从问题分析到代码落地的完整过程。

Read more

终极图表数据自动化提取:PlotDigitizer完整实战指南

终极图表数据自动化提取:PlotDigitizer完整实战指南 【免费下载链接】PlotDigitizerA Python utility to digitize plots. 项目地址: https://gitcode.com/gh_mirrors/pl/PlotDigitizer 在科研数据处理和图表分析中,我们常常面临一个共同挑战:如何从静态图表图像中恢复原始数据?无论是学术论文中的曲线图、工程报告中的散点分布,还是商业分析中的趋势图表,手动读取数据不仅耗时耗力,还容易出错。PlotDigitizer作为专业的Python图表数字化工具,正是为解决这一痛点而生。 图表数字化的现实困境 传统图表数据提取往往依赖人工判读和手动记录,这种方法存在诸多限制: * 精度难以保证:肉眼判断坐标位置存在主观误差 * 效率极其低下:复杂图表可能需要数小时处理 * 批量处理困难:多个相关图表难以保持一致性 * 数据格式混乱:手动记录容易导致格式不统一 PlotDigitizer能够智能识别带网格线的图表,自动校准坐标系统 PlotDigitizer:数据提取的革命性方案

By Ne0inhk
【DINOv3】(1)下载与使用

【DINOv3】(1)下载与使用

欢迎关注【AGI使用教程】 专栏 【AGI使用教程】GPT-OSS 本地部署 【AGI使用教程】Meta 开源视觉基础模型 DINOv3 【AGI使用教程】Meta 开源视觉基础模型 DINOv3 * 1. Meta DINOv3 介绍 * 1.1 DINOv3 功能概览 * 1.2 DINOv3 下载地址 * 2. DINOv3 预训练模型 * 2.1 下载 DINOv3 预训练模型 * 2.2 预训练主干网络(通过 PyTorch Hub 加载) * 2.3 通过 Hugging Face 提供的预训练主干网络 * 2.4 图像变换

By Ne0inhk
Git:如何将一个分支的特定提交合并到另一个分支?

Git:如何将一个分支的特定提交合并到另一个分支?

了解更多,关注微信公众号 「思客潘」 Git:将一个分支的特定提交合并到另一个分支的完整指南 一、Git 提交合并的基本方法 1.1 使用 cherry-pick(最常用方法) 适用场景:将某个分支的单个或多个指定提交应用到当前分支。 # 基本语法git cherry-pick <commit-hash># 示例:将feature分支的提交应用到main分支# 1. 首先切换到目标分支git checkout main # 2. 查看要合并的提交IDgit log --oneline --graph feature # 3. 选择并合并特定提交git cherry-pick abc123def # 4. 合并多个不连续的提交git cherry-pick abc123def 789xyz01 # 5. 合并连续范围的提交(左开右闭)git cherry-pick start-commit^..end-commit # 例如:合并从A到B的所有提交(

By Ne0inhk
Answer 开源平台搭建:cpolar 内网穿透服务助力全球用户社区构建

Answer 开源平台搭建:cpolar 内网穿透服务助力全球用户社区构建

文章目录 * 前言 * 1. 本地安装Docker * 2. 本地部署Apache Answer * 2.1 设置语言选择简体中文 * 2.2 配置数据库 * 2.3 创建配置文件 * 2.4 填写基本信息 * 3. 如何使用Apache Answer * 3.1 后台管理 * 3.2 提问与回答 * 3.3 查看主页回答情况 * 4. 公网远程访问本地 Apache Answer * 4.1 内网穿透工具安装 * 4.2 创建远程连接公网地址 * 5. 固定Apache Answer公网地址 前言 在开源社区运营中,问答平台的全球化访问始终面临双重挑战:一方面需要保障数据主权与隐私安全,另一方面要实现低延迟的跨地域访问。Answer

By Ne0inhk