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

Excel实用公式6:求每隔n行中的单元格之和

学习Excel技术,关注微信公众号: excelperfect 很多时候,我们都可能想要对每隔n行中的单元格求和,其中n是一个整数。如下图1所示,每隔1行求和、每隔2行求和、每隔3行求和,等等。 ?...图1 从图1的示例可知,如果我们每隔1行求和,有求奇数行或者偶数行的单元格之和两种情况,其中,奇数行求和的数组公式为: =SUM(IF(MOD(ROW($A$1:$A$15),2)=1,$A$1:$A$15,0...对于每隔2行求和,即求第1、4、7、10、13行中单元格之和,使用数组公式: =SUM(IF(MOD(ROW($A$1:$A$15),3)=1,$A$1:$A$15,0)) 对于每隔3行求和,即求第1、...5、9、13行中的单元格之和,使用数组公式: =SUM(IF(MOD(ROW($A$1:$A$15),4)=1,$A$1:$A$15,0)) 我们可以得到一个规律,对于每隔n行求和(n>1),其一般公式...),n+1)=1,Range,0))

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

    如何取一个数字到N位小数点

    如果取一个数字到N位小数点,要怎么做呢? 这里总结有两种方式:格式化和四舍五入。...格式化 如果只是想打印n位小数,可以使用字符串格式化进行打印: System.out.printf("格式化成小数点后3位: %.3f %n", PI); //打印结果:格式化成小数点后3位: 3.142...使用DoubleRounder四舍五入 DoubleRounder是decimal4j库中的一个工具类,它提供了从0到18位小数点快速且使用Garbage-free思想(避免或减少对象的创建)的四舍五入方法...在这种情况下,我们可以通过乘和除以10^n来控制小数点后n位: public static double roundAvoid(double value, int places) { double...// 打印结果: 92.23372036854776 roundAvoid(260.775d, 2); // 打印的是 260.77 而不是预想的 260.78 总结 本篇文章介绍了不同的方式取一个数字到

    90420

    Python把列表中的数字尽量等分成n份

    问题描述:假设一个列表中含有若干整数,现在要求将其分成n个子列表,并使得各个子列表中的整数之和尽可能接近。...下面的代码并没有使用算法,而是直接将原始列表分成n个子列表,然后再不断地调整各个子列表中的数字,从元素之和最大的子列表中拿出最小的元素放到元素之核最小的子列表中,重复这个过程,知道n个子列表足够接近为止...import random def numberSplit(lst, n, threshold): '''lst为原始列表,内含若干整数,n为拟分份数 threshold为各子列表元素之和的最大差值...''' length = len(lst) p = length // n #尽量把原来的lst列表中的数字等分成n份 partitions = [] for i in range...('初始分组结果:', partitions) #不停地调整各个子列表中的数字 #直到n个子列表中数字之和尽量相等 times = 0 while times < 1000:

    3.2K80

    2022-03-16:给你一个整数 n ,表示有 n 个专家从 0 到 n -

    2022-03-16:给你一个整数 n ,表示有 n 个专家从 0 到 n - 1 编号。...另外给一个下标从 0 开始的二维整数数组 meetings , 其中 meetingsi = xi, yi, timei 表示专家 xi 和专家 yi 在时间 timei 要开一场会。...一个专家可以同时参加 多场会议 。最后,给你一个整数 firstPerson 。 专家 0 有一个 秘密 ,最初,他在时间 0 将这个秘密分享给了专家 firstPerson 。...也就是说,在同一时间,一个专家不光可以接收到秘密,还能在其他会议上与其他专家分享。 在所有会议都结束之后,返回所有知晓这个秘密的专家列表。你可以按 任何顺序 返回答案。...(ret) } func findAllPeople(n int, meetings [][]int, firstPerson int) []int { // 0~n-1号专家,各自建立小集合 /

    30920

    一行代码就可以替换n个仓储文件

    ( 且放白鹿青崖间,须行即骑访名山 ) 终于还是要面对这个问题了,一直想着可以逃避它,自从18年就开始纠结这个问题,后来看了DDD,然后也收集了很多的设计思想,发现一个框架除了稳定性,可扩展性以外,易操作无冗余也是很重要的...但是这个时候就埋下了一个伏笔,就是很多人也发现了,如果新建一个实体,就会需要增加四层类文件,服务/服务接口,仓储/仓储接口,如果再算上控制器提供API(下一步打算设计将server层接口直接作为控制器api...但是仓储文件就显得有点儿鸡肋了,代码都是空的,还需要两个cs文件,就是一个中转的作用,看着真的是没有什么必要一样: 然后就很多小伙伴针对这一点,一直在提意见,发问题,甚至开怼,无奈的我只能说: 服务层写的是业务逻辑...容器中注册仓储基类 这个就是文章标题说的内容了,只需要这一行代码就行了: builder.RegisterGeneric(typeof(BaseRepository)) .As(typeof(IBaseRepository...: (我这里也把仓储接口层给删了,毕竟没有几个文件) 修改服务实现层对仓储调用 上边我们已经把仓储/接口都删除了,那如何使用呢,很简单,直接用基类泛型注入就行了,这里用一个Service文件来看看:

    55320

    2022-07-17:1、2、3...n-1、n、n、n+1、n+2... 在这个序列中,只有一个数字有重复(n)。 这个序列是无序的,找到重复数字n。 这个序

    2022-07-17:1、2、3...n-1、n、n、n+1、n+2...在这个序列中,只有一个数字有重复(n)。这个序列是无序的,找到重复数字n。这个序列是有序的,找到重复数字n。...一个结论 return slow;}// 符合题目要求的、无序数组,找重复数// 时间复杂度O(N),额外空间复杂度O(1)// 用异或fn find_duplicate2(arr: &mut Vec...一个结论 return ans;}// 符合题目要求的、有序数组,找重复数// 时间复杂度O(logN),额外空间复杂度O(1)fn find_duplicate_sorted(arr: &mut...[]; for i in 0..n + 1 { ans.push(i + 1); } ans[n as usize] = rand::thread_rng().gen_range...(0, n) + 1; let mut i = n; while i > 0 { let j = rand::thread_rng().gen_range(0, i + 1);

    82810

    一日一技:在Python里面如何获取列表的最大n个元素或最小n个元素?

    我们知道,在Python里面,可以使用 max和 min获得一个列表的最大、最小的元素: a = [4, 2, -1, 8, 100, -67, 25]max_value = max(a)min_value...= min(a) print(max_value)print(min_value) 运行效果如下图所示: 那么问题来了,如何获取最大的3个元素和最小的5个元素?...:{max_three}')print(f'最小的5个元素:{min_five}') 运行效果如下图所示: 这里的 heapq是一个用于处理 堆这种数据结构的模块。...它会把原来的列表转换成一个堆,然后取最大最小值。 需要注意,当你要取的是前n大或者前n小的数据时,如果n相对于列表的长度来说比较小,那么使用 heapq的性能会比较好。...但是如果n和列表的长度相差无几,那么先排序再切片的性能会更高一些。

    8.8K30

    无码实现​从非数字到数字拆分到行,是怎么做到的?| Power Query技巧

    在Power Query里,拆分列的功能非常强大,除了按分隔符、字符数等基本拆分功能外,还支持如从大写到小写或相反,从数据到非数字或相反等等特殊方式,相信很多朋友也都使用过: 其中,按分隔符拆分,有一个比在...Step-02 按分隔符拆分列 虽然我们最后要按“从数字到非数字”进行拆分,但是,我们要借助按分隔符可以拆分到行的方法: 在按分隔符拆分中选择拆分为“行”: 此时,我们通过观察可以发现,生成的步骤中...,其实是通过一个splitter函数来实现拆分的,而“到行”是通过Table.ExpandListColumn函数进行扩展得到的: 所以,如果我们改变了其中的Splitter参数,就能实现不同方式拆分到行的功能...但是,要自己去写这些Splitter函数,还是比较麻烦的,而且,我们也没有必要自己动手去写,生成一个步骤去复制就可以了—— Step-03 按照从非数字到数字的转换拆分列 此时,我们看步骤的公式,明显...Splitter参数,并复制: Step-04 替换前一步骤“按分隔符拆分列”中的Splitter参数 回到“按分隔符拆分列”的步骤,粘贴替换掉原来按分隔符拆分的Splitter参数,马上就得到从非数字到数字的拆分到行的效果

    1.1K10

    2021-08-26:长度为N的数组arr,一定可以组成N^2个数字

    2021-08-26:长度为N的数组arr,一定可以组成N^2个数字对。...例如arr = 3,1,2,数字对有(3,3) (3,1) (3,2) (1,3) (1,1) (1,2) (2,3) (2,1) (2,2),也就是任意两个数都可以,而且自己和自己也算数字对,数字对怎么排序...给定一个数组arr,和整数k,返回第k小的数值对。 福大大 答案2021-08-26: 1.暴力解。 时间复杂度:(N^2 * log(N^2)). 2.下标定位+bfprt算法。 2.1.k--。...i1=k/N。 i2=k%N。 2.3.根据bfprt算法求出第i1小和第i2小的数。 时间复杂度:O(N)。 空间复杂度:O(1)。arr数组里的元素顺序会发生变化。 代码用golang编写。...第1维数字 lessFristNumSize := 0 fristNumSize := 0 for i := 0; i N; i++ { if arr[i]

    41610

    2022-03-07:K 个关闭的灯泡。 N 个灯泡排成一行,编号从

    2022-03-07:K 个关闭的灯泡。 ​ N 个灯泡排成一行,编号从 1 到 N 。最初,所有灯泡都关闭。每天只打开一个灯泡,直到 N 天后所有灯泡都打开。...给你一个长度为 N 的灯泡数组 blubs ,其中 bullsi = x 意味着在第 (i+1) 天,我们会把在位置 x 的灯泡打开,其中 i 从 0 开始,x 从 1 开始。...给你一个整数 K ,请你输出在第几天恰好有两个打开的灯泡,使得它们中间 正好 有 K 个灯泡且这些灯泡 全部是关闭的 。 如果不存在这种情况,返回 -1 。...:= 1 ret := kEmptySlots2(arr, k) fmt.Println(ret) } func kEmptySlots2(bulbs []int, k int) int { n...:= len(bulbs) days := make([]int, n) for i := 0; i n; i++ { days[bulbs[i]-1] = i + 1 } ans :=

    49210
    领券