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

excel函数技巧:reduce+filter/offset\tocol三种排列组合的方法

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

如图,从A列21个字母中选出3个进行排列组合,忽略字母顺序,共有1330种可能,如何公式实现呢?公式如下:

方法1:

=LET(t,TOCOL(TRANSPOSE(A2:A22)&TOCOL(A2:A22&TRANSPOSE(A2:A22))),p,MAP(t,LAMBDA(x,CONCAT(UNIQUE(SORT(MID(x,ROW($1:$3),1)))))),UNIQUE(FILTER(p,LEN(p)=3)))

方法2:

=DROP(UNIQUE(REDUCE("",A2:A22,LAMBDA(x,y,VSTACK(x,REDUCE("",FILTER(A2:A22,A2:A22<>y),LAMBDA(i,j,VSTACK(i,REDUCE("",FILTER(A2:A22,ISERROR(XMATCH(A2:A22,VSTACK(j,y)))),LAMBDA(m,n,VSTACK(m,IF(OR(BYROW(IFERROR(FIND(HSTACK(y,j,n),VSTACK(x,i,m)),0),LAMBDA(s,AND(s<>0)))),"",y&j&n))))))))))),1)

方法3:

=DROP(UNIQUE(REDUCE("",A2:A22,LAMBDA(x,y,VSTACK(x,REDUCE("",OFFSET(y,1,,MAX(1,22-ROW(y))),LAMBDA(i,j,VSTACK(i,REDUCE("",OFFSET(j,1,,MAX(1,22-ROW(j))),LAMBDA(m,n,IF(OR(OFFSET(y,1,,MAX(1,22-ROW(y)))="", OFFSET(j,1,,MAX(1,22-ROW(j)))=""),"",VSTACK(m,y&j&n))))))))))),1)

公式思路:

公式1利用字母两次纵横结合,得到了所有的排列组合,然后利用函数进行排序、去重、长度过滤、再去重得到结果,方法很简洁,运算速度也很快,是首选方法,它充分利用了excel二维表格的特点。

公式2利用了reduce函数实现三次循环,同时利用filter函数去除了重复,加快效率,并以累积器中是否存在为判断条件,返回不重复的组合。这个公式适用于内存数组,但对于区域数组来说运算速度较慢。

公式3同样利用了reduce函数实现了三次循环,每次循环数组,根据变量的索引用offset函数进行了精准的控制,快速得到了结果。

相关推荐

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...