C++知识点总结(23):高级模拟算法真题 ★★★☆☆《骰子游戏》

2024-03-09 16:28

本文主要是介绍C++知识点总结(23):高级模拟算法真题 ★★★☆☆《骰子游戏》,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

骰子游戏

1. 审题

題目描述

E r i c Eric Eric 最近在澳门旅游,澳门游乐场有这样一个骰子游戏,他们使用三颗六面骰子,游戏规则如下:点数的优先级是 6 6 6 5 5 5 4 4 4 3 3 3 2 2 2 1 1 1,当三个骰子的点数都相同时,称为“豹子”,豹子按点数优先级比较大小;当两个骰子的点数相同时,称为“对子”,所有对子都按剩余骰子的点数优先级比较;其他情况称为“点子”,点子按点数和比较大小;豹子比对子、点子大,对子比点子大,现在 E r i c Eric Eric 需要和电脑先模拟投骰子的情况,请你来判断一下胜负情况(没有为什么,总是我们来帮忙 )。

输入描述

第一行为一个正整数 n n n,表示一共有 n n n 次游戏,以后每两行表示一个样例,第一行是 E r i c Eric Eric 骰子的点数,第二行为电脑骰子的点数。

输出描述

输出有 n n n 行,如果是 E r i c Eric Eric 赢,则输出 "Eric",如果是电脑赢,则输出 "Computer",其他情况都输出 "Balance"

2. 参考答案

  • 伪核心代码
getsum(a[])if (a[0] == a[1] && a[0] == a[2])return a[0] + 25if (a[0] == a[1])return a[2] + 15if (a[0] == a[2])return a[1] + 15if (a[1] == a[2])return a[0] + 15return a[0] + a[1] + a[2]
  • AC代码
#include <iostream>
using namespace std;int n;
int eric[5], computer[5];
int sumeric, sumcomputer;int getsum(int a[])
{if (a[0] == a[1] &&  a[0] == a[2]) // 豹子{return a[0] + 25;}if (a[0] == a[1]) // 对子{return a[2] + 15;}if (a[0] == a[2]) // 对子{return a[1] + 15;}if (a[1] == a[2]) // 对子{return a[0] + 15;}return a[0] + a[1] + a[2]; // 其他情况
}int main()
{cin >> n;for (int i = 1; i <= n; i++){cin >> eric[0] >> eric[1] >> eric[2];cin >> computer[0] >> computer[1] >> computer[2];// 计算胜负sumeric = getsum(eric);sumcomputer = getsum(computer);if (sumeric > sumcomputer){cout << "Eric\n";}else if (sumcomputer > sumeric){cout << "Computer\n";}else{cout << "Balance\n";}}return 0;
}

这篇关于C++知识点总结(23):高级模拟算法真题 ★★★☆☆《骰子游戏》的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/791244

相关文章

Windows下C++使用SQLitede的操作过程

《Windows下C++使用SQLitede的操作过程》本文介绍了Windows下C++使用SQLite的安装配置、CppSQLite库封装优势、核心功能(如数据库连接、事务管理)、跨平台支持及性能优... 目录Windows下C++使用SQLite1、安装2、代码示例CppSQLite:C++轻松操作SQ

C++中RAII资源获取即初始化

《C++中RAII资源获取即初始化》RAII通过构造/析构自动管理资源生命周期,确保安全释放,本文就来介绍一下C++中的RAII技术及其应用,具有一定的参考价值,感兴趣的可以了解一下... 目录一、核心原理与机制二、标准库中的RAII实现三、自定义RAII类设计原则四、常见应用场景1. 内存管理2. 文件操

C++中零拷贝的多种实现方式

《C++中零拷贝的多种实现方式》本文主要介绍了C++中零拷贝的实现示例,旨在在减少数据在内存中的不必要复制,从而提高程序性能、降低内存使用并减少CPU消耗,零拷贝技术通过多种方式实现,下面就来了解一下... 目录一、C++中零拷贝技术的核心概念二、std::string_view 简介三、std::stri

C++高效内存池实现减少动态分配开销的解决方案

《C++高效内存池实现减少动态分配开销的解决方案》C++动态内存分配存在系统调用开销、碎片化和锁竞争等性能问题,内存池通过预分配、分块管理和缓存复用解决这些问题,下面就来了解一下... 目录一、C++内存分配的性能挑战二、内存池技术的核心原理三、主流内存池实现:TCMalloc与Jemalloc1. TCM

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

C++ 函数 strftime 和时间格式示例详解

《C++函数strftime和时间格式示例详解》strftime是C/C++标准库中用于格式化日期和时间的函数,定义在ctime头文件中,它将tm结构体中的时间信息转换为指定格式的字符串,是处理... 目录C++ 函数 strftipythonme 详解一、函数原型二、功能描述三、格式字符串说明四、返回值五

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

C++作用域和标识符查找规则详解

《C++作用域和标识符查找规则详解》在C++中,作用域(Scope)和标识符查找(IdentifierLookup)是理解代码行为的重要概念,本文将详细介绍这些规则,并通过实例来说明它们的工作原理,需... 目录作用域标识符查找规则1. 普通查找(Ordinary Lookup)2. 限定查找(Qualif

Nginx Location映射规则总结归纳与最佳实践

《NginxLocation映射规则总结归纳与最佳实践》Nginx的location指令是配置请求路由的核心机制,其匹配规则直接影响请求的处理流程,下面给大家介绍NginxLocation映射规则... 目录一、Location匹配规则与优先级1. 匹配模式2. 优先级顺序3. 匹配示例二、Proxy_pa

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio