最大公共子字符串


//
//  main.m
//  最大公共子字符串
//
//  Created by SUN on 16/7/31.
//  Copyright © 2016年 VitoSun. All rights reserved.
//

#import <Foundation/Foundation.h>

int main(int argc, const char * argv[]) {
    @autoreleasepool {
        NSString *str1 = @"zqyerwre";
        NSString *str2 = @"zeqwse";
        
        NSString *temp = [NSString string];
        
        NSMutableArray *mArray = [NSMutableArray array];
        
        //找出所有公共字符串
        for (int i = 0; i<str1.length; i++) {
            for (int k = 0; k<str1.length+1-i; k++) {
                temp = [str1 substringWithRange:NSMakeRange(k, i)];
                if([str2 containsString:temp]){
                    [mArray addObject:temp];
                }
            }
        }
        
        int i = (int)mArray.count-1;
        NSString *max = mArray[i];
        //从后向前,若长度不等,结束循环
        while([mArray[i] length]==[mArray[i-1] length]){
            if([mArray[i-1] compare:max]==NSOrderedDescending){
                max = mArray[i-1];
            }
            if(--i ==0){
                break;
            }
        }
        NSLog(@"%@",mArray);
        
        NSLog(@"%@",max);
    }
    return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值