用C语言实现牛顿摆控制台动画

news2024/10/7 10:20:04

题目

用C语言实现牛顿摆动画,模拟小球的运动,如图所示

用C语言实现牛顿摆动画

用C语言实现牛顿摆动画
用C语言实现牛顿摆动画

拆解

  1. 通过控制台API定位输出小球
  2. 运动的只是2边小球,中间小球不运动,只需要固定位置输出
  3. 左边小球上升下降时,X、Y轴增量一致。
  4. 右边小球上升下降时,X、Y轴增量相反。

代码

#include <stdbool.h> // bool类型头文件
#include <stdio.h>
#include <windows.h>
#include <conio.h>

#define CONSOLEWIDTH 80  // 控制台宽度
#define CONSOLEHEIGHT 40 // 控制台高度

// 坐标结构
typedef struct _point
{
    short X;
    short Y;
} Point;

// 控制台相关

/// @brief  设置光标位置,起点从1开始
/// @param nCols 列
/// @param nRows 行
void MoveCursorTo(int nCols, int nRows)
{
    COORD crdLocation = {nCols, nRows};
    HANDLE HOutput = GetStdHandle(STD_OUTPUT_HANDLE); // 获取标准输出的句柄
    SetConsoleCursorPosition(HOutput, crdLocation);   // 设置光标位置
}

/// @brief  设置控制台大小
/// @param uCol 列
/// @param nRows 行
void SetConsoleSize(unsigned uCol, unsigned nRows)
{
    char cmd[64];
    sprintf(cmd, "mode con cols=%d lines=%d", uCol, nRows);
    system(cmd);
}

//

#define NODECOUNT 6 // 小球数量
#define STARTNUM 4  // 小球大小

/// @brief 绘制小球
/// @param pos 小球位置
void printNode(Point pos)
{
    int i;
    MoveCursorTo(pos.X, pos.Y);
    for (i = 0; i < STARTNUM; i++)
        printf("*");

    MoveCursorTo(pos.X, pos.Y + 1);
    printf("*");
    for (i = 0; i < STARTNUM - 2; i++)
        printf(" ");
    printf("*");

    MoveCursorTo(pos.X, pos.Y + 2);
    for (i = 0; i < STARTNUM; i++)
        printf("*");
}

/// @brief 绘制中间不动的小球
/// @param pos 绘制位置
void printMid(Point pos)
{
    for (int i = 0; i < NODECOUNT - 1; i++)
    {
        printNode(pos);
        pos.X += STARTNUM + 1;
    }
}

int main()
{
    SetConsoleSize(CONSOLEWIDTH, CONSOLEHEIGHT); // 设置控制台大小

    Point lpos, rpos, orign;
    bool isLeft = true; // 左球标记

    orign.X = (CONSOLEWIDTH - STARTNUM * NODECOUNT) / 2; // 居中输出
    orign.Y = (CONSOLEHEIGHT - 5) / 2;

    int step = 5; // 运动步数
    int l = 0, r = 0, flag = 1;

    lpos = rpos = orign;
    lpos.X -= (STARTNUM + 1) + step; // 左球起始定位
    lpos.Y -= step;

    rpos.X += (STARTNUM + 1) * (NODECOUNT - 2); // 右球起始定位

    while (true)
    {
        if (_kbhit()) // 按任意键退出
            break;

        system("cls");

        if (isLeft)
        { // 左球运动
            lpos.X += flag;
            lpos.Y += flag;

            printNode(lpos); // 绘制小球
            printMid(orign); // 绘制中间不动的小球

            l += flag;
            if (l == step) // 左球碰撞
            {
                isLeft = false;
                flag = -1; // 标记右球起始运动
            }
            if (l == 0) // 左球到达顶点
                flag = 1;
        }
        else
        {                    // 右球运动
            rpos.X += -flag; // 右球运动时X与Y增量相反
            rpos.Y += flag;

            printNode(rpos);
            printMid(lpos);

            r += -flag;
            if (r == step) // 右球到达顶点
                flag = 1;

            if (r == 0) // 右球碰撞
            {
                isLeft = true;
                flag = -1;
            }
        }

        Sleep(300); // 运动速度,数字越小越快
    }

    return 0;
}

