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

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

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


如图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则没有集齐。

相关推荐

编程学子看过来,竞赛刷题网站推荐

2022年编程竞赛已经公布,想要在今年取得竞赛成绩的学生,一定要把握寒假时间,学习知识的同时通过刷题,巩固所学知识,提升解题能力。小编为大家推荐几个刷题网站,想要竞赛的学生一定不要错过。USACO美国...

给大家推荐些好的c语言代码的网站

C语言,那就来推荐几个吧,部分含有C++:1、TheLinuxKernelArchives(kernel.org)Linux内核源码,仅限于C,但内核庞大,不太适合新手;2、redis(redi...

推荐几个编程入门学习网站_比较好的编程自学网站

有一些刚上大学的朋友和想对编程感兴趣的朋友经常会让我推荐学习网站,下面几个是我认为零基础学编程比较好的网站,希望大家都有收获!1.W3schoolhttp://www.w3school.com.c...

10个最值得收藏的编程学习网站_有什么学编程的网站

程序员是一个需要不断学习的职业。幸运的是,在这个互联网时代,知识就在那里,等着我们去获取。以下我列举一些免费的编程学习网站包含多个开发语言Java、php、html、javascript等多个。1、h...

6个超酷的练习算法,学习编程的网站

在不了解算法的前提下,您无法通过Google或Facebook的采访。那么为什么不现在学习。我是一位拥有15年以上经验的程序员。从高中开始的第一年,我在算法上学习和工作很多。在我毕业之前,我一直...

在线 python 编程的网站_python3在线编程,python3在线编译器,在线编辑器

以下是一些提供在线Python编程环境的网站:1.Repl.it:Repl.it提供了一个多语言在线编程平台,您可以使用它在任何地方编写、运行、共享代码。Repl.it支持多种编程语言,包括Pyth...

推荐 7 个能过招全球程序员的编程挑战网站,欢迎挑战!

作为程序员的你,是不是经常估不准自己的编程水平?下面推荐7个能过招全球程序员的编程挑战网站,助你磨练技巧,提升技能,最终问鼎代码江湖!1.HackerRank你可以参加各种编码竞赛,比如算法、数学...

盘点 20 个编程学习教程网站,建议收藏

欢迎关注@程序员柠檬橙私信回复「1024」获取海量编程学习资源!如果你想学习编程,现在互联网这么方便,不用着急报名培训班,有很多高质量的编程学习资源网站可供你学习,程序员日常浏览的技术教程网站有哪些...

Flask 数据可视化_flourish数据可视化

数据可视化是数据处理中的重要部分,前面我们了解了Flask的开发和部署,如何用Flask做数据可视化呢?今天我们来了解一下。Python语言极富表达力,并且拥有众多的数据分析库和框架,是数据...

【python 工具】selenium 浏览器操作

selenium的安装步骤:1.安装selenium,打开cmd控制台pipinstallselenium2.安装驱动程序(我这里安装的是chromedriver),用来启动chrome浏览器...

可视化爬虫工具,EasySpider软件体验

现在提起爬虫,大家可能会联想到Python语言,然后就是各种使用无头浏览器去网页上爬取数据,使用Python的过程相较于使用其他语言来说,简单了不少。但毕竟是编程语言,也需要去学习来适配各种网...

cursor+mcp+playwright,让AI给你推荐五一旅游胜地

阅读本文前提当你已了解mcp是什么,若不知,猛击:https://github.com/modelcontextprotocol/servers。最近有个小需求,根据用户输入内容,使用大模型来理解用户...

Cursor+Claude+Playwright:AI 让自动化测试效率暴涨,快到飞起!

一、引言随着AI时代的到来,软件测试变得越来越复杂,如何高效、准确地进行自动化测试成了每一个开发团队必须面对的问题。在日常工作中,测试工作常常面临各种挑战,比如功能复杂、需求频繁变更、时间紧迫等。传统...

推荐一个检测 JS 内存泄漏的神器_js内存泄漏的几种情况

大家好,我是Echa哥。作为一名Web应用程序开发者,排查和修复JavaScript代码的内存泄漏一直是最困扰我的问题之一。最近,Meta开源了一款检测JavaScript代码内存泄漏...

Python+Playwright自动化实战:高效爬虫全攻略

一、为什么选择Playwright?在信息爆炸的时代,数据获取能力直接决定内容生产效率。Playwright作为微软开源的新型自动化工具,凭借以下优势成为技术创作者的新宠:支持Chromium/Web...