握手问题 第十五届蓝桥杯大赛软件赛省赛C/C++ 大学 B 组

server/2025/3/25 23:30:48/

握手问题

题目来源

第十五届蓝桥杯大赛软件赛省赛C/C++ 大学 B 组

原题链接

蓝桥杯 握手问题

问题描述

问题分析

算法思路分析:

  1. 问题描述

    • 总共有 50 人参加会议,每个人需要与其他 49 人握手一次。
    • 但有 7 个人彼此之间没有握手(这 7 人之间没有握手,但他们与其他 43 人握手)。
    • 需要计算实际发生的握手次数。
  2. 握手总数计算

    • 如果没有限制,50 人之间总的握手次数为组合数 C ( 50 , 2 ) = 50 × 49 2 = 1225 C(50, 2) = \frac{50 \times 49}{2} = 1225 C(50,2)=250×49=1225
    • 但由于 7 人之间没有握手,需要减去这 7 人之间本应发生的握手次数 C ( 7 , 2 ) = 7 × 6 2 = 21 C(7, 2) = \frac{7 \times 6}{2} = 21 C(7,2)=27×6=21
  3. 代码实现

    • 代码通过累加 1 到 49 的和来计算 50 人之间的总握手次数(因为 1 + 2 + ⋯ + 49 = 49 × 50 2 = 1225 1 + 2 + \dots + 49 = \frac{49 \times 50}{2} = 1225 1+2++49=249×50=1225)。
    • 然后减去 1 到 6 的和(因为 1 + 2 + ⋯ + 6 = 6 × 7 2 = 21 1 + 2 + \dots + 6 = \frac{6 \times 7}{2} = 21 1+2++6=26×7=21),表示减去 7 人之间未发生的握手次数。
    • 最终结果为 1225 − 21 = 1204 1225 - 21 = 1204 122521=1204

代码解释:

  1. 计算总握手次数

    • 使用循环 for (int i = 1; i < 50; i++) 累加 1 到 49 的和,得到 50 人之间的总握手次数 1225。
  2. 减去未发生的握手次数

    • 使用循环 for (int i = 1; i < 7; i++) 累加 1 到 6 的和,得到 7 人之间未发生的握手次数 21。
    • 从总握手次数中减去 21,得到实际握手次数 1204。
  3. 输出结果

    • 使用 printf("%d", res); 输出最终的握手次数。

总结:

通过累加和减去的方式,高效计算实际发生的握手次数。


完整代码

#include <iostream>
using namespace std;int main() {int res = 0;  // 定义结果变量 res,用于存储握手总次数// 计算 50 人之间的总握手次数// 1 + 2 + 3 + ... + 49 = 1225for (int i = 1; i < 50; i++) {res += i;}// 减去 7 人之间未发生的握手次数// 1 + 2 + 3 + ... + 6 = 21for (int i = 1; i < 7; i++) {res -= i;}// 输出最终的握手次数printf("%d", res);return 0;
}

http://www.ppmy.cn/server/176680.html

相关文章

【第14节】windows sdk编程:进程与线程介绍

目录 一、进程与线程概述 1.1 进程查看 1.2 何为进程 1.3 进程的创建 1.4 进程创建实例 1.5 线程查看 1.6 何为线程 1.7 线程的创建 1.8 线程函数 1.9 线程实例 二、内核对象 2.1 何为内核对象 2.2 内核对象的公共特点 2.3 内核对象句柄 2.4 内核对象的跨进程访…

电脑管家如何清理内存及垃圾,提升电脑性能

电脑在长时间使用后&#xff0c;常常会变得越来越卡顿&#xff0c;打开程序的速度变慢&#xff0c;甚至响应迟缓。这时&#xff0c;不少用户会选择使用电脑管家来进行内存清理和垃圾清理。那么&#xff0c;电脑管家是如何清理内存的&#xff1f;它又是如何清理垃圾的&#xff1…

docker,centos容器开机启动程序

1、拉取个centos容器 2、这样启动&#xff0c;有systemctl权限 docker run -tid --name centos01 --privilegedtrue centos:02 /usr/sbin/init3、加环境变量&#xff0c;在/etc/profile 配置环境变量&#xff0c;&#xff08;自己安装的软件&#xff0c;入java&#xff09;&a…

Python刷题:流程控制(上)

今天刷的是PythonTip的Python 入门挑战中的题&#xff0c;整体难度不高&#xff0c;适合小白练手以及巩固知识点。下面会进行详细讲解。 每日一句 每一个拼命努力的人&#xff0c;都像是独自穿越黑暗森林的行者&#xff0c; 没有并肩的身影&#xff0c;唯有孤独如影随形&…

FPGA管脚约束

目录 前言 一、IO约束 二、延迟约束 前言 IO约束包括管脚约束和延迟约束。 一、IO约束 对管脚进行约束&#xff0c;对应的约束语句&#xff1a; set_property -dict {PACKAGE_PIN AJ16 IOSTANDARD LVCMOS18} [get_ports "led[0]" ] 上面是单端的管脚&…

游戏开发全流程及其工具详解

游戏开发是一个复杂且高度协作的过程&#xff0c;涉及多个专业领域&#xff0c;从原画设计到程序开发&#xff0c;从建模到音效制作&#xff0c;每一个环节都需要精确的工具与流程支持。涵盖了原画设计、建模、动画制作、UI开发、特效、音效、程序开发等多个方面&#xff0c;并…

【Agent】OpenManus-Agent架构详细分析

各组件详细设计见&#xff1a; BaseAgent&#xff1a;BaseAgentReActAgent&#xff1a;ReActAgentToolCallAgent&#xff1a;ToolCallAgent具体Agent实现&#xff1a;具体AgentMemory数据结构&#xff1a;Memory 1. 智能体层次结构 OpenManus 采用了一个多层次的智能体继承结…

集成学习之随机森林

目录 一、集成学习的含义 二、集成学习的代表 三、集成学习的应用 1、分类问题集成。&#xff08;基学习器是分类模型&#xff09; 2、回归问题集成。&#xff08;基学习器是回归模型&#xff09; 3、特征选取集成。 四、Bagging之随机森林 1、随机森林是有多个决策树&a…