当前位置: 首页 > news >正文

(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; }
http://www.gsyq.cn/news/132155.html

相关文章:

  • 非线性最优化问题求解器Ipopt介绍
  • NPM2100 电池电量估算
  • java计算机毕业设计网络探店 基于大数据的美食探店可视化平台 互联网餐饮探店数据爬取与分析系统
  • Windows系统文件inetcomm.dll丢失损坏 下载修复方法
  • linux centos7.9 中文乱码
  • springcloud springboot nacos版本对应 - 指南
  • java计算机毕业设计网络流行语资源库建设及实现 网络热词共享与语义标注平台 互联网流行语知识图谱与检索系统
  • NPM2100 可控的gpio
  • .NET 文件操作中常见的内存泄漏场景梳理
  • Qt 信号槽机制的一些实现细节
  • 【读书笔记】《苏格拉底的申辩》
  • 毕业季必看!7款免费AI写论文神器实测,一站式搞定选题、大纲到降重
  • 别慌!AI淘汰的不是人,是不会用AI的人
  • 【人工智能AI安全与对齐】
  • C++按索引同时删除vector中的多个元素
  • 5.string类型
  • 8个AI论文工具,MBA轻松搞定研究论文!
  • Windows系统文件hcproviders.dll丢失或损坏 下载修复方法
  • Thinkphp和Laravel手工艺品商城交流与买卖平台vue
  • 4.常用数据结构和单线程模型理解
  • 【学习笔记】后量子密码迁移科技研究
  • 大模型微调完整学习路线,附20天到4个月详细规划_零基础入门人工智能(AI)大模型微调!
  • python作业4
  • 从高频政策热词看经济“新风口”与资本流向
  • 边缘AI与端云协同架构
  • Flutter 实现一个容器内部元素可平移、缩放和旋转等功能(六)
  • 2025年度开发趋势有感
  • 链动2+1模式、AI智能名片与S2B2C商城小程序在直播营销中的规范化应用研究
  • 华为OD机试(机考) - 机器人搬砖 (C++ Python JAVA JS GO)
  • 人工智能之数学基础 微积分:第三章 基本法则