算法训练 审美课

第一次尝试

你好! 这是你第一次使用 Markdown编辑器 所展示的欢迎页。如果你想学习如何使用Markdown编辑器, 可以仔细阅读这篇文章,了解一下Markdown的基本语法知识。

源码

#include<iostream>
using namespace std;
int main (){
	int n,m;
	cin>>n>>m;
	int A[50000]={0};
	int flag=0;
	for(int i=0;i<m;i++){
		flag=flag*2+1;
	}
	int count=0;
	for(int i=0;i<n;i++){
		for(int j=0;j<m;j++){
			int a;
			cin>>a;
			A[i]=A[i]*2+a;
		}
		for(int j=0;j<i;j++){
			if((A[i]^A[j])==flag){
				count++;
			}			
		}
	}
	cout<<count<<endl;
	return 0;
} 

结果

在这里插入图片描述

查阅资料

资料1.
资料2.
发现map的使用

map的使用

map是STL的一个关联容器,它提供一对一的hash。

第一个可以称为关键字(key),每个关键字只能在map中出现一次;
第二个可能称为该关键字的值(value);

使用map后的代码

#include<iostream>
#include <map>
using namespace std;
int main (){
	int n,m;
	cin>>n>>m;

	int flag=0;
	for(int i=0;i<m;i++){
		flag=flag*2+1;
	}
	map<int ,int> A;
	int count=0;
	for(int i=0;i<n;i++){
		int a=0;
		for(int j=0;j<m;j++){
			int b;
			cin>>b;
			a=a*2+b;
		}
		A[a]+=1;
	}
	
	for(map<int,int>::iterator it=A.begin();it!=A.end();it++){
		int a=it->first;
		int num=flag^a;
		count+=A[num]*it->second;
	}
	cout<<count/2<<endl;
	return 0;
} 

分析

之前的算法时间复杂度是n^2
使用map算法后复杂度变为n,一轮遍历即可求出答案

总结

map相当于一个键值对,以键从小到大排列
定义map<int ,int> A;
遍历
for(map<int,int> iterator it=A.begin();it!=A.end;it++);
it->first;去键值
it->second;取值

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值