Java玩转《啊哈算法》解密回文之栈

菩萨清凉月,常游毕竟空,众生心垢净,菩提影现中。

这目录

  • 这开头
  • 这代码地址
    • 案例
    • 代码
    • 优化建议
    • 类似
    • 扩展

这开头

各位女士们,先生们好!本人最近在看《啊哈算法》,这本书写的确实还可以,很有趣味性。

但略微遗憾的是,书籍示例代码是c语言,而不是本人常用的Java。

那就弥补遗憾吧。于是乎说干就干,把这本书的示例语言用java写一遍, 顺带夹杂一些私货,附上自己的一些理解!

于是就有了本篇博客,本篇博客主要是讲常见数据结构的一种:栈。

在这里插入图片描述

来不及买纸质书但又想尽快感受算法魅力的童鞋也甭担心,电子版的下载链接已经放到下方了,可尽情下载。

链接:https://pan.baidu.com/s/1imxiElcCorw2F-HJEnB-PA?pwd=jmgs
提取码:jmgs

在这里插入图片描述

这代码地址

本文代码已开源:

git clone https://gitee.com/guqueyue/my-blog-demo.git

请切换到gitee分支,

然后查看aHaAlgorithm模块下的src/main/java/com/guqueyue/aHaAlgorithm/chapter_2_StackAndChainTable即可!

在上期博客:Java玩转《啊哈算法》解密QQ号之队列 中,我们说到
在这里插入图片描述

而与队列相对的栈,也有一个非常核心的概念:FILO(First In Last Out) - 先进后出
在这里插入图片描述

如上图,栈就像往桶里面放球,先放进去的球,要后面才能拿出来。

在这里插入图片描述

这也暗合一句歇后语:砌墙的石头 —— 后来居上。

当然,在我往期的博客:递归和循环之间不得不说的故事 中,里面也有生动形象的动图用来理解栈,这里就不多加赘述。

同样的,栈也只有两种操作:

  1. 新来的元素入栈。
  2. 栈顶的元素出栈。

案例

同样的,作者这里也用了一个案例,来引出

栈究竟有哪些作用呢?
我们来看一个例子。“xyzyx”是一个回文字符串,所谓回文字符串就是指正读反读均相同的字符序列,如“席主席”、“记书记”、“aha”和“ahaha”均是回文,但“ahah”不是回文。通过栈这个数据结构我们将很容易判断一个字符串是否为回文。

我们来分析一下这道题目, 关于回文串,无非就是左右对称嘛。

那么,我们只需要如下几步即可:

  1. 求出中心对称点。将回文串分为 左串右串
  2. 左串从右到左 的顺序 和 右串从左到右的顺序进行逐个字符匹配。若全匹配上,则为回文串;反之,则不然。
  3. 我们只需要将左串从左到右 的顺序入栈,由于栈为先进后出,所以我们只需要出栈,即为从右到左

那么,我们只需要边匹配边出栈,匹配上则出栈;匹配不上,则结束匹配。

如果匹配结束,栈为空,则说明是回文串;反之,则不是。

代码

理论讲完了,下面直接上代码:

package com.guqueyue.aHaAlgorithm.chapter_2_StackAndChainTable;

import java.util.Scanner;

/**
 * @Author: guqueyue
 * @Description: 通过栈判断是否为回文串
 * @Date: 2024/1/12
 **/
public class PalindromeStr {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);

        System.out.print("请输入一段字符串:");
        String str = scanner.nextLine();

        // 获取字符串长度 以及 字符串中心点
        int len = str.length();
        int mid = len / 2 - 1;

        // 初始化栈并入栈 - 左串
        char[] stack = new char[101];
        int top = -1;
        for (int i = 0; i <= mid; i++) {
            stack[++top] = str.charAt(i);
        }

        // 获取起始匹配点 - 长度为偶数为 mid+1, 奇数为 mid+2
        int next = (len % 2 == 0) ? mid + 1 : mid + 2;
        // 开始匹配 - 右串
        for (int i = next; i <= len - 1; i++) {
            if (str.charAt(i) != stack[top]) {
                break;
            }

            top--;
        }
		
		// 若栈顶为-1, 即栈为空,则是回文串
        System.out.println(top == -1 ? "YES" : "NO");
    }
}

运行,若输入aha
在这里插入图片描述
若输入ahah
在这里插入图片描述
完美!!!

优化建议

当然,我们也可以把数组和栈顶指针抽出来封装成栈类再使用,如:

package com.guqueyue.aHaAlgorithm.entity;

/**
 * @Author: guqueyue
 * @Description: 栈 - 字符栈
 * @Date: 2024/2/5
 **/
public class CharStack {

    public char[] data = new char[10]; // 数组,用来存储栈的内容
    public int top = -1; // 栈顶
}

然后,小幅改动即可:

package com.guqueyue.aHaAlgorithm.chapter_2_StackAndChainTable;

import com.guqueyue.aHaAlgorithm.entity.CharStack;

import java.util.Scanner;

