20150802厦门大学华为校园提前批招聘机试体验题二:计算麻将的番数

题二:

描述:

 

计算麻将的番数

 

麻将游戏越来越受到大家喜爱,也在网络上盛行。本题目是给定一组已经和牌的麻将,编写一个函数计算这组麻将的番数。为简化题目,假设麻将只有筒子和条子两种花型,能翻番的规则也只有以下三种,当一组牌中没有下述三种情况中的一种或多种,则这组牌为0番,每种番数是加的关系,例如一组牌既有卡2条又有四归一,则番数为3番。

 

1.卡2条为一番,即有一局牌是 1条2条3条;

2.四归一为两番,即有4张一样的牌(花色和数字都一样);

3.巧七对为两番,即一组牌恰好是7对牌;

 

  一些约定:

 

1.一组已经和牌的麻将由多局牌组成,一局牌可以是一对牌、3张连续同样花色的牌、3张一样的牌、4张一样的牌。

2.一组已经和牌一般有14张牌,最多可以有18张牌(当有四归一的时候)。

 

输入:

一字符串表示已经和牌的麻将(由输入者保证,编程人员无需考虑没有和牌),如1T2T3T,4T5T6T,7T8T9T,1D2D3D,4D4D.

 

说明:

1.”1T”表示1条,T表示条子,前面跟数字几表示几条,数据范围1~9,输入者保证,编程无需考虑输入规范性;

2.”4D”表示4筒,D表示筒子,前面跟数字几表示几筒,数据范围是1~9, 输入者保证,编程无需考虑输入规范性;

3.每局牌之间由’,’隔开,输入者保证每局牌都是正确的且按照数字由小到大排序,编程人员无需判断每局牌的正确性;

4.一组牌以’.’号结束,由输入者保证,编程人员无需考虑是否有”.”号。

5.输入保证有番数的牌在一局中,编程人员无需考虑排序,即有番数的牌不会分散在多局牌中。

 

输出:

麻将的番数,整型类型。

 

样例输入:1T2T3T,4T5T6T,7T8T9T,1D2D3D,4D4D.

样例输出: 1 


本题的难点在于正确理解题目的意思,考虑到所有情况,算法不难。本文采用的是字符数组,可能比较麻烦。熟练掌握C++中的string类的同学,可以用字符串操作,这样简便些。


代码如下:

#include <iostream>

using namespace std;

int main()
{
	char str[100] = {};
	char str1[100][100] = {};
	int i, j = 0, k = 0;
	int count = 0;
	cin.getline(str, 100);   //字符数组输入
	for (i = 0; i < 100 && str[i]!='.';i++)
	{
		if (str[i]==',') //遇到逗号,则一局牌取完
		{
			str1[k][j + 1] = '\0';   //一局牌最后加'\0'结束符
			k++;     //牌局数+1
			j = 0;  //一局中的计数清零
		}
		else
		{
			str1[k][j] = str[i];  //获取每一局牌的具体牌
			j++;
		}
	}  //获取各局牌,用str1保存
	if (k == 6)  //巧七对,则两番
	{
		count = count + 2;
	}
	k++;  //补上最后一局牌局数
	for (i = 0; i < k;i++)
	{
		if (strlen(str1[i]) == 6)  //两种3张牌情况:1、3张连续同花色的牌;2、3张一样的牌
		{
			if (strcmp(str1[i], "1T2T3T") == 0) //卡2条,则一番
			{
				count++;
			}
		}
		else if (strlen(str1[i]) == 8)  //4张牌情况,即为四归一,则两番
		{
			count = count + 2;
		}
	}
	cout << count << endl;  //输出番数
	return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值