百马百担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.mfbz.cn/a/213738.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

CSS——复合选择器、CSS特性、背景属性、显示模式

1、复合选择器 复合选择器&#xff1a;由两个或多个基础选择器&#xff0c;通过不同的方式组合而成。 作用&#xff1a;更准确、更高效的选择目标元素&#xff08;标签&#xff09; 1.1 后代选择器 后代选择器&#xff1a;选中某元素的后代元素 选择器写法&#xff1a;父选…

使用WPF设计时绑定加快开发速度

知识来源&#xff1a;B站up主 香辣恐龙蛋 第一步 第二步

小心处理 C++ 静态变量中的陷阱

小心处理 C 静态变量中的陷阱 函数中的 static 变量 static 变量的作用 C 中 static 关键字的最后一个用途是在函数内创建局部变量&#xff0c;这些变量在其作用域内退出和进入时保持其值。函数内的 static 变量类似于只能从该函数访问的全局变量。static 变量的一个常见用途…

【合集】从Java基础到JavaWeb网络开发——Java基础文章合集 JavaWeb网络开发文章合集

前言 本篇博客是Java开发的合集文章&#xff0c;内容涵盖了Java基础相关的博客&#xff0c;JavaWeb开发相关的博客&#xff0c;并且给出了小项目的案例。 目录 前言引出Java基础1、基本数据类型2、数组和集合List3、运算符4、逻辑控制5、IO流6、面向对象初步7、数据库入门8、J…

微服务实战系列之EhCache

前言 书接前文&#xff0c;继续深耕。上一篇博主对Redis进行了入门级介绍&#xff0c;大体知道了Redis可以干什么以及怎么使用它。 今日博主继续带着大家学习如何使用EhCache&#xff0c;这是一款基于Java的缓存框架。 微服务实战系列之Redis微服务实战系列之Cache微服务实战…

uni-app 微信小程序之自定义navigationBar顶部导航栏

文章目录 1. 实现效果2. App.vue3. pages.json 配置自定义4. 顶部导航栏 使用 微信小程序自定义 navigationBar 顶部导航栏&#xff0c;兼容适配所有机型 1. 实现效果 2. App.vue 在App.vue 中&#xff0c;设置获取的 StatusBar&#xff0c;CustomBar 高度&#xff08;实现适配…

FL Studio 21.2.1.3859中文破解激活版2024免费下载安装图文教程

FL Studio 21.2.1.3859中文破解激活版是我见过更新迭代最快的宿主软件&#xff0c;没有之一。FL Studio12、FL Studio20、FL Studio21等等。有时甚至我刚刚下载好了最新版本&#xff0c;熟悉了新版本一些好用的操作&#xff0c;Fl Studio就又推出了更新的版本&#xff0c;而且F…

【附代码】Python函数性能测试(perfplot)

文章目录 相关文献测试电脑配置展开元素是list的list在numpy数组上映射函数的最有效方法数组numpy中唯一值的最有效频率计数方法反转numpy数组的最有效方法如何向 numpy 数组添加额外的列将 numpy 矩阵初始化为零或一以外的值 作者&#xff1a;小猪快跑 基础数学&计算数学&…

P2 Linux系统目录结构

前言 &#x1f3ac; 个人主页&#xff1a;ChenPi &#x1f43b;推荐专栏1: 《C_ChenPi的博客-CSDN博客》✨✨✨ &#x1f525; 推荐专栏2: 《Linux C应用编程&#xff08;概念类&#xff09;_ChenPi的博客-CSDN博客》✨✨✨ &#x1f6f8;推荐专…

【STL】手撕 string类

目录 1&#xff0c;string类框架 2&#xff0c;string&#xff08;构造&#xff09; 3&#xff0c;~string&#xff08;析构&#xff09; 4&#xff0c;swap&#xff08;交换&#xff09; 5&#xff0c;string&#xff08;拷贝构造&#xff09; 1&#xff0c;常规法 2&a…

【数据结构】AOV网与拓扑排序

一.AOV网的概念&#xff08;Activity On Vertex Network&#xff09; 在一个表示工程的有向图中&#xff0c;用顶点表示活动&#xff0c;用弧表示活动之间的优先关系。这样的有向图为顶点表示活动的网&#xff0c;我们称为AOV网&#xff08;Activity On Vertex Network&#xf…

【系统运维】Centos部署Haproxy+Keepalived+RabbitMQ高可用集群

1.RabbitMQ高可用集群方案 &#xff08;1&#xff09;RabbitMQ搭建集群的作用&#xff1a;提高可用性、可靠性和处理能力&#xff0c;确保系统提供高效的消息传递服务 高可用性&#xff1a;通过集群&#xff0c;即使其中一个节点发生故障&#xff0c;其他节点仍然可以继续提供…

C++ 学习笔记——C++纯虚函数和抽象类

C纯虚函数 什么是纯虚函数 1&#xff0c;纯虚函数只有函数名、参数、返回值类型。 2&#xff0c;纯虚函数的定义是在函数句首使用 virtual 关键字修饰&#xff0c;并且在句末增加 “ 0”。 virtual void funtion() 0;3&#xff0c;纯虚函数只有声明&#xff0c;基类可以存…

LLM 开发模式 RAG,MRKL,Re-Act,Plan-Execute 模式对比

本心、输入输出、结果 文章目录 LLM 开发模式 RAG&#xff0c;MRKL&#xff0c;Re-Act&#xff0c;Plan-Execute 模式对比前言RAG、MRKL、Re-Act和Plan-Execute模式的一些对比花有重开日&#xff0c;人无再少年实践是检验真理的唯一标准 LLM 开发模式 RAG&#xff0c;MRKL&…

JVM:强软弱虚四种引用

下面依次解释五种引用 一、强引用 把一个对象赋值给一个引用变量&#xff0c;就相当于把这个对象的强引用放到变量中。 只要对象可达&#xff0c; GC一定不会回收这个对象&#xff08;A1&#xff09; 二、软引用 当一个对象&#xff08;A2&#xff09;没有强引用时&#xff…

图文并茂教你模拟302接口,实现js中axios,fetch遇到302状态码后跳转的多种方案axios,fetch成功响应拦截302

前情提要 日常工作中&#xff0c;我们会使用fetch,或者axios发起请求来获取数据&#xff0c;但是当我们遇到一些特殊需求的时候&#xff0c;使用不同库之后&#xff0c;会得到不同的结果&#xff0c;例如302,308的状态码&#xff0c;那么我们应该怎么处理这两种情况呢&#xf…

C语言练习题

C语言练习题 文章目录 C语言练习题题目一题目二题目三题目四题目五题目六题目八 题目一 #include <stdio.h> //VS2022,默认对齐数为8字节 union Un {short s[7];int n; };int main() {printf("%zd", sizeof(union Un));return 0; }代码运行结果:> 16 sizeo…

Springboot依赖注入时重复初始化Bean的问题

前言 最近做项目&#xff0c;发现了springboot2.7.x在参数initiate的时候可以反复初始化&#xff0c;而且首次异常后&#xff0c;第二次成功居然也可以启动&#xff0c;通过查看源代码发现了问题根源&#xff0c;且在springboot高版本3.x&#xff0c;就出现了了Configuration的…

pytorch 中的dim 的作用范围

1. 二维矩阵时 不同的运算&#xff0c; dim 的作用域都是一样的思想&#xff1b; 当数据是二维矩阵时&#xff0c; 可以按照下面的思想理解&#xff1a; 对于矩阵&#xff1a; dim0 按列操作&#xff08;沿列向下&#xff09;。 dim1 按行操作&#xff08;跨行&#xff09;。 …
最新文章