使用堆栈检查给定的字符串是否是回文

Check if given string is a palindrome using stack(使用堆栈检查给定的字符串是否是回文)
本文介绍了使用堆栈检查给定的字符串是否是回文的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

伙计们,

我最近接受了采访,并收到了一个关于回文的问题.

I was recently interviewed and got a question on Palindrome.

给定一个字符串(可能代表一个日期),检查它是否是一个回文或不使用堆栈.

Given a string ( which might represent a date ), check if it's a palindrome or not using Stack.

我试图想出解决办法,但他不喜欢这样.

I tried to come up with solution, but he didn't like that.

谁能给我看Java的代码片段?

Can anyone show me the code snippet for it in Java ?

谢谢

PS:这不是作业,而是实际的面试问题.

PS : This is not a homework, actual interview question.

推荐答案

import java.util.Stack;

public class PalindromeTest {

    public static void main(String[] args) {

        String input = "test";
        Stack<Character> stack = new Stack<Character>();

        for (int i = 0; i < input.length(); i++) {
            stack.push(input.charAt(i));
        }

        String reverseInput = "";

        while (!stack.isEmpty()) {
            reverseInput += stack.pop();
        }

        if (input.equals(reverseInput))
            System.out.println("Yo! that is a palindrome.");
        else
            System.out.println("No! that isn't a palindrome.");

    }
}

这篇关于使用堆栈检查给定的字符串是否是回文的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

How can create a producer using Spring Cloud Kafka Stream 3.1(如何使用Spring Cloud Kafka Stream 3.1创建制片人)
Insert a position in a linked list Java(在链接列表中插入位置Java)
Did I write this constructor properly?(我是否正确地编写了这个构造函数?)
Head value set to null but tail value still gets displayed(Head值设置为空,但仍显示Tail值)
printing nodes from a singly-linked list(打印单链接列表中的节点)
Control namespace prefixes in web services?(控制Web服务中的命名空间前缀?)