计算麻将的番数
描述: |
计算麻将的番数 麻将游戏越来越受到大家喜爱,也在网络上盛行。本题目是给定一组已经和牌的麻将,编写一个函数计算这组麻将的番数。为简化题目,假设麻将只有筒子和条子两种花型,能翻番的规则也只有以下三种,当一组牌中没有下述三种情况中的一种或多种,则这组牌为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 |
答案提示: |
只输出番数,且为整型。 |
思路:
这道题目还是有点BT的,首先我没接触过麻将,不像之前的同学7岁便打遍全城无敌手了,完全看不懂题目的节奏有木有。细细理一下题目,在纸上写写画画还是很有必要的。看懂题目之后,就知道是干嘛的了,不就是字符串匹配嘛。
首先想到的就是正则表达式,这是它的强项啊。可是奈何我对正则君了解甚少,各种尝试,网上各种找资料,可是一个简单的四归一就把我难住了,只好作罢。
那么只能用“笨法子”,逐个分析字符了,好在题目说了是保证输入的正确性的,那么就只有三种情况要匹配,我是先对字符串长度进行判断,若长度满足{6,8,28}之中的一个,那么才有可能是三种情况中的一种:
- 卡2条:最简单了,在字符串长度等于6的情况下,只要判断是否与"1T2T3T"匹配即可;
- 四归一:在字符串长度等于8的情况下,将字符串分为四份,若四份都相等,那么就是四归一,加番;
- 巧七对:在字符串长度等于28的情况下判断,有点复杂,不多说了,看程序吧。
package com.liuhao; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.util.regex.Pattern; public class Mahjong { public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); String input = br.readLine(); // 输入是以","间隔,以"."结尾的,因此用[,|.]进行分割,得到各局的牌面 String[] strArray = input.split("[,.]"); // 记录总番数 int num = 0; for (int i = 0; i < strArray.length; i++) { System.out.print(strArray[i] + " "); //分情况进行判断,其他情况不加分 //若为卡2条,是则加1分 if((6 == strArray[i].length()) && isKaErTiao(strArray[i])){ num += 1; } //若为四归一,是则加2分 if((8 == strArray[i].length()) && isSiGuiYi(strArray[i])){ num += 2; } //若为巧七对,是则加2分 if((28 == strArray[i].length()) && isQiaoQiDui(strArray[i])){ num += 2; } } System.out.println(num); } //判断是否是卡2条为一番,即有一局牌是 1T2T3T; private static boolean isKaErTiao(String str) { boolean temp = false; if ("1T2T3T".equals(str)) { temp = true; } return temp; } //判断四归一为两番,即有4张一样的牌(花色和数字都一样); //如1T1T1T1T,3D3D3D3D private static boolean isSiGuiYi(String str) { boolean temp = false; //如3D3D3D3D,判断3D,3D,3D,3D是否两两相等 if(str.subSequence(0, 2).equals(str.substring(2, 4)) && str.substring(2, 4).equals(str.substring(4, 6)) && str.substring(4, 6).equals(str.substring(6))){ temp = true; } return temp; } //1T1T2T2T1D1D2D2D7T7T8T8T1D1D //判断巧七对为两番,即一组牌恰好是7对牌; private static boolean isQiaoQiDui(String str) { boolean temp = true; //如1T1T2T2T1D1D2D2D7T7T8T8T1D1D //分为七个单元,在每个单元内 判断是否满足 "1"=="1"同时"T"=="T" for(int i=0;i<str.length()-3;i+=4){ if(!((str.charAt(i) == str.charAt(i+2)) && (str.charAt(i+1) == str.charAt(i+3)))){ temp = false; break; } } return temp; } }
在华为平台提交后仍然没得满分,我只能做到这里了,还请大神们指点。
相关推荐
标题“华为南京研究所机考练习-亮着电灯的盏数”所指的是一场编程考试或面试题目,其中可能涉及到计算机科学中的算法和逻辑思维。这类问题通常要求编写程序来解决特定的问题,例如在这个例子中,可能是关于灯的状态...
标题中的“华为南京研究所机考练习-从考试成绩中划出及格线”指的是一个编程练习,可能是华为在招聘或培训过程中对候选人进行的技术考核的一部分。这个练习可能要求考生编写程序,从一组考试成绩中自动确定及格分数...
总的来说,【华为机考100题-带答案】是一份全面的复习资料,对于准备华为认证考试的考生而言,通过系统地练习和学习,可以有效地提升自己的技术水平和应试能力。同时,它也是检验自我学习成果和查漏补缺的良好工具。...
华为作为全球知名的ICT解决方案提供商,其在电子设计与集成电路领域有着深厚的积累,每年都会举行针对FPGA(Field-Programmable Gate Array,现场可编程门阵列)和数字IC(Digital Integrated Circuits,数字集成...
华为机考练习试题汇总
### 华为机考一本通-2024:OD岗位与机考攻略详解 #### 一、华为OD岗位解析 ##### 1.1 OD岗位介绍 - **岗位性质**:OD岗位即华为与德科合作的精英研发项目,与传统外包项目不同,OD岗位在华为内部具有更高的地位和...
"华为机考试题+答案参照.pdf" 本资源是一个华为机考试题集,涵盖了多个IT领域的知识点,包括算法、数据结构、操作系统等。本文将对每个题目进行详细的解释和分析。 1. 评委打分问题: * 知识点:算法、数组操作 ...
根据给定文件的信息,我们可以提炼出三个主要的技术知识点:评分系统的计算逻辑、数组排序与重构算法、以及操作系统任务调度机制。 ### 1. 评分系统的计算逻辑 #### 知识点解析: 本部分代码实现了一个评分系统,...
华为校招硬件技术工程师机考试卷试题包括答案.docx
### 华为OD机考100题之五键键盘输出问题 #### 问题背景与描述 本题目属于算法设计类题目,旨在考察考生对于键盘输入处理的理解以及基本的编程能力。题目要求根据一系列给定的键盘输入指令,模拟一个特殊键盘的操作...
华为机考练习攻略及注意事项
### 华为OD机考攻略知识点详析 #### 一、机考介绍 - **考试形式**:华为OD机考采用在线形式,考试平台为牛客网。 - **试题构成**:考试包含三道算法题,其中两道简单题各占100分,一道中等难度题占200分,总分400...
华为OD机考是华为公司针对求职者进行技术能力评估的一种方式,主要测试应聘者的编程技能。这个压缩包包含了四个部分,分别标记为ABCD卷,涵盖了四种编程语言:Java、C++、JavaScript和Python。这些语言在现代软件...
在准备华为OD机考的过程中,不仅要理解这些知识点,还要通过大量的练习来提高解题速度和准确性。在阅读和练习题目时,先尝试自己解决问题,然后再对照答案,这样可以更有效地评估自己的学习进度和理解程度。
### 华为校招硬件岗,电源岗笔试题解析 #### 题目1:压敏电阻选型原则 **题目描述**:压敏电阻选型需满足:压敏电压 \(U_c >\) 最大持续工作电压 \(U_{max} >\) 额定工作电压 \(U_n\);绝不允许 \(U_c\) 低于被...
【华为OD机考2023试题】涉及的IT知识点主要涵盖算法设计、字符串处理、游戏逻辑、日志管理、链表操作以及优化问题解决。下面将分别详细讲解这些知识点。 1. **任务混部问题**: 这是一道典型的资源调度优化问题,...
2022华为od机考题_嵌入式-常用知识&面试题库_大厂面试真题.rar