新浪笔试编程题二

  Java源文件source.java中含有“()”“{}”“[]”三种括号

1)  实现方法判断文件中括号是否正确匹配

2)  在此基础上,若不匹配输出行号和不匹配的括号类型。

思路:使用stack进行存储,若为右侧括号则入栈,若为左侧括号则出栈,并判断是否为一对相匹配括号,若匹配则继续直到将java源文件读取完毕,若不匹配则停止判断并输出判断结果

问题2在1的基础上增加一些代码即可,代码如下

public boolean isTrue(String filepath) throws IOException{
boolean flag = true;
File f = new File(filepath);
BufferedReader br = new BufferedReader(new FileReader(f));

String temp = "";
Stack<Character> stack = new Stack<>();
Lable:
while((temp = br.readLine())!=null){
for(int i = 0;i<temp.length();i++){
char ch = temp.charAt(i);
if (ch=='('||ch=='{'||ch=='[') {
stack.push(ch);
}
else if(ch==')'||ch=='}'||ch==']'){
if (stack.size()==0) {
flag = false;
break Lable;
}else{
char top = stack.pop();
if (top!=ch) {
flag = false;
break Lable;
}
}
}
}
}

return flag;
}
public boolean isTrue2(String filepath) throws IOException{
boolean flag = true;
File f = new File(filepath);
BufferedReader br = new BufferedReader(new FileReader(f));
int line  = 0;
String temp = "";
char ch = '0';
Stack<Character> stack = new Stack<>();
Lable:
while((temp = br.readLine())!=null){
line++;
for(int i = 0;i<temp.length();i++){
ch = temp.charAt(i);
if (ch=='('||ch=='{'||ch=='[') {
stack.push(ch);
}
else if(ch==')'||ch=='}'||ch==']'){
if (stack.size()==0) {
flag = false;
break Lable;
}else{
char top = stack.pop();
if (top!=ch) {
flag = false;

break Lable;
}
}
}
}
}

if (flag) {
System.out.println("全部匹配");
}else{
System.out.println("不匹配的行号为:"+line+",不匹配的括号为:"+ch);
}
return flag;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值