洛谷 P1148 拱猪计分

【题目链接】

洛谷 P1148 拱猪计分

题目补充说明:

D10与D11都可能出现,D10作用与D11相同。如果D10与D11同时出现,只算有1张D牌。

当H1~H13都有,但D或S只有1个时:D牌作用:-100分,S牌作用:+100分。

【题目考点】

1. 模拟

【解题思路】

根据题意直接模拟

设布尔数组h,用来记录是否有牌Hi。设布尔变量s12, d10, c10,表示是否存在S、D和C牌。

按照题目描述,根据该玩家手中存在的牌的种类,计算分数。

具体解释见注释。

【题解代码】

解法1:模拟
cpp 复制代码
#include <bits/stdc++.h>
#define INF 0x3f3f3f3f
using namespace std;
#define N 105
int proc(int n)//n:有n张牌 
{
	string s;
	int score = 0;
	bool h[20] = {}, s12 = false, d10 = false, c10 = false;//h[1]~p[13]:H1~H13 是否存在  
	int pt[15] = {0,-50,-2,-3,-4,-5,-6,-7,-8,-9,-10,-20,-30,-40};//pt[i]:牌Hi的分数 
	for(int i = 1; i <= n; ++i)
	{
		cin >> s;
		if(s[0] == 'H')
			h[stoi(s.substr(1))] = true;//标记h[i]为真 
		else if(s[0] == 'S')
			s12 = true;
		else if(s[0] == 'D')//D10与D11都认为是D10 
			d10 = true;
		else if(s[0] == 'C')
			c10 = true;
	}
	bool hasAllH = true;//是否有所有13张H牌 
	for(int i = 1; i <= 13; ++i)
		if(h[i] == false)
		{
			hasAllH = false;
			break;
		}
	if(hasAllH)//如果有全部13张红心牌 
	{
		score = 200;//全红心牌加200 
		if(s12 && d10)//如果同时有S牌和D牌 
			score = 500;
		else if(s12)//如果只有S,那么减100 
			score -= 100;
		else if(d10)//如果只有D,那么加100 
			score += 100;
		if(c10)//如果有C牌,分数乘2 
			score *= 2;
	}
	else//如果并没有持有所有的红心牌 
	{
		for(int i = 1; i <= 13; ++i)
			if(h[i])//如果有Hi这张牌 
				score += pt[i];
		if(score == 0 && !s12 && !d10 && c10)//如果只有C牌没有其它牌 
			score += 50;
		else
		{
			if(s12)//如果有S牌 
				score -= 100;
			if(d10)//如果有D牌 
				score += 100;
			if(c10)//如果有C牌 
				score *= 2;
		}
	}
	return score;
}
int main()
{
	bool isOver;
	int n, score[5];//score[i]:某局游戏后第i名玩家的得分 
	while(true)
	{
		isOver = true;
		for(int i = 1; i <= 4; ++i)
		{
			cin >> n;
			if(n != 0)
				isOver = false;
			score[i] = proc(n);//求出第i名玩家的得分 
		}
		if(isOver)//如果输入4个0,则跳出 
			break;
		for(int i = 1; i <= 4; ++i)//输出每位玩家的得分 
			cout << (score[i] > 0 ? "+" : "") << score[i] << ' ';//如果是正数则输出正号 
		cout << endl;
	}
	return 0;
}
相关推荐
karmueo461 小时前
视频序列和射频信号多模态融合算法Fusion-Vital解读
算法·音视频·多模态
写代码的小球4 小时前
求模运算符c
算法
大千AI助手8 小时前
DTW模版匹配:弹性对齐的时间序列相似度度量算法
人工智能·算法·机器学习·数据挖掘·模版匹配·dtw模版匹配
YuTaoShao9 小时前
【LeetCode 热题 100】48. 旋转图像——转置+水平翻转
java·算法·leetcode·职场和发展
生态遥感监测笔记9 小时前
GEE利用已有土地利用数据选取样本点并进行分类
人工智能·算法·机器学习·分类·数据挖掘
Tony沈哲10 小时前
macOS 上为 Compose Desktop 构建跨架构图像处理 dylib:OpenCV + libraw + libheif 实践指南
opencv·算法
刘海东刘海东10 小时前
结构型智能科技的关键可行性——信息型智能向结构型智能的转变(修改提纲)
人工智能·算法·机器学习
pumpkin8451411 小时前
Rust 调用 C 函数的 FFI
c语言·算法·rust
挺菜的11 小时前
【算法刷题记录(简单题)003】统计大写字母个数(java代码实现)
java·数据结构·算法