运行结果

用C语言实现牛顿摆动画

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

解决在远程连接的linux服务器上调用matplotlib画图的问题

前言&#xff1a; 我遇到这个问题的时候&#xff0c;在知乎上看到了一个回答&#xff0c;结果评论区看到了一个最简洁的解。 https://zhuanlan.zhihu.com/p/346384579 效果 左边是代码&#xff0c;右边是结果&#xff0c;弊处就是有点慢。 安装步骤 1. 安装插件 在代码处…

荣威 D7 正式亮相,新能源江湖再战

在 2023 成都车展上&#xff0c;荣威回归轿车领域的全新车型——D7 正式亮相。新车将推出纯电和插混的版本。 一、内饰实拍 内饰方面&#xff0c;这也是荣威 D7 的首次开门。可以看到&#xff0c;荣威 D7 将采用类似三联屏的设计&#xff0c;实际采用的是双 12.3 英寸液晶屏。…

linux 多重启动grub2详解

https://www.gnu.org/software/grub/manual/grub/grub.pdf

Revit SDK 介绍:ManipulateForm 体量族的修改

前言 这个例子介绍体量族的修改。包含了创建体量&#xff0c;用API 移动体量族的顶点、边、轮廓&#xff08;面&#xff09;。 内容 效果分步骤展示。 整理&#xff1a; 核心逻辑 创建拉伸体 m_revitDoc.FamilyCreate.NewLoftForm(true, profiles)增加一个截面 form.Add…

解释一下Kubernetes Minikube是什么,以及如何在本地运行一个Minikube集群

文章目录 步骤1&#xff1a;准备环境步骤2&#xff1a;安装和配置Minikube步骤3&#xff1a;验证集群状态步骤4&#xff1a;部署一个示例应用创建一个Deployment部署应用检查部署 步骤5&#xff1a;访问应用获取Minikube IP地址&#xff1a;获取Service的NodePort&#xff1a; …

SEO百度优化基础知识全解析(了解百度SEO标签作用)

百度SEO优化的作用介绍&#xff1a; 百度SEO优化是指通过对网站的内部结构、外部链接、内容质量、用户体验等方面进行优化&#xff0c;提升网站在百度搜索结果中的排名&#xff0c;从而提高网站的曝光率和流量。通过百度SEO优化&#xff0c;可以让更多的潜在用户找到你的网站&…

提升 Markdown 文档协作:Let‘s Markdown介绍与部署

在当今数字化的世界中&#xff0c;我们经常需要分享文本和文档。Markdown 是一种流行的轻量级标记语言&#xff0c;用于格式化文本和创建文档。但是&#xff0c;有时在不同的平台和编辑器之间共享和处理 Markdown 文档可能会带来一些麻烦。为了解决这些问题&#xff0c;诞生了 …

21 Spring Boot整合Redis

一、Redis简介 简单来说 Redis 就是一个使用 C 语言开发的数据库&#xff0c;不过与传统数据库不同的是 Redis 的数据是存在内存中的 &#xff0c;也就是它是内存数据库&#xff0c;所以读写速度非常快&#xff0c;因此 Redis 被广泛应用于缓存方向。 另外&#xff0c;Redis 除…

第5篇 vue的通信框架axios和ui框架-element-ui以及node.js

一 axios的使用 1.1 介绍以及作用 axios是独立于vue的一个项目&#xff0c;基于promise用于浏览器和node.js的http客户端。 在浏览器中可以帮助我们完成 ajax请求的发送在node.js中可以向远程接口发送请求 1.2 案例 二 element-ui组件 1.1 ui组件库 element-ui 是饿了么…

Unity 之 使用定时调用与Update 正常帧更新的运行答疑

文章目录 疑惑代码辨析具体解释 疑惑 就是说&#xff0c;当我们在Start 函数里面定义了一个InvokeRepeating 函数&#xff0c;那么我们又在Update 定义了一个基本操作&#xff0c;想联合控制物体一个往返的一个运动时&#xff0c;我们应该怎么办&#xff1f; 就是说系统是怎么…

【2023数学建模国赛】A题定日镜场的优化设计模型建立

