逆波蘭(算法) OC實(shí)現(xiàn)

新建一個(gè)Stack棧,用來(lái)對(duì)數(shù)組進(jìn)行操作
@interface Stack : NSObject

- (NSInteger)pop;

- (void)push:(NSInteger)number;

- (BOOL)isOperator:(NSString *)str;

@property(nonatomic, strong)NSMutableArray *stack;

@end

@implementation Stack

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

- (NSInteger)pop
{
    if (_stack.count > 0){
        NSInteger lastNumber = ((NSNumber *)(_stack.lastObject)).integerValue;
        [_stack removeLastObject];
        return lastNumber;
    }
    
    return (long)0;
}

- (void)push:(NSInteger)number
{
    [_stack addObject:[[NSNumber alloc]initWithInteger:number]];
}

- (BOOL)isOperator:(NSString *)str{
    
    return [@"+-*/" containsString:str];
}

@end
@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.
    
    //逆波蘭算法
    NSArray *opArray = @[@"10", @"6", @"9", @"3", @"+", @"-11", @"*", @"/", @"*", @"17", @"+", @"5", @"+"];
    
    Stack *stack = [[Stack alloc] init];
    NSInteger result = 0;
    for (NSString *str in opArray)
    {
       if ([stack isOperator:str] == NO)
       {
           [stack push:str.integerValue];
       }else {
           NSInteger leftOperator = result == 0 ? [stack pop] : result;
           NSInteger rightOperator = [stack pop];
           if ([str isEqualToString:@"+"]){
               result = rightOperator+leftOperator;
           }else if ([str isEqualToString:@"-"]){
               result = rightOperator-leftOperator;
           }else if ([str isEqualToString:@"*"]){
               result = rightOperator*leftOperator;
           }else{
               result = rightOperator/leftOperator;
           }
       }
    }
    
    NSLog(@"");
    
    
}
@end
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容