百马百担c语言编程

以下是一个百马百担问题的C语言编程实现:

  1. #include <stdio.h>
  2. int main() {
  3.     int n, m, k;
  4.     scanf("%d%d%d", &n, &m, &k);
  5.     int a[n], b[m], c[k];
  6.     for (int i = 0; i < n; i++) {
  7.         scanf("%d", &a[i]);
  8.     }
  9.     for (int i = 0; i < m; i++) {
  10.         scanf("%d", &b[i]);
  11.     }
  12.     for (int i = 0; i < k; i++) {
  13.         scanf("%d", &c[i]);
  14.     }
  15.     int sum_a = 0, sum_b = 0, sum_c = 0;
  16.     for (int i = 0; i < n; i++) {
  17.         sum_a += a[i];
  18.     }
  19.     for (int i = 0; i < m; i++) {
  20.         sum_b += b[i];
  21.     }
  22.     for (int i = 0; i < k; i++) {
  23.         sum_c += c[i];
  24.     }
  25.     if (sum_a == sum_b && sum_b == sum_c) {
  26.         printf("YES\n");
  27.     } else {
  28.         printf("NO\n");
  29.     }
  30.     return 0;
  31. }

这个程序首先读取三个整数n、m、k,分别表示马的数量、担的数量和人的数量。然后分别读取n个马的数量、m个担的重量、k个人的人数,存储在数组a、b、c中。接着计算马的总重量sum_a、担的总重量sum_b、人的总重量sum_c,如果三者相等则输出"YES",否则输出"NO"。

当然,这个程序可以根据需要进行一些改进。以下是一个可能的改进版本,它可以处理更一般的情况,并且输出更详细的信息:

  1. #include <stdio.h>
  2. int main() {
  3.     int n, m, k;
  4.     scanf("%d%d%d", &n, &m, &k);
  5.     int a[n], b[m], c[k];
  6.     for (int i = 0; i < n; i++) {
  7.         scanf("%d", &a[i]);
  8.     }
  9.     for (int i = 0; i < m; i++) {
  10.         scanf("%d", &b[i]);
  11.     }
  12.     for (int i = 0; i < k; i++) {
  13.         scanf("%d", &c[i]);
  14.     }
  15.     int sum_a = 0, sum_b = 0, sum_c = 0;
  16.     for (int i = 0; i < n; i++) {
  17.         sum_a += a[i];
  18.     }
  19.     for (int i = 0; i < m; i++) {
  20.         sum_b += b[i];
  21.     }
  22.     for (int i = 0; i < k; i++) {
  23.         sum_c += c[i];
  24.     }
  25.     if (sum_a == sum_b && sum_b == sum_c) {
  26.         printf("YES, all weights are equal.\n");
  27.     } else {
  28.         printf("NO, weights are not equal.\n");
  29.         if (sum_a != sum_b) {
  30.             printf("The total weight of horses is %d, but the total weight of donkeys is %d.\n", sum_a, sum_b);
  31.         }
  32.         if (sum_b != sum_c) {
  33.             printf("The total weight of donkeys is %d, but the total weight of people is %d.\n", sum_b, sum_c);
  34.         }
  35.     }
  36.     return 0;
  37. }

这个版本的程序在比较重量之前先分别计算了马、担和人各自的重量总和,这样如果重量不等,程序可以输出哪个总和与其它总和不相等,以便用户更好地理解问题。

好的,以下是对上述程序的进一步改进,增加了对输入数据的验证和错误处理:

  1. #include <stdio.h>
  2. int main() {
  3.     int n, m, k;
  4.     scanf("%d%d%d", &n, &m, &k);
  5.     // 检查输入数据的有效性
  6.     if (n <= 0 || m <= 0 || k <= 0) {
  7.         printf("Invalid input: all counts must be positive.\n");
  8.         return 0;
  9.     }
  10.     int a[n], b[m], c[k];
  11.     for (int i = 0; i < n; i++) {
  12.         scanf("%d", &a[i]);
  13.     }
  14.     for (int i = 0; i < m; i++) {
  15.         scanf("%d", &b[i]);
  16.     }
  17.     for (int i = 0; i < k; i++) {
  18.         scanf("%d", &c[i]);
  19.     }
  20.     // 检查输入数据的总和是否为整数,并且不超过整数的最大值
  21.     long long sum_a = 0, sum_b = 0, sum_c = 0;
  22.     for (int i = 0; i < n; i++) {
  23.         sum_a += a[i];
  24.     }
  25.     for (int i = 0; i < m; i++) {
  26.         sum_b += b[i];
  27.     }
  28.     for (int i = 0; i < k; i++) {
  29.         sum_c += c[i];
  30.     }
  31.     if (sum_a != sum_b || sum_b != sum_c) {
  32.         printf("The total weights are not equal.\n");
  33.         if (sum_a != sum_b) {
  34.             printf("The total weight of horses is %lld, but the total weight of donkeys is %lld.\n", sum_a, sum_b);
  35.         }
  36.         if (sum_b != sum_c) {
  37.             printf("The total weight of donkeys is %lld, but the total weight of people is %lld.\n", sum_b, sum_c);
  38.         }
  39.     } else {
  40.         printf("YES, all weights are equal.\n");
  41.     }
  42.     return 0;
  43. }