/**
 * @Author: guqueyue
 * @Description: 通过栈判断是否为回文串
 * @Date: 2024/2/5
 **/
public class PalindromeStr2 {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);

        System.out.print("请输入一段字符串:");
        String str = scanner.nextLine();

        // 获取字符串长度 以及 字符串中心点
        int len = str.length();
        int mid = len / 2 - 1;

        // 初始化栈并入栈 - 左串
        CharStack stack = new CharStack();
        for (int i = 0; i <= mid; i++) {
            stack.data[++stack.top] = str.charAt(i);
        }

        // 获取起始匹配点 - 长度为偶数为 mid+1, 奇数为 mid+2
        int next = (len % 2 == 0) ? mid + 1 : mid + 2;
        // 开始匹配 - 右串
        for (int i = next; i <= len - 1; i++) {
            if (str.charAt(i) != stack.data[stack.top]) {
                break;
            }

            stack.top--;
        }

        // 若栈顶为-1, 即栈为空,则是回文串
        System.out.println(stack.top == -1 ? "YES" : "NO");
    }
}

类似

当然,力扣上面也有同样的题目:125. 验证回文串

在这里插入图片描述

当然,这道题稍微复杂一点,需要剔除所有非字母数字字符,然后再将大写字母转小写。

但是,我相信,如果你理解了上面的栈,再简单查阅些资料,绝对难不倒你的!

扩展

栈的运用其实很广泛,上文的例子看起来好像只是为了出题,而是我们的实际有点远.。

那么,有没有什么例子离我们特别是作为程序员的我们比较近的呢?

当然有,那就是括号的匹配

我们在编写代码的时候括号到底有没有匹配上,编译器会进行自动检测:
在这里插入图片描述
在这里插入图片描述

如上图,我注释掉了两个括号,编译器会自动报错,提示有两个括号缺失。

这也是力扣一道比较经典的题目,看看你能不能做的出来吧:20. 有效的括号

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

代码随想录算法训练营第28天 | 93.复原IP地址 ,78.子集 ,90.子集II

回溯章节理论基础&#xff1a; https://programmercarl.com/%E5%9B%9E%E6%BA%AF%E7%AE%97%E6%B3%95%E7%90%86%E8%AE%BA%E5%9F%BA%E7%A1%80.html 93.复原IP地址 题目链接&#xff1a;https://leetcode.cn/problems/restore-ip-addresses/ 思路&#xff1a; 这是切割问题&am…

2024年2月8日 十二生肖 今日运势

小运播报&#xff1a;2024年2月8日&#xff0c;星期四&#xff0c;农历腊月廿九 &#xff08;甲辰年丙寅月壬寅日&#xff09;&#xff0c;法定工作日。 红榜生肖&#xff1a;马、猪、狗 需要注意&#xff1a;龙、蛇、猴 喜神方位&#xff1a;正南方 财神方位&#xff1a;正…

基于swing和cf的推荐相似度SQL实现

对于cf和swing算法的介绍可以参考ItemCF的演进&#xff1a;狭义 VS 广义 基于cf的推荐相似度 这里介绍这样一个场景&#xff0c;我们有了大量的电商购买数据&#xff0c;希望通过cf算法计算不同的类目之间的相似度&#xff0c;以方便对用户购买进行兴趣探索。 使用SQL实现需要…

10.0 Zookeeper 权限控制 ACL

zookeeper 的 ACL&#xff08;Access Control List&#xff0c;访问控制表&#xff09;权限在生产环境是特别重要的&#xff0c;所以本章节特别介绍一下。 ACL 权限可以针对节点设置相关读写等权限&#xff0c;保障数据安全性。 permissions 可以指定不同的权限范围及角色。 …

【STL】:priority_queue介绍和模拟实现

朋友们、伙计们&#xff0c;我们又见面了&#xff0c;本期来给大家解读一下有关priority_queue的使用&#xff0c;如果看完之后对你有一定的启发&#xff0c;那么请留下你的三连&#xff0c;祝大家心想事成&#xff01; C 语 言 专 栏&#xff1a;C语言&#xff1a;从入门到精通…

C# ONNX使用入门教程

背景 有新入坑的老哥不太了解C# onnx 运行的机理&#xff0c;我这边详细介绍一下&#xff0c;之前直接放官方的样例有点草率了。 准备[python环境] 1、要使用onnx&#xff0c;首先我们就自己生成一个onnx文件&#xff0c;请大家准备一下以下需要的[python]环境 python 版本…

探索设计模式的魅力:揭秘享元模式-轻松实现资源高效利用的秘密武器

设计模式专栏&#xff1a;http://t.csdnimg.cn/U54zu 目录 引言&#xff1a; 一、简介 二、实现资源的极致利用 公共自行车与享元模式的智慧共享 HOW 三、案例探讨 3.1 场景 3.2 不用模式实现&#xff1a;一坨坨代码实现 3.3 痛点 3.4 解决方案分析 注意 四、深入享…

Qt多线程与SocketTCP的简单实现

