zoj 2975 Kinds of Fuwas

本文介绍了一种通过枚举列并计算每种特定字符(B,J,H,Y)出现次数的方法来找出矩阵中相同列的数量。利用组合数学原理计算每种字符相同位置出现的次数,并最终汇总得到总数量。
部署运行你感兴趣的模型镜像

枚举列,对每个字母算出存在多少相同的列,然后用组合数算。

#include <iostream> #include <cstring> using namespace std; char data[250][251]; int m, n; int _num[5]; inline int index(char c) { if(c == 'B') return 0; if(c == 'J') return 1; if(c == 'H') return 2; if(c == 'Y') return 3; return 4; } int main() { int t; cin >> t; while(t--) { int ans = 0; cin >> m >> n; for(int i = 0; i < m; i++) { cin >> data[i]; } for(int i = 0; i < n - 1; i++) { for(int j = i + 1; j < n; j++) { memset(_num, 0, sizeof(_num)); for(int k = 0; k < m; k++) { if(data[k][i] == data[k][j]) _num[index(data[k][i])]++; } for(int j = 0; j < 5; j++) ans = ans + _num[j] * (_num[j] - 1) / 2; } } cout << ans << endl; } return 0; }

您可能感兴趣的与本文相关的镜像

Facefusion

Facefusion

AI应用

FaceFusion是全新一代AI换脸工具,无需安装,一键运行,可以完成去遮挡,高清化,卡通脸一键替换,并且Nvidia/AMD等显卡全平台支持

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值