2023年全国大学生数学建模竞赛A题定日镜场的优化设计&#xff0c;目前已写出第四版国赛A题思路和模型详细公式&#xff0c;目录如下&#xff1a; 一、 问题重述... 1 二、 问题分析... 1 三、 模型假设... 6 四、 问题一模型的建立和求解... 6 4.1 定日镜场坐标系的建立...…

安全测试 —— 你了解WEB安全测试吗?

&#x1f60f;作者简介&#xff1a;博主是一位测试管理者&#xff0c;同时也是一名对外企业兼职讲师。 &#x1f4e1;主页地址&#xff1a;【Austin_zhai】 &#x1f646;目的与景愿&#xff1a;旨在于能帮助更多的测试行业人员提升软硬技能&#xff0c;分享行业相关最新信息。…

UG\NX二次开发 已知3x3矩阵分别求XYZ方向 UF_MTX3_x_vec、UF_MTX3_y_vec、UF_MTX3_z_vec

文章作者:里海 来源网站:王牌飞行员_里海_里海NX二次开发3000例,里海BlockUI专栏,C\C++-CSDN博客 简介: UG\NX二次开发 已知3x3矩阵分别求XYZ方向 UF_MTX3_x_vec、UF_MTX3_y_vec、UF_MTX3_z_vec 效果: 代码: #include "me.hpp"void ufusr(char* param,…

我眼中的《视觉测量技术基础》

为什么会写这篇博客&#xff1a; 首先给大家说几点&#xff1a;看我的自我介绍对于学习这本书没有任何帮助&#xff0c;如果你是为了急切的想找一个视觉测量的解决方案那可以跳过自我介绍往下看或者换一篇博客看看&#xff0c;如果你是刚入门想学习计算机视觉的同学&#xff0…

YOLOv8 目标检测及图片裁剪

前言 之前我们已经训练了识别是否佩戴口罩的模型文件&#xff0c;可以有效识别人群是否口罩&#xff0c;本文将会讲解如何将识别到的目标裁剪出来 目标识别 需要指定 save_txtTrue&#xff0c;保存数据标注文件 txt yolo predict modelruns/detect/train26/weights/best.pt…

一文带你快速入门『YOLOv8』

前言 本文是 YOLOv8 入门指南&#xff08;大佬请绕过&#xff09;&#xff0c;将会详细讲解安装&#xff0c;配置&#xff0c;训练&#xff0c;验证&#xff0c;预测等过程 YOLOv8 官网&#xff1a;ultralytics/ultralytics: NEW - YOLOv8 &#x1f680; in PyTorch > ONN…

AjaxJavaScriptcss模仿百度一下模糊查询功能

1、效果 如下图所示&#xff0c;我们在输入大学时&#xff0c;程序会到后端查询名字中包含大学的数据&#xff0c;并展示到前端页面。 用户选择一个大学&#xff0c;该大学值会被赋值到input表单&#xff0c;同时关闭下拉表单&#xff1b; 当页面展示的数据都不符合条件时&…

华为云云耀云服务器L实例评测|基于云服务器的minio部署手册

华为云云耀云服务器L实例评测|基于云服务器的minio部署手册 【软件安装版本】【集群安装&#xff08;是&#xff09;&#xff08;否&#xff09;】 版本 创建人 修改人 创建时间 备注 1.0 jz jz 2023.9.2 minio华为云耀服务器 一. 部署规划与架…

Python程序设计实例 | 条形码图片识别

* 本系列推文案例中&#xff0c;建议Python采用3.10及以上版本&#xff0c;NumPy采用1.22.3及以上版本&#xff0c;Matplotlib采用3.5.1及以上版本&#xff0c;Pandas采用1.4.2及以上版本。Python从3.10这个版本开始&#xff0c;标准发行版本中自带的IDLE交互式环境中输入提示符…

腾讯云和阿里云2核2G服务器租用价格表对比

2核2G云服务器可以选择阿里云服务器或腾讯云服务器&#xff0c;腾讯云轻量2核2G3M带宽服务器95元一年&#xff0c;阿里云轻量2核2G3M带宽优惠价108元一年&#xff0c;不只是轻量应用服务器&#xff0c;阿里云还可以选择ECS云服务器u1&#xff0c;腾讯云也可以选择CVM标准型S5云…