1 条题解
-
0
1.数组解法 思路 因为需要去重,所以我们可以考虑开一个 bool 类型数组,只要出现过这张牌就赋值为 。
那么问题又来了,因为数组下标只能为整数,不能直接以字符串作为下标。观察数据,发现一张扑克牌只有两个元素:花色和点数,所以我们可以开一个二维数组,第一维代表花色,第二维代表点数,然后用 ~ 分别表示四个花色,点数同理。
#include<bits/stdc++.h> using namespace std; int n; bool a[5][20]; int main(){ cin>>n; while(n--){ char x,y; //x,b为花色,y,c为点数 int b,c; cin>>x>>y; if(x=='D') b=1; if(x=='C') b=2; if(x=='H') b=3; if(x=='S') b=4; if(y=='A') c=1; if(y>='2'&&y<='9') c=y-'0'; if(y=='T') c=10; if(y=='J') c=11; if(y=='Q') c=12; if(y=='K') c=13; a[b][c]=1; } int ans=0; for(int i=1;i<=4;++i){ for(int j=1;j<=13;++j){ ans+=a[i][j]; } } cout<<52-ans; return 0; }
信息
- ID
- 634
- 时间
- 1000ms
- 内存
- 256MiB
- 难度
- 10
- 标签
- 递交数
- 5
- 已通过
- 1
- 上传者