标签:Excel公式,INDEX函数,MATCH函数 有时候,工作表行中的数据可能并不在第1个单元格,而我们可能会要获得行中第一个非空单元格中的数据,如下图1所示。...图1 可以使用INDEX函数/MATCH函数的组合来解决这个问题,如果找不到的话,再加上IFERROR函数来进行错误处理。...在单元格H4中输入公式: =IFERROR(INDEX(C4:G4,0,MATCH("*",C4:G4,0)),"空") 然后向下拖拉复制公式至数据单元格末尾。...公式中,使用通配符“*”来匹配第一个找到的文本,第二个参数C4:G4指定查找的单元格区域,第三个参数零(0)表示精确匹配。 最后,IFERROR函数在找不到单元格时,指定返回的值。...这里没有使用很复杂的公式,也没有使用数组公式,只是使用了常用的INDEX函数和MATCH函数组合来解决。公式很简单,只是要想到使用通配符(“*”)来匹配文本。
现在我想在单元格B3至F3中使用公式来获取分数,其中单元格B3中是G3:L3中的第1个分数值,即G3中的值45;C3中是第2个分数,即H3中的值44,依此类推。如何编写这个公式? ?...图1 (注:这也是在chandoo.org论坛上看到的一个案例,整理在此与大家分享。) A:使用INDEX/SMALL/IF函数组合来解决。...row_num个元素,即G3中的值,结果为: 45 当公式向右拖时,COLUMN()-COLUMN($A$1)的值递增,这样会依次取数组{7,8,9,FALSE,11,12}中第2、3、4、5小的值,传递给...INDEX函数后分别取单元格H3、I3、K3、L3中的值。...也可以省略INDEX函数的参数row_num,此时的公式为: =INDEX($A$3:$L$3,,SMALL(IF($G3:$L3"",COLUMN($G3:$L3)),COLUMN()-COLUMN
2023-04-16:给定一个长度为N的数组,值一定在0~N-1范围,且每个值不重复比如,arr = 4, 2, 0, 3, 10 1 2 3 4把0想象成洞,任何非0数字都可以来到这个洞里,然后在原本的位置留下洞比如...返回变成任何一种有序的情况都可以,最少的数字搬动次数。来自谷歌。...对于第二种有序情况,我们可以先倒序遍历数组,找出每个数需要移动的最小距离,从而计算出需要移动的次数。最后比较这两种情况下的最小搬动次数,返回较小值即可。...数字只能搬家到洞里,并且走后留下洞,因此在交换过程中需要记录其中一个数字所在的位置作为洞的位置。...这种样子,至少交换几次// ans2 : 1 2 3 4 .... 0 这种样子,至少交换几次// m : 每个环里有几个数// next : 往下跳的位置n := len(nums)ans1, ans2
2025-01-14:K 秒后第 N 个元素的值。用go语言,给定两个整数 n 和 k,我们开始时有一个长度为 n 的整数数组 a,其中每个元素均为 1。...3. pow 函数用来计算 x 的 n 次方的结果,并且对 mod 取模。这个函数会在计算逆元的过程中使用。 4. valueAfterKSeconds 函数用来计算经过 k 秒后第 n 个元素的值。...首先计算出当前数组的值,然后按照规则更新数组 n+k-1 次,最终返回 a[n-1] 的值对 mod 取模的结果。...• 在 valueAfterKSeconds 函数中,计算 a[n-1] 的时间复杂度为 O(n),所以总的时间复杂度为 O(n)。...• 在 valueAfterKSeconds 函数中,除了常数项外并没有额外的空间占用,复杂度为 O(1)。 综上,总的时间复杂度为 O(n),总的额外空间复杂度为 O(n)。
2021-07-27:给定一个数组arr,长度为N,arr中的值只有1,2,3三种。...arri == 1,代表汉诺塔问题中,从上往下第i个圆盘目前在左;arri == 2,代表汉诺塔问题中,从上往下第i个圆盘目前在中;arri == 3,代表汉诺塔问题中,从上往下第i个圆盘目前在右。...那么arr整体就代表汉诺塔游戏过程中的一个状况。如果这个状况不是汉诺塔最优解运动过程中的状况,返回-1。如果这个状况是汉诺塔最优解运动过程中的状况,返回它是第几个状况。...福大大 答案2021-07-27: 1-7的汉诺塔问题。 1-6左→中。 7左→右。 1-6中→右。 单决策递归。 k层汉诺塔问题,是2的k次方-1步。 时间复杂度:O(N)。...to 另一个是啥?
2023-04-16:给定一个长度为N的数组,值一定在0~N-1范围,且每个值不重复 比如,arr = [4, 2, 0, 3, 1] 0 1 2 3 4 把0想象成洞...对于第一种有序情况,我们可以模拟交换排序的过程,算出需要交换的次数,具体实现见函数sortArray()。 2....对于第二种有序情况,我们可以先倒序遍历数组,找出每个数需要移动的最小距离,从而计算出需要移动的次数。 3. 最后比较这两种情况下的最小搬动次数,返回较小值即可。 注意事项: 1....数字只能搬家到洞里,并且走后留下洞,因此在交换过程中需要记录其中一个数字所在的位置作为洞的位置。...这种样子,至少交换几次 // ans2 : 1 2 3 4 .... 0 这种样子,至少交换几次 // m : 每个环里有几个数 // next : 往下跳的位置 n := len(nums
在《算法导论》第一部分练习中,有这样一道算法题: 1.2-3 对于一个运行时间为100n*n的算法,要使其在同一台机器上,在比一个运行时间为2^n的算法运行的很快,n的最小值是多少?...下面给出我自己的解题思路: 对于100n^2和2^n两个算法进行比较,我们可以这样做:对100n^2-2^n操作,如果结果小于0,那么此时的n就是我们所求的值。...100n^2的算法,要使其在同一台机器上,比一个运行时间为2^n的算 8 * 法运行得更快,n的最小值是多少?...2和2^n两个算法进行比较,我们可以这样做:对100n^2-2^n操作,如果结果小于0,那么此时的n就是我们所求的值。...21 * java中求一个数的n次方,方法为Math.pow(x,y);即x的y次方 22 */ 23 public static void getSum() { 24
2024-12-11:数组最后一个元素的最小值。用go语言,给定两个整数 n 和 x,构造一个长度为 n 的正整数数组 nums,使得数组中相邻元素递增且所有元素按位与的结果为 x。...返回可能的最小 nums 数组中的最后一个元素的值。 1 n, x <= 100000000。 输入:n = 3, x = 4。 输出:6。...解释: 数组 nums 可以是 [4,5,6] ,最后一个元素为 6 。 答案2024-12-11: chatgpt[1] 题目来自leetcode3133。...大体步骤如下: 1.计算变量 bitCount,表示 n 和 x 转换为二进制后的位数差。 2.设置初始解 res 为 x,并初始化另一个变量 m 为 n - 1。...总体额外空间复杂度: • 该算法只使用少量变量来存储数据,额外空间复杂度为 O(1),即为常量级别的空间消耗。
2024-09-04:用go语言,给定一个长度为n的数组 happiness,表示每个孩子的幸福值,以及一个正整数k,我们需要从这n个孩子中选出k个孩子。...在筛选过程中,每轮选择一个孩子时,所有尚未选中的孩子的幸福值都会减少 1。需要注意的是,幸福值不能降低到负数,只有在其为正数时才能减少。 我们的目标是尽可能使选中的k个孩子的幸福值之和最大化。...解释:按以下方式选择 2 个孩子: 1.选择幸福值为 3 的孩子。剩余孩子的幸福值变为 [0,1] 。 2.选择幸福值为 1 的孩子。剩余孩子的幸福值变为 [0] 。注意幸福值不能小于 0 。...4.最终返回累加的结果作为最大化幸福值之和的输出。 时间复杂度分析: • 排序的时间复杂度为 O(n*log(n)),n 为孩子的数量。...• 选 k 个孩子时,需要遍历最多 k 个元素,时间复杂度为 O(k)。 • 因此,总的时间复杂度为 O(n*log(n) + k)。
2023-01-04:有三个题库A、B、C,每个题库均有n道题目,且题目都是从1到n进行编号每个题目都有一个难度值题库A中第i个题目的难度为ai题库B中第i个题目的难度为bi题库C中第i个题目的难度为ci...小美准备组合出一套试题,试题共有三道题,第一题来自题库A,第二题来自题库B,第三题来自题库C试题要求题目难度递增,且梯度不能过大具体地说,第二题的难度必须大于第一题的难度,但不能大于第一题难度的两倍第三题的难度必须大于第二题的难度...,但不能大于第二题难度的两倍小美想知道在满足上述要求下,有多少种不同的题目组合(三道题目中只要存在一道题目不同,则两个题目组合就视为不同输入描述 第一行一个正整数n, 表示每个题库的题目数量第二行为n个正整数...a1, a2,...... an,其中ai表示题库A中第i个题目的难度值第三行为n个正整数b1, b2,...... bn,其中bi表示题库B中第i个题目的难度值第四行为n个正整数c1, c2,......... cn,其中ci表示题库C中第i个题目的难度值1 n <= 20000, 1 <= ai, bi, ci <= 10^9。
2024-06-26:用go语言,给定一个长度为n的数组nums和一个正整数k, 找到数组中所有相差绝对值恰好为k的子数组, 并返回这些子数组中元素之和的最大值。 如果找不到这样的子数组,返回0。...解释:好子数组中第一个元素和最后一个元素的差的绝对值必须为 3 。好子数组有 [-1,3,2] 和 [2,4,5] 。最大子数组和为 11 ,对应的子数组为 [2,4,5] 。...大体步骤如下: 1.初始化变量:设定初始答案 ans 为负无穷大(math.MinInt),创建一个空的 map minS 用来存储元素之和为某特定值的最小下标,初始化总和 sum 为 0。...3.最终判断 ans 是否仍为负无穷大,如果是,则返回 0,否则将 ans 转换为 int64 类型后返回。 总的时间复杂度为 O(n),其中 n 为输入数组的长度。...总的额外空间复杂度也是 O(n),因为使用了一个 map 来存储元素之和为特定值的最小下标,当输入数组中所有元素都不相差绝对值恰好为 k 时,map 中最多会存储 n 个元素。
2023-01-12:一个n*n的二维数组中,只有0和1两种值, 当你决定在某个位置操作一次, 那么该位置的行和列整体都会变成1,不管之前是什么状态。 返回让所有值全变成1,最少的操作次数。...1 n n < 10, 不会到10!最多到9! 来自华为。 答案2023-01-12: 四维dp+贪心。这道题优化力度很有限,跟暴力差不多。...i32) -> i32 { let mut n = n as u32; n = (n & 0x55555555) + ((n >> 1) & 0x55555555); n =...(n & 0x33333333) + ((n >> 2) & 0x33333333); n = (n & 0x0f0f0f0f) + ((n >> 4) & 0x0f0f0f0f); n...= (n & 0x00ff00ff) + ((n >> 8) & 0x00ff00ff); n = (n & 0x0000ffff) + ((n >> 16) & 0x0000ffff);
一个过程的调用包括将数据(以过程参数和返回值的形式)和控制从代码的一部分传递到另一部分。此外,它还必须在进入时为过程的局部变量分配空间,并在退出时释放空间。...虽然在给定时刻只能有一个过程是活动的,但是我们必须保证当一个过程(调用者)调用另一个过程(被调用者)时,被调用者不会覆盖某个调用者稍后会使用的寄存器的值。...如下图所示,它用寄存器 %ebx 来保存过程参数 n 的值(第 6 行代码)。它将寄存器 %ebx 中的返回值设置为 1,预期 n的情况,它就会跳转到完成代码。 ? ...的值 ②、被调用保存寄存器%ebx保存着参数n 因此将这两个值相乘(第 13 行)得到该函数的返回值。...对于终止条件和递归调用,代码都会继续到完成部分(第15~17行),恢复栈和被调用者保存寄存器,然后在返回。 所以我们看到递归调用一个函数本身与调用其它函数是一样的。
给定一个长度为n的数组arr, 现在你有一次机会, 将其中连续的K个数全修改成任意一个值, 请你计算如何修改可以使修改后的数 列的最长不下降子序列最长。 请输出这个最长的长度。...这些数组和变量将用于存储计算过程中的中间结果和输入数据。 2.在main函数中设置给定的输入数据:n表示数组的长度为5,k表示连续的k个数需要修改,arr存储具体的数组元素。...rightFn函数的步骤描述: 1.初始化right数组的最后一个元素right[n]为1,表示以最后一个元素为结尾的最长不下降子序列的长度为1。...2.初始化ends数组的第一个元素ends[1]为arr[n],表示以最后一个元素为结尾的最长不下降子序列的最后一个元素为arr[n]。...2.初始化len为0,表示当前最长不下降子序列的长度为0。 3.从第k+1个元素开始,循环遍历数组arr,计算修改后的数组的最长不下降子序列的长度。
By CaesarChang 合作: root121toor@gmail.com ~关注我 带你看更多精品知识 见注释 简单动态规划问题 将前面的数之和做一个更新
2023-05-03:给你一棵 二叉树 的根节点 root ,树中有 n 个节点每个节点都可以被分配一个从 1 到 n 且互不相同的值另给你一个长度为 m 的数组 queries你必须在树上执行 m 个...独立 的查询,其中第 i 个查询你需要执行以下操作:从树中 移除 以 queriesi 的值作为根节点的子树题目所用测试用例保证 queriesi 不 等于根节点的值。...返回一个长度为 m 的数组 answer ,其中 answeri 是执行第 i 个查询后树的高度。注意:查询之间是独立的,所以在每个查询执行后,树会回到其 初始 状态。...定义用于深度优先搜索的四个数组 dfn、deep、size、maxl、maxr 和一个计数器 n,保存每个节点的编号、深度、子树大小、左右子树的最大深度。...由于最坏情况下二叉树可能退化成一个链表,因此堆栈空间的最大使用量为 O(n),其中 n 是二叉树的节点数。
排序 指导您如何对查询返回的结果集进行排序。 去重查询 为您提供一个删除结果集中重复行的子句。 第 2 节. 过滤数据 主题 描述 WHERE 根据指定条件过滤行。...完全外连接 使用完全连接查找一个表中在另一个表中没有匹配行的行。 交叉连接 生成两个或多个表中的行的笛卡尔积。 自然连接 根据连接表中的公共列名称,使用隐式连接条件连接两个或多个表。 第 4 节....CUBE 定义多个分组集,其中包括所有可能的维度组合。 ROLLUP 生成包含总计和小计的报告。 第 7 节. 子查询 主题 描述 子查询 编写一个嵌套在另一个查询中的查询。...主题 描述 插入 指导您如何将单行插入表中。 插入多行 向您展示如何在表中插入多行。 更新 更新表中的现有数据。 连接更新 根据另一个表中的值更新表中的值。 删除 删除表中的数据。...连接删除 根据另一个表中的值删除表中的行。 UPSERT 如果新行已存在于表中,则插入或更新数据。 第 10 节.
二、栈帧结构和控制转移权方式大多数CPU上的程序实现使用栈来支持函数调用操作。栈被用来传递函数参数、存储返回信息、临时保存寄存器原有值以备恢复以及用来存储局部数据。...前两行用来设置保存调用者的帧指针和设置本函数的栈帧指针,第5行通过把栈指针esp下移4字节为局部变量c分配空间。6~15行是swap函数的主体部分。...第6~8行用于取调用者的第1个参数&a,并以该参数作为地址取所存内容到ecx寄存器中,然后保存到为局部变量分配的空间中(-4(%ebp))。...第9~12行用于取第2个参数&b,并以该参数值作为地址取其内容放到第1个参数指定的地址处。第13~15行把保存在临时局部变量c中的值存放到第2个参数指定的地址处。第16~17行是函数结束部分。...第19~21行是main()函数的设置部分,在保存和重新设置帧指针之后,main()为局部变量a和b在栈中分配了空间。第22~23行为这两个局部变量赋值。
2023-01-12:一个n*n的二维数组中,只有0和1两种值,当你决定在某个位置操作一次,那么该位置的行和列整体都会变成1,不管之前是什么状态。返回让所有值全变成1,最少的操作次数。...1 n n i32 { let mut n = n as u32; n = (n & 0x55555555) + ((n >> 1) & 0x55555555); n = (n...& 0x33333333) + ((n >> 2) & 0x33333333); n = (n & 0x0f0f0f0f) + ((n >> 4) & 0x0f0f0f0f); n = (n...& 0x00ff00ff) + ((n >> 8) & 0x00ff00ff); n = (n & 0x0000ffff) + ((n >> 16) & 0x0000ffff); return
前言 GDB是一个由GNU开源组织发布的、UNIX/LINUX 操作系统下的、基于命令行的、功能强大的程序调试工具。...test list/l n 从第 n 行开始显示程序, 后续继续输入 list/l,就可以显示后面的代码 break/b n 在第 n 行设置断点,断点那一行不会执行 run.../r 运行程序 接下来按 next/n/step/s 继续向下执行 next/n :下一个,调用函数就跑 step/s :单步,会进入调用的函数 要注意的是,如果是系统函数,按 s 就出不来了...; } } 设置两个断点,一个是普通断点(打在第14行),一个是条件断点(当 i = 6 时打在第6行),再执行 run b 14 b 6 if i = 6 run backtrace...有一点我们可能比较迷惑,在第一次执行backtrace的时候,main 函数所在的栈帧编号为0,而第二次执行的时候,main 函数的栈帧为1,而 myprint 函数的栈帧为0,这是因为与栈的向下增长规律一致
领取专属 10元无门槛券
手把手带您无忧上云