首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Excel公式练习35: 拆分连字符分隔的数字并放置在同一列中

本次的练习是:在单元格区域A1:A6中,有一些数据,有的是单独的数字,有的是由连字符分隔的一组数字,例如13-16表示13、14、15、16,现在需要将这些数据拆分并依次放置在列D中,如下图1所示。...公式解析 公式中的first和last是定义的两个名称。...与上面的原理相同,最后得到的结果为: ={“ 2”;” 6”;”9”;” 11”;” 16”;”21”} 再来看公式中IF语句的第一部分: IF(ROWS($D$1:$D1)>SUM(...因为这两个相加的数组正交,一个6行1列的数组加上一个1行4列的数组,结果是一个6行4列的数组,有24个值。...例如对于上面数组中的第4行{10,11,12,13},在last数组中对应的值是11,因此剔除12和13,只保留10和11。

3.7K10

在排序数组中查找元素的第一个和最后一个位置

在排序数组中查找元素的第一个和最后一个位置 给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。...接下来,在去寻找左边界,和右边界了。 采用二分法来去寻找左右边界,为了让代码清晰,我分别写两个二分来寻找左边界和右边界。...刚刚接触二分搜索的同学不建议上来就像如果用一个二分来查找左右边界,很容易把自己绕进去,建议扎扎实实的写两个二分分别找左边界和右边界 寻找右边界 先来寻找右边界,至于二分查找,如果看过704.二分查找就会知道...nums 数组中二分查找得到第一个大于等于 target的下标(左边界)与第一个大于target的下标(右边界); # 2、如果左边界第一个大于等于 target的下标leftBorder; # 2、在 nums 数组中二分查找得到第一个大于等于 target+1的下标, 减1则得到rightBorder;

4.7K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    在排序数组中查找元素的第一个和最后一个位置

    在排序数组中查找元素的第一个和最后一个位置 给你一个按照非递减顺序排列的整数数组 nums,和一个目标值 target。请你找出给定目标值在数组中的开始位置和结束位置。...如果数组中不存在目标值 target,返回 [-1, -1]。 你必须设计并实现时间复杂度为 O(log n) 的算法解决此问题。...我们将这道题拆解成两个部分,第一部分就是求该元素的左端点,另一部分就是求该元素的右端点。其实这两部分是大同小异,只要弄懂其中一个,另一个就迎刃而解! 我们首先来讲第一部分——求该元素的左端点。...第一步将这些数据分为两个部分:小于元素和大于等于该元素这两个部分。 第二步就是普通二分算法的代码 注意这里有一个细节,跟普通二分查找算法不同,也是后面细节的“万恶之源”。...总结:只要左式和右式的操作数不一样,中点就偏向哪边!!!

    10410

    matlab—基本操作与矩阵输入

    >>A(8) = 9,编号是按照一列一列数下来,在向量A中,“21”对应的编号是4 >>A([1 3 5]) = 1 31 17 >>A([1 3;1 3]) =  >>A(3,2) = 2,以逗号隔开的两个数字...,前面表示行,后面表示列 >>A([1 3],[1 3]) = ,前面的[1 3]表示,第一行和第三行,后面的[1 3]表示第一列和第三列 3.2.1 替换矩阵值 方法:A() = [],等号左边是索引...(n1,n2):n1×n2的矩阵,矩阵内元素全部为1 diag([x1 x2 x3]):主对角线为x1,x2,x3的矩阵 linspace(a,b,n):生成一个1×n的矩阵,第一个元素值为a,最后一个元素值为...(A)) = 9(max外面嵌套一个max的作用是求出矩阵所有元素中的最大值) min(A)= 0 0 3(min函数的作用是求出矩阵每一列中的最小值) min(min(A)) = 0(min外面嵌套一个...min的作用是求出矩阵所有元素中的最小值) sum(A) = 8 7 18(sun函数的作用是计算矩阵每一列的和) sum(sum(A)) = 33(sum外面嵌套一个sum的作用是求出矩阵内所有元素的和

    1.2K10

    Excel公式技巧23: 同时定位字符串中的第一个和最后一个数字

    在很多情况下,我们都面临着需要确定字符串中第一个和最后一个数字的位置的问题,这可能是为了提取包围在这两个边界内的子字符串。...本文寻找的是如何通过确定字符串中的第一个和最后一个数字来提取出子字符串的一种通用解决方案,而不管分隔符是什么、有多少,并且不需要执行替换操作。...construction]由两个单独的子句进行减法运算,其中一个是字符串内第一个数字的位置,另一个是最后一个数字的位置。...我们首先查看一些确定字符串中最后一个数字的位置的公式结构,然后查看其中的哪一个(如果有的话)也可能有助于发现第一个数字的位置,这可能会很有用。...和25分别代表字符串中第一个和最后一个数字的位置。

    2.8K10

    数学建模--层次分析法~~深入解读

    ; 2.模型的建立和求解 (1)数量级的统一 我们只看这个粉丝的数量,这个罗翔老师的粉丝的数量是最多的,我们进行相关的处理之后需要保证这个罗翔老师的粉丝的数量仍旧是第一名; (2)归一化处理 就是按这个对应的数值除以这一列相关数值的相加求和...,含义就是一个因素相较于另外一个因素的重要性,例如这个我们觉得粉丝数量比稿件的数量明显重要,我们就在以粉丝数量作为横坐标,以稿件的数量作为纵坐标的位置填写上数字5,在关于这个矩阵的主对角线的对称位置我们就是填写的他的倒数...: 上面的这个过程可能会有一些繁琐,我下面放了一张图,方便大家理解: 3.matlab代码求解 (1)上面我们介绍的进行这个一致性检验的时候,需要求借这个判断矩阵的最大特征值,再matlab里面有一个函数可以帮助我们直接进行求解...,再去根据这个一致性检验的公式运算,符合一致性检验之后,按照列求和,算出这一列的每一列数据在这一列的权重,在按照行求解平均值,得到权重(科学的,相对客观的); 在带入这个最原始的数据,在单位统一的情况下还是求解数据在这一列的权重...,在按照行求解平均值,让这个向量和权重向量做乘法,得到最后的评分; (6)matlab代码 clc,clear % 输入判断矩阵 A = [1 2 3 5 1/2 1 1/2 2 1/

    10810

    Matlab入门(一)

    函数在运算时是将函数逐项作用于矩阵的每个元素上,所以最后运算的结果就是一个与自变量同型的矩阵。...变量与赋值语句 变量本质上讲是内存单元的一个抽象 在Matlab中,变量名是以字母开头,后接字母、数字或下划线的字母序列,最多63个字符。...5.矩阵元素的引用 1 通过下标来引用矩阵的元素 2 通过序号来引用:在MATLAB中,矩阵元素按列存储,即首先存储矩阵的第一列元素,然后存储第二列元 素,一直到矩阵的最后一列元素。...reshape (A,m,n) 注意:reshape函数只是改变原矩阵的行数和列数,但并不改变原矩阵元素个数及其存储顺序。 A(:)将矩阵A的每一列元素堆叠起来成为一个列向量。...(在点除的时候需要保证矩阵形式相同) .\ (右点除) : A.\3 %3除以A中对应元素 A.\ B%用每一个元素分别对应除以矩阵中的元素。 .

    21210

    Leetcode No.34 在排序数组中查找元素的第一个和最后一个位置

    一、题目描述 给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。 如果数组中不存在目标值 target,返回 [-1, -1]。...-109 <= target <= 109 二、解题思路 使用二分法查找第一个位置,初始化两个变量low=0,hight=nums.length-1 1、当low>high时,表示没有找到,返回-1...nums[mid]时,说明目标值在左侧,往左侧递归查找,否则往右侧递归查找 查找最后一个位置同理,唯一不同的是第4、5步 4、假如nums[mid]等于target且nums[mid]比相邻的右侧元素小...mid-1]<nums[mid])){ return mid; } if(target<=nums[mid]){ //寻找第一个位置...mid]<nums[mid+1]){ return mid; } if(target>=nums[mid]){ //寻找最后一个位置

    1.9K10

    leetcode34-在排序数组中查找元素的第一个和最后一个位置

    前言 今天刷的题目是:在排序数组中查找元素的第一个和最后一个位置,这道题目在最开始AC以后,然后做了两步的优化操作,供大家参考。...题目 leetcode-34:在排序数组中查找元素的第一个和最后一个位置 分类(tag):二分查找这一类 英文链接:https://leetcode.com/problems/find-first-and-last-position-of-element-in-sorted-array...nums,和一个目标值 target。...找出给定目标值在数组中的开始位置和结束位置。 你的算法时间复杂度必须是 O(log n) 级别。 如果数组中不存在目标值,返回 [-1, -1]。...-1,如果不是-1,那说明需要继续找最右边的下标,如果是-1的话,那么说明数组中没有target的值,所以我们也不必在去找最右边的下标了,因为已经找过了,不存在的,还费这事干嘛,最终这样优化完速度快了1ms

    2.6K30

    LeetCode-34-在排序数组中查找元素的第一个和最后一个位置

    # LeetCode-34-在排序数组中查找元素的第一个和最后一个位置 给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。...5,7,7,8,8,10], target = 6 输出: [-1,-1] # 解题思路 方法1、双指针暴力法(low): 特例判断: 当数组为空或数组长度为0时,直接返回[-1,1] 当数组长度为1时,判断第一个数字是否等于...target,等于则返回[0,0],否则返回[-1,-1] 初始化头尾指针 移动头指针,直到找到第一个等于target的位置,如果找完了都没有找到,返回[-1,-1] 移动尾指针,直到找到最后一个等于target...时,说明target在mid左方,end = mid-1 当nums[mid]==target时,说明左右边界有一个地方等于target,这时候只需要查找另外一个边界等于target的即可,可以进行循环移动查找...,最后返回[start,end]即可 如果没有找到,返回[-1,-1] 方法3、递归分治(low): 通过二分查找切分数组寻找左右子数组的target位置,迭代到只有一个,判断是否是目标值,返回一个都是当前

    2.3K20

    在排序数组中查找元素的第一个和最后一个位置(leetcode34)

    给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。 如果数组中不存在目标值 target,返回 [-1, -1]。...示例 1: 输入:nums = [5,7,7,8,8,10], target = 8 输出:[3,4] 解析: 方法一:二分查找 二分查找中,寻找leftIdx 即为在数组中寻找第一个大于等于 target...的下标,寻找 rightIdx 即为在数组中寻找第一个大于target 的下标,然后将下标减一。...两者的判断条件不同,为了代码的复用,我们定义 binarySearch(nums, target, lower) 表示在 nums 数组中二分查找 target 的位置,如果 lower 为 true,...则查找第一个大于等于 target 的下标,否则查找第一个大于target 的下标。

    1.8K10

    在排序数组中查找元素的第一个和最后一个位置--题解

    在排序数组中查找元素的第一个和最后一个位置 给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。...如果数组中不存在目标值 target,返回 [-1, -1]。 进阶: 你可以设计并实现时间复杂度为 O(log n) 的算法解决此问题吗?...示例 3: 输入:nums = [], target = 0 输出:[-1,-1] 提示: 0 <= nums.length <= 105 -109 <= nums[i] <= 109 nums 是一个非递减数组...mid - 1 } else if nums[mid] == target { end = mid } else { start = mid + 1 } } //此处防止数组第一个数是...target int) int { start, end := 0, len(nums)-1 for start < end { //此处注意,为了防止 start=mid的问题

    1.9K30

    LeetCode题目34:在排序数组中查找元素的第一个和最后一个位置

    原题描述 + 给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。 你的算法时间复杂度必须是 O(log n) 级别。...如果数组中不存在目标值,返回 [-1, -1]。...普通的二分查找在找到target后立即返回,所以我们需要做变式,情况分为以下两种。 寻找左边界 还是得举个例子。...因为lower的左边不是target,而higher也一直在尽可能的往左挪动。 寻找右边界 与上面过程相反,我们尽可能向右挪动lower,让其与higher相撞即可。...但如果复用上面的逻辑,每次挪动时令lower=mid+1,那么最终lower一定会与higher相撞于最后一个target的后一个位置。此时lower-1才是所求。

    3.1K20

    在排序数组中查找元素的第一个和最后一个位置

    前言 今天主要讲解的内容是:如何在已排序的数组中查找元素的第一个和最后一个位置。以 leetcode 34 题作为例题,提供二分查找的解题思路,供大家参考。...题目详述 给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。 如果数组中不存在目标值 target,返回 [-1, -1]。...1),不断向 mid 的左侧收缩,最后达到锁定左边界(元素的第一个位置)的目的; 如何查找元素的最后一个位置?...同查找元素的第一个位置类似,在查找到数组中某元素值等于目标值 target 时,不立即返回,通过增大查找区间的下边界 low (令 low = mid + 1),不断向 mid 的右侧收缩,最后达到锁定右边界...举栗 以 nums = [5,7,7,8,8,10], target = 8 为栗子,通过下图来找出目标值 8 在数组中出现的第一个和最后一个位置。

    2.6K20

    原 初学数模-MATLAB Quick S

    其实,这个矩阵被叫做Magic Square,是因为他的每行每列、主对角线和副对角线数字之和全部相等,且都是(1+16)*2=34。     ...3.翻转函数fliplr:将矩阵的第一列与最后一列交换、第二列与倒数第二列交换……篇幅所限,这里就不再演示fliplr(A)了~ 4.对角阵diag:取主对角线元素,作为一个向量。         ...在MATLAB中,你可以通过三种方法来获得一个矩阵:             1.手动输入             2.在mat文件中读取             3.通过MATLAB函数(除了自带的函数...生成     其中,最常用的就是第一种和第三种了。     而MATLAB也有许多有用的矩阵构造函数,如:zeros、ones、rand、randn、perms等。     ...如果你让一个非零值除以0,或者得到数值大于matlab允许的最大值(大约为10^308),MATLAB很可能会返回给你一个Inf。

    1.6K90
    领券