查找数组元素相同的最后一组数组的第一个下标

题目

面试过程中,被问到这道面试题,做个记录:

有一组数组x:
x={“11”,”aa”}

要比较的数组y是:
y={“11”,”aa”,“11”,”aa”}
y1={“11”,”aa”,“11”,”res”,”aa”}
y2 = {“11”,”11”,“11”,”aa”}

需求:查找y数组,找出与x数组相同项(相同项可能有多组),找最后一组,并返回最后一组的第一个元素的下标

以上分别返回:
2
0
2


使用OC语言写的代码:

- (void)viewDidLoad {
    [super viewDidLoad];
    
    //测试数组
    NSArray *x = @[@"aa", @"aa", @"11"];
    NSArray *y = @[@"aa", @"aa", @"aa", @"11"];
    //调用
    NSInteger result = [self lastIndexWithArrayX:x andY:y];
    NSLog(@"%d", result);
}

//返回最后一组的下标
- (NSInteger)lastIndexWithArrayX:(NSArray *)x andY:(NSArray *)y
{
    //判断边界条件
    if(x == nil) return 0;
    if(y == nil) return 0;
    
    //定义最后找到的Y值index
    int lastYIndex = 0;
    
    //比较x和y
    int findYIndex = 0;
    for(findYIndex = 0; findYIndex < y.count; findYIndex++){//y
        
        int tempFindYIndex = findYIndex;
        
        for(int j = 0; j < x.count; j++){//x
            if(y[tempFindYIndex] == x[j]){//相等,找下一个
                //边界条件,x找完了
                if(j == x.count - 1){//找下一组
                    lastYIndex = tempFindYIndex;//记录最后一次找到的Y值的index
                    break;
                }
                
                //+1操作
                tempFindYIndex++;
            }else{//不相等,y值从下一个开始,x值从0开始
                break;
            }
        }
    }
    
    if(lastYIndex > 0){
        return lastYIndex - (x.count - 1);
    }else{
        return 0;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值