Java-Part 0

news2025/1/12 6:07:12

Advanced Java and Cutting-edge Applications

Part 0: Course presentation

image-20240922221436556

Part 1

其实就是个括号匹配问题,Stack 经典问题,但是好久没用Java,有一点点生疏,感觉老师的版本要简洁的多

package tiei.ajp.test;

import java.util.HashMap;
import java.util.Map;
import java.util.Stack;

public class CheckBalance {
    public String str;

    public CheckBalance() {
    }

    public CheckBalance(String string) {
        str = string;
    }

    public boolean balanced() {
        Stack<Character> stack = new Stack<>();
        char[] s = str.toCharArray();
        Map<Character, Integer> map = Map.of('(', 1, '[', 2, '{', 3, ')', 4, ']', 5, '}', 6);
        for (Character c : s) {
//            if ((c != '(') && (c != ')') && (c != '[') && (c != ']') && (c != '{') && (c != '}')) continue;
            if(!map.containsKey(c)) continue;
//            if (c == '(' || c == '{' || c == '[') {
            if (map.get(c) <= map.size() / 2) {
                stack.push(c);
            } else {
                if (stack.empty()) return false;
                char temp = stack.peek();
//                if ((temp == '(' && c == ')') || (temp == '[' && c == ']') || (temp == '{' && c == '}')) {
                if (map.get(c) - map.get(temp) == map.size() / 2) {
                    stack.pop();
                } else {
                    return false;
                }
            }
        }
        return stack.empty();
    }

    public int index() {
        Stack<Integer> stack = new Stack<>();
        char[] s = str.toCharArray();

        for (int i = 0; i < s.length; i++) {
            char c = s[i];
//            if (Character.isLetter(c) || c == ' ') continue;
            if ((c != '(') && (c != ')') && (c != '[') && (c != ']') && (c != '{') && (c != '}')) continue;

            if (c == '(' || c == '{' || c == '[') {
                stack.push(i);
            } else {

                if (stack.empty()) return i;

                char temp = s[stack.peek()];
                if ((temp == '(' && c == ')') || (temp == '[' && c == ']') || (temp == '{' && c == '}')) {
                    stack.pop();
                } else {
                    return i;
                }
            }
        }

        if (!stack.empty()) return stack.peek();

        return -1;
    }
}

老师版本:

package tiei.ajp.test;

import java.util.HashMap;
import java.util.Map;
import java.util.Stack;

public class CheckBalance {
    private final String OPENINGS = "([{";
    private final String CLOSINGS = ")]}";

    private String s;
    private int index;
    private boolean balanced;

    public CheckBalance(String str) {
        this.s = str;
        balanced = balancedPrivate();
    }

    public boolean balanced(){
        return balanced;
    }

    private boolean balancedPrivate() {
        index = 0;
        Stack<Character> stack = new Stack<>();
        for (index = 0; index < s.length(); index++) {
            char c = s.charAt(index);
            if (isOpening(c)) {
                stack.push(c);
            } else if (isClosing(c)) {
                if (stack.empty() || dontMatch(stack.pop(), c)) {
                    return false;
                }
            }
        }
        return stack.isEmpty();
    }

    public int index() {
        return index;
    }

    private boolean isOpening(char c) {
        return OPENINGS.indexOf(c) > -1;
    }

    private boolean isClosing(char c) {
        return CLOSINGS.indexOf(c) > -1;
    }

    private boolean dontMatch(char o, char c) {
        return OPENINGS.indexOf(o) != CLOSINGS.indexOf(c);
    }
}
Part 2
package tiei.ajp.test;

public class ArrayStack {
    private static int MAX_SIZE = 100;
    private char[] stackArray;
    private int top;

    public ArrayStack(){
        stackArray = new char[MAX_SIZE];
        top = -1; 
    }
    public boolean isEmpty(){
        return top == -1;
    }
    public char peek(){
        if (isEmpty()) {
            return '\0';
        }
        return stackArray[top];
    }
    public void push(char c){
        if (top < MAX_SIZE - 1) {
            stackArray[++top] = c;
        }
    }
    public char pop(){
        if (isEmpty()) {
            return '\0';
        }
        return stackArray[top--];
    }
}
Part 3
package tiei.ajp.test;

public class ListStack {

    private class Node {
        char data;
        Node next;

        Node(char data) {
            this.data = data;
            this.next = null;
        }
    }

    private Node top;

    public ListStack() {
        top = null;
    }

    public boolean isEmpty() {
        return top == null;
    }


    public char peek() {
        if (isEmpty()) {
            return '\0';
        }
        return top.data;
    }


    public void push(char c) {
        Node newNode = new Node(c);
        newNode.next = top;
        top = newNode;
    }

    public char pop() {
        if (isEmpty()) {
            return '\0';
        }
        char popData = top.data;
        top = top.next;
        return popData;
    }
}

