leetcode 2125.银行中的激光束数量

1.题目要求:

银行内部的防盗安全装置已经激活。给你一个下标从 0 开始的二进制字符串数组 bank ,表示银行的平面图,这是一个大小为 m x n 的二维矩阵。 bank[i] 表示第 i 行的设备分布,由若干 '0' 和若干 '1' 组成。'0' 表示单元格是空的,而 '1' 表示单元格有一个安全设备。

对任意两个安全设备而言,如果同时 满足下面两个条件,则二者之间存在 一个 激光束:

两个设备位于两个 不同行 :r1 和 r2 ,其中 r1 < r2 。
满足 r1 < i < r2 的 所有 行 i ,都 没有安全设备 。
激光束是独立的,也就是说,一个激光束既不会干扰另一个激光束,也不会与另一个激光束合并成一束。

返回银行中激光束的总数量。

在这里插入图片描述

void one_count(char* string,int* number,int*length){
    int count = 0;
    for(int i = 0;i < strlen(string);i++){
        if(string[i] == '1'){
            count++;
        }
    }
    if(count == 0){
        return;
    }else{
        number[(*length)++] = count;
        return;
    }
}
int numberOfBeams(char ** bank, int bankSize){
    int* number = (int*)malloc(sizeof(int) * bankSize);
    int* length = (int*)malloc(sizeof(int));
    *length = 0;
    for(int i = 0;i < bankSize;i++){
        one_count(bank[i],number,length);
    }
    if(*length == 1)
        return 0;
    else{
        int sum = 0;
        for(int i = 0;i < *length - 1;i++){
            sum += (number[i] * number[i + 1]);
        }
        return sum;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值