这个版本的程序增加了对输入数据的验证,包括检查输入数据的有效性和总和是否为整数,并且不超过整数的最大值。如果输入数据无效或总和不是整数,程序将输出错误信息。如果总和不等,程序将输出哪个总和与其它总和不相等,以便用户更好地理解问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/238394.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

微信小程序自定义tabBar简易实现

文章目录 1.app.json设置custom为true开启自定义2.根目录创建自定义的tab文件3.app.js全局封装一个设置tabbar选中的方法4.在onshow中使用选中方法最终效果预览 1.app.json设置custom为true开启自定义 2.根目录创建自定义的tab文件 index.wxml <view class"tab-bar&quo…

Centos7使用阿里云镜像加速服务安装Docker

文章目录 一、前提说明二、安装docker1、创建docker文件夹2、安装所需的软件包3、设置Docker仓库4、安装docker5、启动验证使用阿里云镜像加速服务 三、卸载docker 一、前提说明 需要先安装好虚拟机&#xff0c;可以查看这篇https://blog.csdn.net/qq_36433289/article/detail…

春秋云镜 CVE-2022-30887

春秋云镜 CVE-2022-30887 多语言药房管理系统 (MPMS) 靶场介绍 多语言药房管理系统 (MPMS) 是用 PHP 和 MySQL 开发的, 该软件的主要目的是在药房和客户之间提供一套接口&#xff0c;客户是该软件的主要用户。该软件有助于为药房业务创建一个综合数据库&#xff0c;并根据到期…

Kubernetes(K8s) Pod详解-05

Pod详解 Pod介绍 Pod结构 每个Pod中都可以包含一个或者多个容器&#xff0c;这些容器可以分为两类&#xff1a; 用户程序所在的容器&#xff0c;数量可多可少 Pause容器&#xff0c;这是每个Pod都会有的一个根容器&#xff0c;它的作用有两个&#xff1a; 可以以它为依据…

html实现各种好看的鼠标滑过图片特效模板

文章目录 1.鼠标悬浮效果1.1 渐动效果1.2 渐变效果1.3 边框效果1.4 线行效果1.5 图标效果1.6 块状效果1.7 边线效果1.8 放大效果1.9 渐出效果1.10 痕迹效果1.11 交叉效果1.12 着重效果1.13 详展效果1.14 能动效果1.15 明细效果 2.主要源码2.1 源代码 源码下载 作者&#xff1a;…

go开发之个人微信号机器人开发

简要描述&#xff1a; 下载消息中的文件 请求URL&#xff1a; http://域名地址/getMsgFile 请求方式&#xff1a; POST 请求头Headers&#xff1a; Content-Type&#xff1a;application/jsonAuthorization&#xff1a;login接口返回 参数&#xff1a; 参数名必选类型…

泊车功能专题介绍 ———— 汽车全景影像监测系统性能要求及试验方法(国标未公布)

文章目录 术语和定义一般要求功能要求故障指示 性能要求响应时间图像时延单视图视野范围平面拼接视图视野平面拼接效果总体要求行列畸变拼接错位及拼接无效区域 试验方法环境条件仪器和设备车辆条件系统响应时间试验图像时延试验单视图视野范围试验平面拼接视图视野试验平面拼接…

使用 NRF24L01 无线收发模块进行远程控制

NRF24L01 是一款基于 2.4GHz 射频通信的低功耗无线收发模块&#xff0c;具有高性能和稳定性&#xff0c;适用于远程控制和数据传输应用。本文将介绍如何使用 NRF24L01 模块进行远程控制&#xff0c;包括硬件的连接和配置&#xff0c;以及相应的代码示例。 一、引言 NRF24L01 是…

使用K-means把人群分类

1.前言 K-mean 是无监督的聚类算法 算法分类&#xff1a; 2.实现步骤 1.数据加工&#xff1a;把数据转为全数字&#xff08;比如性别男女&#xff0c;转换为0 和 1&#xff09; 2.模型训练 fit 3.预测 3.代码 原数据类似这样(source&#xff1a;http:img-blog.csdnimg.cn…

【力扣 面试题02.07链表相交】一种思路极其清晰的解法

力扣一单简单题&#xff0c;看完大佬的题解真是佩服得五体投地&#xff01; 虽是一道简单题&#xff0c;当我吭哧吭哧写了几十行后&#xff0c;看到大佬仅仅几行直接秒掉&#xff0c;只能说算法的本质还是数学&#xff0c;数学逻辑思维真是太重要了&#xff0c;有时候真得慢慢去…

电子学会C/C++编程等级考试2021年06月(四级)真题解析

C/C++等级考试(1~8级)全部真题・点这里 第1题:数字三角形问题 (图1) 图1给出了一个数字三角形。从三角形的顶部到底部有很多条不同的路径。对于每条路径,把路径上面的数加起来可以得到一个和,你的任务就是找到最大的和。 注意:路径上的每一步只能从一个数走到下一层上和它…

JavaScript 基本数据类型

JavaScript 基本数据类型 目录 JavaScript 基本数据类型 一、数字型&#xff08;Number型&#xff09; 1、整型数据 2、浮点型数据 二、字符串型 1、单引号括起来的一个或多个字符&#xff1a; 2、双引号括起来的一个或多个字符&#xff1a; 3、单引号定界的字符串中可…