1.相关说明 多线程实现Qt的socket编程实现客户端发送文件&#xff0c;服务端接收文件&#xff0c;并且在客户端设置了心跳&#xff0c;用于监控服务端是否存活。因为Qt中socket套接字发送数据&#xff0c;会先把数据发送至缓冲区中&#xff0c;在发送数据过程中&#xff0c;soc…

寒假学习第24天---PythonPoc基础编写(二)

提示&#xff1a;所分享内容仅用于每一个爱好者之间的技术讨论及教育目的&#xff0c;所有渗透及工具的使用都需获取授权&#xff0c;禁止用于违法途径&#xff0c;否则需自行承担&#xff0c;本作者不承担相应的后果。 文章目录 前言一、 目标二、过程思路实践开始 总结完整代…

Java基于微信小程序的驾校报名小程序,附源码

博主介绍&#xff1a;✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;…

腾讯云游戏服务器购买入口,详细配置精准报价

2024年更新腾讯云游戏联机服务器配置价格表&#xff0c;可用于搭建幻兽帕鲁、雾锁王国等游戏服务器&#xff0c;游戏服务器配置可选4核16G12M、8核32G22M、4核32G10M、16核64G35M、4核16G14M等配置&#xff0c;可以选择轻量应用服务器和云服务器CVM内存型MA3或标准型SA2实例&am…

创建网站的具体步骤是什么?

创建网站的具体步骤是什么 一.领取一个免费域名和SSL证书&#xff0c;和CDN 1.打开网站链接&#xff1a;https://www.rainyun.com/z22_ 2.在网站主页上&#xff0c;您会看到一个"登陆/注册"的选项。 3.点击"登陆/注册"&#xff0c;然后选择"微信登…

假期刷题打卡--Day26

1、MT1212乘法表 请编写一个简单程序&#xff0c;输出九九乘法表。输入n&#xff0c;就输出乘法表到n的地方。 格式 输入格式&#xff1a; 输入整型 输出格式&#xff1a; 输出整型。形式如&#xff1a;1*11 样例 1 输入&#xff1a; 5输出&#xff1a; 1*11 2*12 …

格子表单GRID-FORM | 文档网站搭建(VitePress)与部署(Github Pages)

格子表单/GRID-FORM已在Github 开源&#xff0c;如能帮到您麻烦给个星&#x1f91d; GRID-FORM 系列文章 基于 VUE3 可视化低代码表单设计器嵌套表单与自定义脚本交互文档网站搭建&#xff08;VitePress&#xff09;与部署&#xff08;Github Pages&#xff09; 效果预览 格…

服装设计公司,如何用钉钉实现企业数字化成功转型?

钉钉作为数字化工作平台&#xff0c;为某服装设计公司实现了组织管理的数字化转型&#xff0c;构建了一站式的工作平台。通过钉钉赋能&#xff0c;有利于企业推进组织架构、员工沟通、产品运营和客户服务等方面的数字化、智能化转型。 借助钉钉平台&#xff0c;该服设公司轻松实…

【C++第二阶段】空指针访问成员函数常成员函数常成员属性

你好你好&#xff01; 以下内容仅为当前认识&#xff0c;可能有不足之处&#xff0c;欢迎讨论&#xff01; 文章目录 空指针访问成员函数常成员函数&常成员属性 空指针访问成员函数 类对象类型的空指针可以访问成员函数&#xff0c;但是不能够访问带有成员属性的成员函数。…

js-添加网页快捷方式

title: js-添加网页快捷方式 categories: Javascript tags: [p快捷方式] date: 2024-02-04 15:28:25 comments: false mathjax: true toc: true js-添加网页快捷方式 前篇 谷歌上包困难的情况, 只能通过投放落地页来缓解一下痛苦, web2app 那种形式有几个比较大的缺点就是需要…

人工智能基础部分24-人工智能的数学基础,汇集了人工智能数学知识最全面的概况

、 大家好&#xff0c;我是微学AI&#xff0c;今天给大家介绍一下人工智能基础部分24-人工智能的数学基础&#xff0c;汇集了人工智能数学知识最全面的概况&#xff0c;深度学习是一种利用多层神经网络对数据进行特征学习和表示学习的机器学习方法。要全面了解深度学习的数学基…

FlinkSql通用调优策略

历史文章迁移&#xff0c;稍后整理 使用DataGenerator 提前进行压测&#xff0c;了解数据的处理瓶颈、性能测试和消费能力 开启minibatch&#xff1a;"table.exec.mini-batch.enabled", "true" 开启LocalGlobal 两阶段聚合&#xff1a;"table.exec.m…

【力扣】快乐数,哈希集合+快慢指针+数学

快乐数原题地址 方法一&#xff1a;哈希集合 定义函数getNext(n)&#xff0c;返回n的所有位的平方和。一直执行ngetNext(n)&#xff0c;最终只有2种可能&#xff1a; n停留在1。无限循环且不为1。 证明&#xff1a;情况1是存在的&#xff0c;如力扣的示例一&#xff1a; 接…