c语言新龟兔赛跑

2023-11-24 11:15
文章标签 语言 赛跑 新龟

本文主要是介绍c语言新龟兔赛跑,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

以下是一个使用C语言编写的新的龟兔赛跑游戏:

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <time.h>
  4. int main() {
  5.     int distance, turtle_speed, rabbit_speed, turtle_time, rabbit_time, rabbit_lead;
  6.     srand(time(NULL)); // 随机数种子
  7.     // 初始化变量
  8.     distance = 100; // 赛跑距离为100米
  9.     turtle_speed = 1; // 乌龟速度为1米/分钟
  10.     rabbit_speed = 5; // 兔子速度为5米/分钟
  11.     turtle_time = 0; // 乌龟所用时间为0分钟
  12.     rabbit_time = 0; // 兔子所用时间为0分钟
  13.     rabbit_lead = 0; // 兔子领先距离为0米
  14.     printf("新龟兔赛跑游戏\n");
  15.     printf("赛跑距离: %d米\n", distance);
  16.     printf("乌龟速度: %d米/分钟\n", turtle_speed);
  17.     printf("兔子速度: %d米/分钟\n", rabbit_speed);
  18.     printf("开始赛跑!\n");
  19.     // 模拟赛跑过程
  20.     while (distance > 0) {
  21.         // 乌龟前进
  22.         turtle_time += 1; // 乌龟用时加1分钟
  23.         if (turtle_time == 60) { // 乌龟每60分钟走1米
  24.             turtle_time = 0;
  25.             distance--;
  26.         }
  27.         // 兔子前进
  28.         rabbit_time += 1; // 兔子用时加1分钟
  29.         if (rabbit_time == 60) { // 兔子每60分钟走5米
  30.             rabbit_time = 0;
  31.             distance -= rabbit_speed;
  32.         }
  33.         // 判断胜负
  34.         if (distance <= 0) {
  35.             break;
  36.         } else if (distance >= rabbit_speed) { // 如果兔子能够到达终点,则计算领先时间
  37.             rabbit_lead = rabbit_time + (distance / rabbit_speed) * 60 - turtle_time;
  38.         } else { // 如果兔子不能到达终点,则计算剩余距离和时间
  39.             distance -= rabbit_speed;
  40.             rabbit_lead = rabbit_time + (distance / rabbit_speed) * 60 - turtle_time;
  41.         }
  42.     }
  43.     // 输出结果
  44.     printf("赛跑结束!\n");
  45.     printf("乌龟所用时间: %d分钟\n", turtle_time);
  46.     printf("兔子所用时间: %d分钟\n", rabbit_time);
  47.     if (rabbit_lead > 0) { // 如果兔子领先,则输出领先时间,否则输出落败信息
  48.         printf("兔子领先乌龟%d分钟!\n", rabbit_lead);
  49.     } else {
  50.         printf("兔子落败!\n");
  51.     }
  52.     return 0;
  53. }

好的,以下是对该程序的进一步解释:

  1. 在程序的开始部分,我们引入了三个头文件,这些头文件提供了我们需要的一些基本功能:
  1. stdio.h:用于输入和输出操作,例如printf()scanf()函数。
    • stdlib.h:包含了一系列有用的函数和宏,例如rand()函数用于生成随机数。
    • time.h:提供了与时间相关的函数和数据类型,例如time()函数用于获取当前时间。
  1. 我们使用srand()函数初始化随机数生成器。这个函数需要一个种子值,我们使用当前时间作为种子值,这样每次运行程序时生成的随机数都会不同。
  2. 我们定义了一些变量来模拟赛跑的过程:
  1. distance:表示赛跑的距离,初始值为100米。
    • turtle_speed:表示乌龟的速度,每分钟走1米。
    • rabbit_speed:表示兔子的速度,每分钟走5米。
    • turtle_time:表示乌龟所用的时间,初始值为0分钟。
    • rabbit_time:表示兔子所用的时间,初始值为0分钟。
    • rabbit_lead:表示兔子领先的时间,初始值为0分钟。
  1. 在模拟赛跑的过程中,我们使用一个while循环来模拟乌龟和兔子前进的过程。循环条件是赛跑距离大于0米。在循环中:
  1. 乌龟每60分钟走1米,所以我们将turtle_time加1,然后判断是否走到了终点,如果走到了终点,就跳出循环。
    • 兔子每60分钟走5米,所以我们将rabbit_time加1,然后判断是否走到了终点,如果走到了终点,就计算领先时间,然后跳出循环。
  1. 最后,我们输出乌龟和兔子所用的时间以及兔子的领先时间。如果兔子领先,我们输出“兔子领先乌龟XX分钟!”,如果兔子落败,我们输出“兔子落败!”。

这篇关于c语言新龟兔赛跑的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

如何确定 Go 语言中 HTTP 连接池的最佳参数?

确定 Go 语言中 HTTP 连接池的最佳参数可以通过以下几种方式: 一、分析应用场景和需求 并发请求量: 确定应用程序在特定时间段内可能同时发起的 HTTP 请求数量。如果并发请求量很高,需要设置较大的连接池参数以满足需求。例如,对于一个高并发的 Web 服务,可能同时有数百个请求在处理,此时需要较大的连接池大小。可以通过压力测试工具模拟高并发场景,观察系统在不同并发请求下的性能表现,从而

C语言:柔性数组

数组定义 柔性数组 err int arr[0] = {0}; // ERROR 柔性数组 // 常见struct Test{int len;char arr[1024];} // 柔性数组struct Test{int len;char arr[0];}struct Test *t;t = malloc(sizeof(Test) + 11);strcpy(t->arr,

C语言指针入门 《C语言非常道》

C语言指针入门 《C语言非常道》 作为一个程序员,我接触 C 语言有十年了。有的朋友让我推荐 C 语言的参考书,我不敢乱推荐,尤其是国内作者写的书,往往七拼八凑,漏洞百出。 但是,李忠老师的《C语言非常道》值得一读。对了,李老师有个官网,网址是: 李忠老师官网 最棒的是,有配套的教学视频,可以试看。 试看点这里 接下来言归正传,讲解指针。以下内容很多都参考了李忠老师的《C语言非

C 语言基础之数组

文章目录 什么是数组数组变量的声明多维数组 什么是数组 数组,顾名思义,就是一组数。 假如班上有 30 个同学,让你编程统计每个人的分数,求最高分、最低分、平均分等。如果不知道数组,你只能这样写代码: int ZhangSan_score = 95;int LiSi_score = 90;......int LiuDong_score = 100;int Zhou

C 语言的基本数据类型

C 语言的基本数据类型 注:本文面向 C 语言初学者,如果你是熟手,那就不用看了。 有人问我,char、short、int、long、float、double 等这些关键字到底是什么意思,如果说他们是数据类型的话,那么为啥有这么多数据类型呢? 如果写了一句: int a; 那么执行的时候在内存中会有什么变化呢? 橡皮泥大家都玩过吧,一般你买橡皮泥的时候,店家会赠送一些模板。 上

linux中使用rust语言在不同进程之间通信

第一种:使用mmap映射相同文件 fn main() {let pid = std::process::id();println!(