Test code
//
// Advanced Java Programming
// TIEI - Fall 2024
//
package tiei.ajp.test;

import java.util.*;
import tiei.ajp.test.CheckBalance;

/**
 * A TestCheckBalance class for the test
 * YOU MUST NOT CHANGE THIS CLASS!!!
 */
public class TestCheckBalance {
	
	// the expected answers from the user
	private static final String YES = "yes";
	private static final String NO  = "no";

	/**
	 * The main program
	 */
	public static void main(String[] args) {
		Scanner input = new Scanner(System.in);
		System.out.println("Welcome to the Balance Checking Program");
		do {
			System.out.print("\nEnter the string you wish to check: ");
			String theString = input.nextLine();
			CheckBalance check = new CheckBalance(theString);
			if ( check.balanced() )
				System.out.println("The string is balanced!");
			else {
				System.out.println("The string is unbalanced:\n");
				System.out.println(theString);
				System.out.printf("%" + ( check.index() + 2 ) + "s", "^\n");
			}
			System.out.println();
		} while ( more(input) );
	}
	
	// Ask the user for more and return a boolean
	private static boolean more(Scanner input) {
		String answer = null;
		do {
			System.out.print("More ('" + YES + "' or '" + NO + "')? ");
			answer = input.nextLine().trim().toLowerCase();
		} while ( ! answer.equals(YES) && ! answer.equals(NO) );
		return answer.equals(YES);
	}
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

二叉树的层序遍历(含八道leetcode相关题目)

文章目录 二叉树层序遍历模板102. 二叉树的层序遍历107. 二叉树的层序遍历 II199. 二叉树的右视图637. 二叉树的层平均值515. 在每个树行中找最大值429. N 叉树的层序遍历116. 填充每个节点的下一个右侧节点指针117. 填充每个节点的下一个右侧节点指针 II 二叉树层序遍历模板 …

深度学习笔记(8)预训练模型

深度学习笔记&#xff08;8&#xff09;预训练模型 文章目录 深度学习笔记&#xff08;8&#xff09;预训练模型一、预训练模型构建一、微调模型&#xff0c;训练自己的数据1.导入数据集2.数据集处理方法3.完形填空训练 使用分词器将文本转换为模型的输入格式参数 return_tenso…

C++迭代器 iterator详解

目录 什么是迭代器 迭代器的类型 迭代器的用法 三种迭代器 范围for 什么是迭代器 它提供了一种访问容器&#xff08;如列表、集合等&#xff09;中元素的方法&#xff0c;而无需暴露容器的内部表示。迭代器使得程序员能够以统一的方式遍历不同的数据结构&#xff0c;而无需…

项目集成sharding-jdbc

目录 项目集成sharding-jdbc 1.业务分析 2.数据库构建 3.分库分表策略 项目配置默认数据源 一&#xff1a;导入sharding-jdbc依赖 二&#xff1a;在application文件中编写配置 三&#xff1a;注释掉主配置文件中配置的数据源 注意&#xff1a;这里添加了spring.main.allow…

基于51单片机的矿井安全检测系统

基于51单片机的矿井安全检测系统使用51单片机作为系统主控&#xff0c;LCD1602进行显示同时系统集成了ADC0808和烟雾传感器、甲烷传感器&#xff0c;二者结合测量环境烟雾值&#xff0c;同时使用DHT11温湿度传感器获取环境温湿度值&#xff0c;使用L298N驱动风扇&#xff0c;利…

2009考研数学真题解析-数二:

第一题&#xff1a; 解析&#xff1a;先找间断点&#xff1a;分母不能等于0&#xff0c;分母是sinΠx&#xff0c; 因此不难看出间断点是x0&#xff0c;-1&#xff0c;-2&#xff0c;-3。。。。。 接着一个一个来算这些点是什么间断点。 &#xff0c;从x趋于2开始&#xff0c;分…

2024年一区极光优化+分解+深度学习!VMD-PLO-Transformer-GRU多变量时间序列光伏功率预测

2024年一区极光优化分解深度学习&#xff01;VMD-PLO-Transformer-GRU多变量时间序列光伏功率预测 目录 2024年一区极光优化分解深度学习&#xff01;VMD-PLO-Transformer-GRU多变量时间序列光伏功率预测效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.中秋献礼&#…

FiBiNET模型实现推荐算法

1. 项目简介 A031-FiBiNET模型项目是一个基于深度学习的推荐系统算法实现&#xff0c;旨在提升推荐系统的性能和精度。该项目的背景源于当今互联网平台中&#xff0c;推荐算法在电商、社交、内容分发等领域的广泛应用。推荐系统通过分析用户的历史行为和兴趣偏好&#xff0c;预…

小球轻重的测量

设有12个小球。其中11个小球的重量相同&#xff0c;称为好球&#xff1b;有一个小球的重量与11个好球的重量不同&#xff08;或轻或重&#xff09;&#xff0c;称这个小球为坏球。试编写一个算法&#xff0c;用一个无砝码的天平称三次找出这个坏球&#xff0c;并确定其比好球轻…

GAMES101(15节,辐射,BRDF)

Irradiance辐射度量学 辐射度量学在渲染领域&#xff0c;可以帮助理解基于物理的光照模型 radiant energy辐射能量Q&#xff0c;累计总能量&#xff08;单位J joule焦耳&#xff09;&#xff0c;就像太阳能板&#xff0c;光照时间越长接收能量越多&#xff0c;收到的能量总和…

02_RabbitMQ消息丢失解决方案及死信队列

一、数据丢失 第一种&#xff1a;生产者弄丢了数据。生产者将数据发送到 RabbitMQ 的时候&#xff0c;可能数据就在半路给搞丢了&#xff0c;因为网络问题&#xff0c;都有可能。 第二种&#xff1a;RabbitMQ 弄丢了数据。MQ还没有持久化自己挂了。 第三种&#xff1a;消费端…

Attention is All You Need精读

原文开头&#xff0c;不是搬运 dog。All attention is all you need Abstract 摘要 这篇文章的内容源于基于编码器-解码器架构的RNN模型&#xff0c;在其他人的工作中&#xff0c;我们可以发现注意力机制对于提升编码器-解码器架构模型的性能很重要。这篇文章提出了一个比较简…

《代码整洁之道:程序员的职业素养》

作者&#xff1a;【美】Robert C. Martin 第1章 专业主义 专业主义就意味着担当责任&#xff0c;软件开发太复杂了&#xff0c;不可能没什么 bug。但很不幸&#xff0c;这并不能为你开脱。人体太复杂了&#xff0c;不可能尽知其全部&#xff0c;但医生仍要发誓不伤害病人。如…

隐藏excel单元格数据的两个方法

在Excel中&#xff0c;公式是用来计算数据和结果的非常重要的一部分。但是&#xff0c;有时候您可能希望隐藏公式&#xff0c;以保护其不被他人修改或查看。那么今天小编就来给大家分享隐藏excel单元格数据的方法。 一、使用“隐藏”功能 在Excel中&#xff0c;我们还可以使用…

ZYNQ学习--AXI总线协议

一、AXI 总线简介 AXI&#xff08;Advanced Extensible Interface&#xff09;高级拓展总线是AMBA&#xff08;Advanced Microcontroller Bus Architecture&#xff09;高级微控制总线架构中的一个高性能总线协议&#xff0c;由ARM公司开发。AXI总线协议被广泛应用于高带宽、低…

大语言模型超参数调优:开启 AI 潜能的钥匙

前言 在人工智能的广袤领域中&#xff0c;大语言模型&#xff08;LLM&#xff09;凭借其强大的实力&#xff0c;不断重塑着我们对机器理解语言的认知。然而&#xff0c;要使这些模型在特定应用场景中发挥最大效能&#xff0c;关键在于巧妙调整其超参数。本文将引领你深入探究 …

x-cmd pkg | bat: cat 命令现代化替代品,终端用户必备工具

目录 简介快速上手安装使用与第三方工具组合使用 功能特点竞品和相关作品进一步阅读 简介 bat 是由 github.com/sharkdp 用 Rust 开发的 cat 命令现代化替代品。它比 cat 命令扩展了更多的现代化功能&#xff0c;如语法高亮、自动分页、Git集成等&#xff0c;能为用户提供更为…

python如何跨文件调用自己定义的函数

当自己定义函数过多时&#xff0c;只有一个python文件时代码会很长&#xff0c;不易理清代码框架&#xff0c;比如下面这段代码&#xff0c;如何隐藏具体函数细节呢&#xff1f;也就是把def函数放到另外一个python文件里步骤如下&#xff1a; 一个python文件代码篇幅过长 imp…

结构体对齐、函数传参、库移植

结构体字节对齐 按固定位大小匹配地址&#xff0c;a:10b:1020位 <32位4字节 202040位>32位 所以ab20作为一个int型&#xff0c;int c:20 单独做4个字节&#xff08;int&#xff09; 101020 &#xff08;int&#xff09;4个字节 &#xff0c;20&#xff08;int&#x…

算法之逻辑斯蒂回归(Logistic regression)

简介&#xff1a;个人学习分享&#xff0c;如有错误&#xff0c;欢迎批评指正。 逻辑斯蒂回归&#xff08;Logistic Regression&#xff09;是统计学中一种广泛应用于二分类问题的算法。它的主要目标是预测二分类问题中的事件发生的概率。尽管名字里有“回归”&#xff0c;但逻…