力扣题目学习笔记(OC + Swift)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

相关推荐

  1. 题目学习笔记(OC + Swift)20. 有效括号

    2023-12-24 18:50:04       40 阅读
  2. | 20. 有效括号

    2023-12-24 18:50:04       38 阅读
  3. 100】20.有效括号 || 栈

    2023-12-24 18:50:04       42 阅读
  4. 刷题练习】20. 有效括号

    2023-12-24 18:50:04       33 阅读
  5. 刷题之20.有效括号

    2023-12-24 18:50:04       18 阅读
  6. 【数据结构与算法】 20. 有效括号

    2023-12-24 18:50:04       10 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-24 18:50:04       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-24 18:50:04       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-24 18:50:04       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-24 18:50:04       20 阅读

热门阅读

  1. 【Kafka每日一问】kafka三种压缩方式差别?

    2023-12-24 18:50:04       30 阅读
  2. oracle 触发器 怎么返回处理错误到客户端

    2023-12-24 18:50:04       39 阅读
  3. MySQL数据的备份与恢复

    2023-12-24 18:50:04       34 阅读
  4. Mysql sql_mode参数配置

    2023-12-24 18:50:04       38 阅读
  5. sql server多表查询

    2023-12-24 18:50:04       39 阅读
  6. 9.9算法

    2023-12-24 18:50:04       32 阅读
  7. 力扣(leetcode)13和14题(Python)

    2023-12-24 18:50:04       41 阅读
  8. 在C#中使用OpenCV获取图像的轮廓

    2023-12-24 18:50:04       42 阅读
  9. 文盘Rust -- 本地库引发的依赖冲突

    2023-12-24 18:50:04       44 阅读
  10. 内网穿透之FRP

    2023-12-24 18:50:04       38 阅读