算法入门小题目——点击消除

简介: 算法入门小题目——点击消除

这个题这样做

先看栈空吗,栈空就放元素,不空判断栈顶元素和当前的字符是否一样,若一样,就不进栈,往后遍历,并弹出栈顶元素

现在栈里面的元素就是我们需要的,但是这是逆序的,我们需要把他存在一个链表里,然后逆置,打印即可

上代码

import java.util.*;
// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        // 注意 hasNext 和 hasNextLine 的区别
        while (in.hasNextLine()) { // 注意 while 处理多个 case
           String str=in.nextLine();
           func(str);
        }
    }
    public static void func(String str){
        Stack<Character> stack=new Stack<>();
        List<Character> list=new ArrayList<>();
        for(int i=0;i<str.length();i++){
            char ch=str.charAt(i);
            if(stack.isEmpty()||ch!=stack.peek()){
                stack.push(ch);
            }else{
                stack.pop();
            }
        }
        if(stack.isEmpty()){
            System.out.print("0");
        }else{
            while(!stack.isEmpty()){
                list.add(stack.pop());
            }
        }
        Collections.reverse(list);
        for(int i=0;i<list.size();i++){
            System.out.print(list.get(i));
        }
    }
}


这是第一种方法,还有第二种方法,我们采用StringBuilder来做


public class TestDemo {
    public static void main(String[] args){
        Scanner in=new Scanner(System.in);
        while(in.hasNextLine()){
            String str=in.nextLine();
            StringBuilder stringBuilder=new StringBuilder(str.length());
            int index=-1;
          for(int i=0;i<str.length();i++){
              char ch=str.charAt(i);
              if(index==-1||ch!=stringBuilder.charAt(index)){
                  stringBuilder.append(ch);
              }else{
                  stringBuilder.deleteCharAt(index);
                  index--;
              }
          }
          if(index==-1){
              System.out.println("0");
          }else{
              System.out.println(stringBuilder);
          }
        }
    }
}

用到StringBuilder就避免了逆置

相关文章
|
6月前
|
机器学习/深度学习 人工智能 算法
深度学习入门:理解神经网络与反向传播算法
【9月更文挑战第20天】本文将深入浅出地介绍深度学习中的基石—神经网络,以及背后的魔法—反向传播算法。我们将通过直观的例子和简单的数学公式,带你领略这一技术的魅力。无论你是编程新手,还是有一定基础的开发者,这篇文章都将为你打开深度学习的大门,让你对神经网络的工作原理有一个清晰的认识。
|
4月前
|
机器学习/深度学习 算法 Python
机器学习入门:理解并实现K-近邻算法
机器学习入门:理解并实现K-近邻算法
65 0
|
5月前
|
机器学习/深度学习 算法
机器学习入门(三):K近邻算法原理 | KNN算法原理
机器学习入门(三):K近邻算法原理 | KNN算法原理
|
5月前
|
机器学习/深度学习 算法 大数据
机器学习入门:梯度下降算法(下)
机器学习入门:梯度下降算法(下)
|
5月前
|
机器学习/深度学习 算法
机器学习入门:梯度下降算法(上)
机器学习入门:梯度下降算法(上)
|
5月前
|
机器学习/深度学习 算法 API
机器学习入门(五):KNN概述 | K 近邻算法 API,K值选择问题
机器学习入门(五):KNN概述 | K 近邻算法 API,K值选择问题
|
7月前
|
机器学习/深度学习 人工智能 算法
AI入门必读:Java实现常见AI算法及实际应用,有两下子!
本文全面介绍了人工智能(AI)的基础知识、操作教程、算法实现及其在实际项目中的应用。首先,从AI的概念出发,解释了AI如何使机器具备学习、思考、决策和交流的能力,并列举了日常生活中的常见应用场景,如手机助手、推荐系统、自动驾驶等。接着,详细介绍了AI在提高效率、增强用户体验、促进技术创新和解决复杂问题等方面的显著作用,同时展望了AI的未来发展趋势,包括自我学习能力的提升、人机协作的增强、伦理法规的完善以及行业垂直化应用的拓展等...
438 3
AI入门必读:Java实现常见AI算法及实际应用,有两下子!
|
7月前
|
SQL 算法 Serverless
B端算法实践问题之使用concat_id算子获取用户最近点击的50个商品ID如何解决
B端算法实践问题之使用concat_id算子获取用户最近点击的50个商品ID如何解决
49 1
|
7月前
|
算法 Java
LeetCode经典算法题:矩阵中省份数量经典题目+三角形最大周长java多种解法详解
LeetCode经典算法题:矩阵中省份数量经典题目+三角形最大周长java多种解法详解
88 6

热门文章

最新文章