百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

wps/excel函数技巧:reduce+product+mmult解决最短用时问题

itomcoil 2025-03-04 12:44 9 浏览


如图A列至G列为源数据,要求统计出黄色区域数据,要求如下:

1.人员参与收集"福禄寿喜财",不限制集的次数

2.要求统计集齐五项人员,未集齐不统计

3.并统计集齐人员所用的最短时长,如果一天集齐5项最短用时算一天,如果时间跨度内齐多次,按最短时间跨度,两个时间直接相减统计最短用时+1天计算

公式如下:

=LET(

列表,REDUCE("",SORT(UNIQUE(A5:A22)),LAMBDA(a,b,LET(

#变量“列表"会形成一个表格,表格由人员名称、5、最短用时三列组成

x,IF(FILTER(C5:G22,A5:A22=b)="",0,1),

#过滤出五福数据变将数据里的”OK"替换成1,空格替换成0

n,FILTER(B5:B22,A5:A22=b), #过滤出每个人员的日期,日期行数与变量x的行数相等

最短天数,MIN(REDUCE("",SEQUENCE(ROWS(x))-1,LAMBDA(ii,jj,VSTACK(ii,DROP(

REDUCE("",SEQUENCE(ROWS(DROP(x,jj))),LAMBDA(ss,tt,VSTACK(ss,IF(PRODUCT (MMULT(SEQUENCE(,tt,1,0),TAKE(DROP(x,jj),tt)))=0,100,INDEX(DROP(n,jj),tt)-INDEX(D ROP(n,jj),1)+1)))),1))))),

#最短天数是利用三次循环得出,得用mmult函数分别对所有行的每种可能组合进行计算,得 出每列都不为0的数据,并根据当前的列号调出时间并与第一行时间相减得到用时,如果有 一 列为0的情况出现则product乘积就会为0,此时输出100

IFERROR(VSTACK(a,HSTACK(b,5,最短天数)),"")))),

FILTER(列表,INDEX(列表,,3)<100))

#将用时大于等于100的过滤掉,也就是将五项不齐全的数据过滤掉

公式思路:本公式最核心部分是得到每个人每列数据的组合,这个组合是用两次循环得到,第一次循环得到每个人数据依次去掉前一行(第一行)、前二行、前三行……的数据,第二次循环根据第一次循环得到的行数分别取前一行(第一行)、前二行、前三行……进行mmult计算,得出是否每列都不为0。

mmult运算法则以取前三行为例:

第一参

1

1

1

第二参

1

1

0

1

0

0

1

0

1

0

1

0

1

0

1

第一参里的一行三列数据分别出第二参里的每一列的三行数据对应相乘:第一列乘以第一行然后再相加、第二列乘以第二行然后再相加……,以第一列为例:

1*1+0*1+1*1=2,根据这个规则5列全部矩阵运算后得到:

2

2

1

2

1

这样一组数字表现的是五福出现的次数,只要是没有一列为0则可视为在这个时间内集齐了五福,反之只要是有一列为0则没有集齐。

相关推荐

Java 如何从一个 List 中随机获得元素

概述从一个List中随机获得一个元素是有关List的一个基本操作,但是这个操作又没有非常明显的实现。本页面主要向你展示如何有效的从List中获得一个随机的元素和可以使用的一些方法。选择一个...

想月薪过万吗?计算机安卓开发之&quot;集合&quot;

集合的总结:/***Collection*List(存取有序,有索引,可以重复)*ArrayList*底层是数组实现的,线程不安全,查找和修改快,增和删比较慢*LinkedList*底层是...

China Narrows AI Talent Gap With U.S. as Research Enters Engineering Phase: Report

ImagegeneratedbyAITMTPOST--ChinaisclosinginontheU.S.intheAIindustry-academia-research...

大促系统优化之应用启动速度优化实践

作者:京东零售宋维飞一、前言本文记录了在大促前针对SpringBoot应用启动速度过慢而采取的优化方案,主要介绍了如何定位启动速度慢的阻塞点,以及如何解决这些问题。希望可以帮助大家了解如何定位该类问...

MyEMS开源能源管理系统核心代码解读004

本期解读:计量表能耗数据规范化算法:myems/myems-normalization/meter.py代码见底部这段代码是一个用于计算和存储能源计量数据(如电表读数)的小时值的Python脚本。它主...

Java接口与抽象类:核心区别、使用场景与最佳实践

Java接口与抽象类:核心区别、使用场景与最佳实践一、核心特性对比1.语法定义接口:interface关键字定义,支持extends多继承接口javapublicinterfaceDrawabl...

超好看 vue2.x 音频播放器组件Vue-APlayer

上篇文章给大家分享了视频播放器组件vue-aliplayer,这次给大家推荐一款音频插件VueAplayer。vue-aplayer一个好看又好用的轻量级vue.js音乐播放器组件。清爽漂亮的U...

Linq 下的扩展方法太少了,MoreLinq 来啦

一:背景1.讲故事前几天看同事在用linq给内存中的两个model做左连接,用过的朋友都知道,你一定少不了一个叫做DefaultIfEmpty函数,这玩意吧,本来很流畅的from......

MapReduce过程详解及其性能优化(详细)

从JVM的角度看Map和ReduceMap阶段包括:第一读数据:从HDFS读取数据1、问题:读取数据产生多少个Mapper??Mapper数据过大的话,会产生大量的小文件,由于Mapper是基于虚拟...

手把手教你使用scrapy框架来爬取北京新发地价格行情(实战篇)

来源:Python爬虫与数据挖掘作者:霖hero前言关于Scrapy理论的知识,可以参考我的上一篇文章,这里不再赘述,直接上干货。实战演练爬取分析首先我们进入北京新发地价格行情网页并打开开发者工具,如...

屏蔽疯狂蜘蛛,防止CPU占用100%(mumu模拟器和雷电模拟器哪个更占用cpu)

站点总是某个时间段莫名的cpu100%,资源占用也不高,这就有必要怀疑爬虫问题。1.使用"robots.txt"规范在网站根目录新建空白文件,命名为"robots.txt&#...

Web黑客近年神作Gospider:一款基于Go语言开发的Web爬虫,要收藏

小白看黑客技术文章,一定要点首小歌放松心情哈,我最爱盆栽!开始装逼!Gospider是一款运行速度非常快的Web爬虫程序,对于爱好白帽黑客的小白来说,可谓是佳作!Gospider采用厉害的Go语言开发...

用宝塔面板免费防火墙屏蔽织梦扫描网站

今天教大家在免费的基础上屏蔽织梦扫描,首先您要安装宝塔面板,然后再安装免费的防火墙插件,我用的是Nginx免费防火墙,然后打开这个插件。设置GET-URL过滤设置一条简单的宝塔面板的正则规则就可以屏蔽...

蜘蛛人再捞4千万美元 连续三周蝉联北美票房冠军

7月15日讯老马追踪票房数据的北美院线联盟今天表示,“蜘蛛人:离家日”(Spider-Man:FarFromHome)击退两部新片的挑战,连续第2周勇夺北美票房冠军,海捞4530万美元。法新...

夏天到了,需要提防扁虱,真是又小又恐怖的动物

夏天马上要到了,你知道吗,扁虱是这个夏天最危险的动物之一,很少有动物能比它还凶猛。Whenitcomestosummer'slittledangers,fewarenastiert...