news 2026/5/1 4:43:01

在指定条件下获取布尔矩阵中的索引矩阵

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
在指定条件下获取布尔矩阵中的索引矩阵

问题重新描述如下,设计程序
[[False False False True True True]
[ True False True False False True]
[False False False True True True]
[ True False False False False False]
[False False False False False False]
[ True False False False False False]
[ True True False True False False]
[False False False True False False]
[ True False True False False True]
[False False False True True True]
[ True True False True False False]
[ True False True False False True]
[ True True False True False False]]

使用 np.where查找前面布尔矩阵中,

1、如果1,4,6列有两个True,则给我返回1,4,6列值为True的行列索引,放在前两个位置(行对索引应一个矩阵,列索引对应一个矩阵),剩下的那一个没有True的则返回该元素原始索引,放在第三个位置。

2、2,3,5列中最多有一个True,返回它的行列索引,放在返回数组的第四个位置。如果1,4,6列中True的个数小于2,就返回 1,4,6列的原始行列索引(放在返回数组的1,2,3列),以及第二列的索引(放在返回数组的第4列)。

3、最终返回两个索引数组,一个是行索引数组,另一个是列索引数组,每一行的索引必须与布尔矩阵中的行相对应

defelegant_solution(arr):""" 修正的向量化版本,无循环 """n_rows=arr.shape[0]# 1. 行索引数组row_array=np.repeat(np.arange(n_rows)[:,None],4,axis=1)# 2. 预定义列cols_146=np.array([0,3,5])cols_235=np.array([1,2,4])# 3. 初始化列索引数组col_array=np.zeros((n_rows,4),dtype=int)# 4. 计算第1,4,6列True数量counts_146=arr[:,cols_146].sum(axis=1)# 5. 区分两种情况mask_eq2=counts_146==2mask_lt2=counts_146<2# 6. 处理mask_lt2为True的情况(True个数小于2)# 设置默认值:第1,4,6列和第2列col_array[mask_lt2]=np.array([0,3,5,1])# 7. 处理mask_eq2为True的情况(True个数等于2)ifnp.any(mask_eq2):rows_eq2=np.where(mask_eq2)[0]n_eq2=len(rows_eq2)ifn_eq2>0:# 提取这些行的第1,4,6列arr_146_sub=arr[rows_eq2][:,cols_146]# 方法:使用argsort分离True和False# 对每行进行排序,True(1)会排在False(0)后面sorted_indices=np.argsort(arr_146_sub,axis=1)# 默认升序,False在前# 提取True的位置(最后两个)和False的位置(第一个)true_indices=sorted_indices[:,-2:]# 形状: (n_eq2, 2)false_indices=sorted_indices[:,0:1]# 形状: (n_eq2, 1)# 转换为原始列索引true_cols=cols_146[true_indices]false_cols=cols_146[false_indices]# 填充前三个位置col_array[rows_eq2,0]=true_cols[:,0]col_array[rows_eq2,1]=true_cols[:,1]col_array[rows_eq2,2]=false_cols[:,0]# 处理第2,3,5列arr_235_sub=arr[rows_eq2][:,cols_235]# 找到每行第一个True的位置# 使用cumsum找到第一个Truecumsum_arr=np.cumsum(arr_235_sub,axis=1)first_true_mask=(cumsum_arr==1)&arr_235_sub# 获取列索引# argmax会返回第一个最大值的位置,我们确保每行至多一个Truefirst_true_idx=np.argmax(first_true_mask,axis=1)# 检查是否找到Truehas_true=np.any(first_true_mask,axis=1)# 转换并填充# 注意:当没有True时,argmax返回0,但我们需要-1# 所以使用where根据has_true选择值col_235_vals=np.where(has_true,cols_235[first_true_idx],-1)col_array[rows_eq2,3]=col_235_valsreturnrow_array,col_array
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 6:50:20

Pandas数据处理:寻找每一行最大值及其列名

在数据分析和处理过程中,经常会遇到需要从数据集中提取特定信息的情况。今天我们来讨论如何在Python的Pandas库中找到DataFrame每一行的最大值及其对应的列名,并基于一个具体的需求进行处理。 问题描述 假设我们有一个DataFrame,其中列名从x_1到x_10,每行包含这些列的值。…

作者头像 李华
网站建设 2026/5/1 5:43:32

C++游戏玩家管理:从初始化列表到迭代器构造

引言 在C++编程中,初始化列表(std::initializer_list)和迭代器构造(std::list的迭代器构造函数)是两个非常有用的特性,尤其在处理容器和对象初始化时。然而,当涉及到复杂的类型转换和容器初始化时,理解这些特性的使用限制和正确用法变得至关重要。本文将通过一个游戏玩…

作者头像 李华
网站建设 2026/5/1 5:43:27

Excel中的动态图片更新技巧

引言 在Excel中处理图片时,经常会遇到需要将图片插入到特定单元格并希望在图片更改时自动更新的问题。本文将介绍如何通过VBA宏实现这一功能,并提供具体实例说明。 背景 假设我们有一个名为"sht__Infos"的工作表,其中有一个单元格命名为"Cel__Logo"。…

作者头像 李华
网站建设 2026/5/1 8:01:32

YOLOv8能否识别古文字?文化遗产数字化助力

YOLOv8能否识别古文字&#xff1f;文化遗产数字化的新可能 在博物馆的恒温库房里&#xff0c;一块布满裂纹的石碑静静伫立。千年的风雨侵蚀让上面的文字模糊不清&#xff0c;专家们需要借助放大镜逐字辨认&#xff0c;耗时数月才能完成一段铭文的释读。而在实验室的另一端&…

作者头像 李华
网站建设 2026/5/1 6:22:14

提高生存模型的泛化能力

原文&#xff1a;towardsdatascience.com/improving-generalization-in-survival-models-bb7bc045bfc6?sourcecollection_archive---------8-----------------------#2024-04-05 关于估算和提高员工流失预测准确性的建议 https://medium.com/nicolupi.2?sourcepost_page---b…

作者头像 李华
网站建设 2026/5/1 4:59:38

Keil调试教程:实时监控PID控制的实战方法

用Keil玩转实时PID调试&#xff1a;边跑代码边调参的硬核技巧 你有没有过这样的经历&#xff1f; 写好了一段PID控制算法&#xff0c;烧进单片机后发现系统震荡不止&#xff1b;想改个 Kd 试试看&#xff0c;就得停下程序、修改代码、重新编译下载——一顿操作下来&#xf…

作者头像 李华