news 2026/4/23 17:13:03

(100分)- 表达式括号匹配(Java JS Python C)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
(100分)- 表达式括号匹配(Java JS Python C)

(100分)- 表达式括号匹配(Java & JS & Python & C)

题目描述

(1+(2+3)*(3+(8+0))+1-2)这是一个简单的数学表达式,今天不是计算它的值,而是比较它的括号匹配是否正确。

前面这个式子可以简化为(()(()))这样的括号我们认为它是匹配正确的,

而((())这样的我们就说他是错误的。注意括号里面的表达式可能是错的,也可能有多个空格,对于这些我们是不用去管的,

我们只关心括号是否使用正确。

输入描述

给出一行表达式(长度不超过 100)。

输出描述

如果匹配正确输出括号的对数,否则输出-1。

用例
输入(1+(2+3)*(3+(8+0))+1-2)
输出4
说明
题目解析

本题就是括号匹配的变种题,只是加入了一些干扰字符,我们可以用正则去掉非()的字符,然后利用栈结构校验括号是否成对

JavaScript算法源码
/* JavaScript Node ACM模式 控制台输入获取 */ const readline = require("readline"); const rl = readline.createInterface({ input: process.stdin, output: process.stdout, }); rl.on("line", (line) => { let count = 0; const stack = []; for (let c of line) { if (c != "(" && c != ")") continue; if (stack.length && c === ")") { if (stack.at(-1) === "(") { stack.pop(); count++; continue; } else { return console.log(-1); } } stack.push(c); } if (stack.length) return console.log(-1); return console.log(count); });
Java算法源码
import java.util.LinkedList; import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); String s = sc.nextLine(); System.out.println(getResult(s)); } public static int getResult(String s) { int count = 0; LinkedList<Character> stack = new LinkedList<>(); for (int i = 0; i < s.length(); i++) { char c = s.charAt(i); if (c != ')' && c != '(') continue; if (stack.size() > 0 && c == ')') { if (stack.getLast() == '(') { stack.removeLast(); count++; continue; } return -1; } stack.add(c); } if (stack.size() > 0) return -1; return count; } }
Python算法源码
# 输入获取 s = input() # 算法入口 def getResult(s): count = 0 stack = [] for c in s: if c != '(' and c != ')': continue if len(stack) > 0 and c == ')': if stack[-1] == '(': stack.pop() count += 1 continue return -1 stack.append(c) if len(stack) > 0: return -1 return count # 算法调用 print(getResult(s))
C算法源码
#include <stdio.h> #include <stdlib.h> #include <string.h> typedef char E; typedef struct ListNode { E ele; struct ListNode *prev; struct ListNode *next; } ListNode; typedef struct { int size; ListNode *head; ListNode *tail; } LinkedList; LinkedList *new_LinkedList(); void addLast_LinkedList(LinkedList *link, E ele); E removeLast_LinkedList(LinkedList *link); E getLast_LinkedList(LinkedList* link); int main() { char s[100]; gets(s); int count = 0; LinkedList *stack = new_LinkedList(); for (int i = 0; i < strlen(s); i++) { if(s[i] != ')' && s[i] != '(') continue; if(stack->size > 0 && s[i] == ')') { if(getLast_LinkedList(stack) == '(') { removeLast_LinkedList(stack); count++; continue; } puts("-1"); return 0; } addLast_LinkedList(stack,s[i]); } if(stack->size > 0) { puts("-1"); } else { printf("%d\n", count); } return 0; } LinkedList *new_LinkedList() { LinkedList *link = (LinkedList *) malloc(sizeof(LinkedList)); link->size = 0; link->head = NULL; link->tail = NULL; return link; } void addLast_LinkedList(LinkedList *link, E ele) { ListNode *node = (ListNode *) malloc(sizeof(ListNode)); node->ele = ele; node->prev = NULL; node->next = NULL; if (link->size == 0) { link->head = node; link->tail = node; } else { link->tail->next = node; node->prev = link->tail; link->tail = node; } link->size++; } E removeLast_LinkedList(LinkedList *link) { if (link->size == 0) exit(-1); ListNode *removed = link->tail; if (link->size == 1) { link->head = NULL; link->tail = NULL; } else { link->tail = link->tail->prev; link->tail->next = NULL; } link->size--; E res = removed->ele; free(removed); return res; } E getLast_LinkedList(LinkedList* link) { if(link->size == 0) exit(-1); return link->tail->ele; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 14:44:14

AI原生开发范式

AI原生开发范式的核心概念 AI原生开发范式&#xff08;AI-Native Development&#xff09;指以AI为核心构建应用程序的设计方法&#xff0c;其特点包括数据驱动、模型即服务&#xff08;MaaS&#xff09;、自动化工作流和持续学习。与传统开发相比&#xff0c;AI原生应用将机器…

作者头像 李华
网站建设 2026/4/23 13:02:27

鸿蒙破晓:一场技术与人才突围的生态远征

转载自&#xff1a;万能的大熊2025年末的深圳夜空被电子屏幕点亮&#xff0c;华为旗舰店内陈列的Mate 80 Pro max超透亮灵珑屏上&#xff0c;HarmonyOS 6系统正流畅运行微信鸿蒙版的原相机调用功能&#xff0c;指尖轻触可实现夜景照片的毫秒级处理&#xff1b;展区另一侧的折叠…

作者头像 李华
网站建设 2026/4/23 12:12:32

当一部手机定价近两万:三星三折叠价格和功能如何匹配?

在高端智能手机市场&#xff0c;每当价格标签触及五位数&#xff0c;总会引发一场关于价值对等的辩论。近日&#xff0c;三星一款新形态折叠屏手机上市的信息&#xff0c;再次将这一话题推向焦点。512GB版本19999.00元&#xff0c;1TB版本21999.00元&#xff0c;面对这样的标价…

作者头像 李华
网站建设 2026/4/23 12:22:26

三星最新款手机推荐:Galaxy Z TriFold三折叠形态的体验革命

“一款手机能当工作站与创作台&#xff1f;三星最新三折叠旗舰给出新答案&#xff01;”三星Galaxy Z TriFold作为最新旗舰&#xff0c;以三折叠设计重构移动设备体验&#xff0c;成为高端用户的焦点之选。本文从技术革新、场景适配等维度&#xff0c;深度解析这款机型的核心价…

作者头像 李华
网站建设 2026/4/23 10:44:52

一文读懂大模型微调:从全参数到LoRA,打造你的专属AI专家

本文详细介绍了三种大模型适配技术&#xff1a;全参数微调&#xff08;性能最佳但资源消耗大&#xff09;、LoRA微调&#xff08;轻量高效&#xff09;和RAG&#xff08;通过外部知识库增强&#xff09;。针对不同场景提供技术选型指南&#xff0c;强调没有"最优解"只…

作者头像 李华