第一次尝试
你好! 这是你第一次使用 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;
}
结果
查阅资料
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;取值