LeetCode 20. 有效的括号

20. 有效的括号

给定一个只包括 ‘(’,‘)’,‘{’,‘}’,‘[’,‘]’ 的字符串 s ,判断字符串是否有效。
有效字符串需满足:
左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
每个右括号都有一个对应的相同类型的左括号。

方法一 栈+hash表

配对的问题首先想到的是用栈来解决,但是如何巧妙的使用hash表刚开始没想到,用的是if判断。
由于要配对,考虑以下几种情况:
1.数据自身不成对,奇数个时结果必然无法配对
2.按顺序入栈,配对到出栈,最后栈为空即为所有配对完成

Swift

func isValid(_ s: String) -> Bool {
        //为奇数则不可能配对,直接返回
        if s.count % 2 != 0 {
            return false
        }
        
        let hashTable:[Character : Character] = [
            "}" : "{",
            ")" : "(",
            "]" : "["
        ]
        
        //create stack
        let stack = Stack()
        
        for char in s {
            if hashTable.keys.contains(char) {
                if stack.top() == hashTable[char] {
                    let _ = stack.pop()
                    continue
                }else {
                    return false
                }
            }
            
            stack.push(char)
        }
        
        
        let result = stack.count() == 0 ? true : false
        return result
    }

其中栈代码如下:

class Stack {
    private var items = [Character]()
    
    func push(_ chara: Character) {
        items.append(chara)
    }
    
    func pop() -> Character? {
        if items.count <= 0 {
            return nil
        }
        
        let res = items.last
        items.removeLast()
        return res
    }
    
    func top() -> Character? {
        return items.last
    }

    func count() -> Int {
        return items.count
    }
}

OC

-(BOOL)isValid:(NSString *)s {
    
    if (s.length % 2 != 0) {
        return NO;
    }
    
    NSDictionary *hashTable = @{
        @")" : @"(",
        @"}" : @"{",
        @"]" : @"["
    };
    
    Stack *stack = [Stack new];
    
    for (NSInteger i=0; i<s.length; i++) {
        unichar chara = [s characterAtIndex:i];
        NSString *s = [[NSString alloc] initWithCharacters:&chara length:1];
        
        if ([hashTable.allKeys containsObject:s]) {
            if ([stack.top isEqualToString:hashTable[s]]) {
                [stack pop];
                continue;
            }else {
                return NO;
            }
        }
        
        [stack push:s];
    }
    return stack.count == 0 ? YES : NO;
}

实现栈结构的OC代码:


@interface Stack<T> : NSObject

- (void)push:(T)item;
- (T)pop;
- (T)top;
-(NSInteger)count;

@end

//------------------------------------------

@implementation Stack

- (instancetype)init {
    if (self = [super init]) {
        _items = [[NSMutableArray alloc] init];
    }
    return self;
}


- (void)push:(id)item {
    [self.items addObject:item];
}

- (id)pop {
    id last = _items.lastObject;
    [self.items removeLastObject];
    return last;
}

- (id)top {
    return _items.lastObject;
}


-(NSInteger)count {
    return self.items.count;
}

@end

  • 8
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Jarlen John

谢谢你给我一杯咖啡的温暖

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值