1 条题解

  • 0
    @ 2025-8-6 14:43:56

    1.数组解法 思路 因为需要去重,所以我们可以考虑开一个 bool 类型数组,只要出现过这张牌就赋值为 11

    那么问题又来了,因为数组下标只能为整数,不能直接以字符串作为下标。观察数据,发现一张扑克牌只有两个元素:花色和点数,所以我们可以开一个二维数组,第一维代表花色,第二维代表点数,然后用 11 ~ 44 分别表示四个花色,点数同理。

    #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;
    }
    • 1

    信息

    ID
    634
    时间
    1000ms
    内存
    256MiB
    难度
    10
    标签
    递交数
    5
    已通过
    1
    上传者