C语言实战演练

简介: C语言实战演练

- LOVE -

完整程序

 

 

 

#include <stdio.h>
#include <math.h>
#include <windows.h>
#include <tchar.h>
float f(float x, float y, float z) {
  float a = x * x + 9.0f / 4.0f * y * y + z * z - 1;
  return a * a * a - x * x * z * z * z - 9.0f / 80.0f * y * y * z * z * z;
}
float h(float x, float z) {
  for (float y = 1.0f; y >= 0.0f; y -= 0.001f)
    if (f(x, y, z) <= 0.0f)
      return y;
  return 0.0f;
}
int main() {
  system("color 0c"); //设计程序颜色
  system("mode con cols=60 lines=28");  //设计控制台大小
  HANDLE o = GetStdHandle(STD_OUTPUT_HANDLE);
  _TCHAR buffer[25][80] = { _T(' ') };
  _TCHAR ramp[] = _T(".:-=+*#%@");
  HWND consoleHandle = GetConsoleWindow();
  // 获取系统屏幕分辨率
  int screenWidth = GetSystemMetrics(SM_CXSCREEN);
  int screenHeight = GetSystemMetrics(SM_CYSCREEN);
  // 获取窗口大小
  RECT consoleRect;
  GetWindowRect(consoleHandle, &consoleRect);
  int consoleWidth = consoleRect.right - consoleRect.left;
  int consoleHeight = consoleRect.bottom - consoleRect.top;
  // 计算窗口应该出现的位置
  int x = (screenWidth - consoleWidth) / 2;
  int y = (screenHeight - consoleHeight) / 2;
  // 使用SetWindowPos函数设置新的窗口位置
  SetWindowPos(consoleHandle, 0, x, y, 0, 0, SWP_NOSIZE | SWP_NOZORDER);
  for (float t = 0.0f;; t += 0.1f) {
    int sy = 0;
    float s = sinf(t);
    float a = s * s * s * s * 0.2f;
    for (float z = 1.3f; z > -1.2f; z -= 0.1f) {
      _TCHAR* p = &buffer[sy++][0];
      float tz = z * (1.2f - a);
      for (float x = -1.5f; x < 1.5f; x += 0.05f) {
        float tx = x * (1.2f + a);
        float v = f(tx, 0.0f, tz);
        if (v <= 0.0f) {
          float y0 = h(tx, tz);
          float ny = 0.01f;
          float nx = h(tx + ny, tz) - y0;
          float nz = h(tx, tz + ny) - y0;
          float nd = 1.0f / sqrtf(nx * nx + ny * ny + nz * nz);
          float d = (nx + ny - nz) * nd * 0.5f + 0.5f;
          *p++ = ramp[(int)(d * 5.0f)];
        } else
          *p++ = ' ';
      }
    }
    for (sy = 0; sy < 25; sy++) {
      COORD coord = { 0, sy };
      SetConsoleCursorPosition(o, coord);
      WriteConsole(o, buffer[sy], 79, NULL, 0);
    }
    Sleep(40);
  }
}

 

 

 

程序分析:

 

这段代码是一个跳动的爱心,使用了数学函数和控制台输出来实现。下面是具体的分析:

 

代码的第3到5行是引入所需要的库文件,其中math.h和windows.h是必须的,而tchar.h是用于处理字符串的。

接下来是代码的主要函数f,它用来计算出一个点在三维空间中的函数值,如果这个值小于等于0,则表明这个点在爱心的表面上。

函数h用来计算在给定的x和z坐标下,最高点的y坐标。

在主函数中,首先设置了程序的颜色和控制台的大小。接着通过GetConsoleWindow()获取控制台的句柄,进而获得控制台的大小和位置,计算出它应该出现的位置,并通过SetWindowPos函数移动控制台窗口到指定位置。

进入主循环后,通过sin函数计算出一个s值,用来控制爱心的缩放。然后通过循环输出每一行的字符,根据每个点的函数值计算出它在爱心表面上的位置并输出相应的字符。最后通过SetConsoleCursorPosition和WriteConsole函数输出到控制台上。

通过Sleep函数让程序等待一段时间,实现爱心跳动的效果。

总的来说,这段代码通过控制台输出的方式,利用函数计算出每一个点在爱心表面上的位置,实现了一个动态的、跳动的爱心效果。

 

 

运行结果

 

 

相关文章
|
4月前
|
存储 人工智能 C语言
数据结构基础详解(C语言): 栈的括号匹配(实战)与栈的表达式求值&&特殊矩阵的压缩存储
本文首先介绍了栈的应用之一——括号匹配,利用栈的特性实现左右括号的匹配检测。接着详细描述了南京理工大学的一道编程题,要求判断输入字符串中的括号是否正确匹配,并给出了完整的代码示例。此外,还探讨了栈在表达式求值中的应用,包括中缀、后缀和前缀表达式的转换与计算方法。最后,文章介绍了矩阵的压缩存储技术,涵盖对称矩阵、三角矩阵及稀疏矩阵的不同压缩存储策略,提高存储效率。
528 8
|
4月前
|
存储 算法 C语言
C语言手撕实战代码_二叉排序树(二叉搜索树)_构建_删除_插入操作详解
这份二叉排序树习题集涵盖了二叉搜索树(BST)的基本操作,包括构建、查找、删除等核心功能。通过多个具体示例,如构建BST、查找节点所在层数、删除特定节点及查找小于某个关键字的所有节点等,帮助读者深入理解二叉排序树的工作原理与应用技巧。此外,还介绍了如何将一棵二叉树分解为两棵满足特定条件的BST,以及删除所有关键字小于指定值的节点等高级操作。每个题目均配有详细解释与代码实现,便于学习与实践。
101 2
|
4月前
|
存储 算法 C语言
C语言手撕实战代码_二叉树_构造二叉树_层序遍历二叉树_二叉树深度的超详细代码实现
这段代码和文本介绍了一系列二叉树相关的问题及其解决方案。其中包括根据前序和中序序列构建二叉树、通过层次遍历序列和中序序列创建二叉树、计算二叉树节点数量、叶子节点数量、度为1的节点数量、二叉树高度、特定节点子树深度、判断两棵树是否相似、将叶子节点链接成双向链表、计算算术表达式的值、判断是否为完全二叉树以及求二叉树的最大宽度等。每道题目均提供了详细的算法思路及相应的C/C++代码实现,帮助读者理解和掌握二叉树的基本操作与应用。
112 2
|
4月前
|
存储 算法 C语言
C语言手撕实战代码_循环单链表和循环双链表
本文档详细介绍了用C语言实现循环单链表和循环双链表的相关算法。包括循环单链表的建立、逆转、左移、拆分及合并等操作;以及双链表的建立、遍历、排序和循环双链表的重组。通过具体示例和代码片段,展示了每种算法的实现思路与步骤,帮助读者深入理解并掌握这些数据结构的基本操作方法。
|
4月前
|
算法 C语言 开发者
C语言手撕实战代码_单链表
本文档详细介绍了使用C语言实现单链表的各种基本操作和经典算法。内容涵盖单链表的构建、插入、查找、合并及特殊操作,如头插法和尾插法构建单链表、插入元素、查找倒数第m个节点、合并两个有序链表等。每部分均配有详细的代码示例和注释,帮助读者更好地理解和掌握单链表的编程技巧。此外,还提供了判断子链、查找公共后缀等进阶题目,适合初学者和有一定基础的开发者学习参考。
|
5月前
|
SQL 缓存 自然语言处理
实战案例1:基于C语言的Web服务器实现。
实战案例1:基于C语言的Web服务器实现。
265 15
|
5月前
|
存储 编译器 数据处理
【编程秘籍】解锁C语言数组的奥秘:从零开始,深入浅出,带你领略数组的魅力与实战技巧!
【8月更文挑战第22天】数组是C语言中存储同类型元素的基本结构。本文从定义出发,详述数组声明、初始化与访问。示例展示如何声明如`int numbers[5];`的数组,并通过下标访问元素。初始化可在声明时进行,如`int numbers[] = {1,2,3,4,5};`,编译器自动计算大小。初始化时未指定的元素默认为0。通过循环可遍历数组,数组名视为指向首元素的指针,方便传递给函数。多维数组表示矩阵,如`int matrix[3][4];`。动态数组利用`malloc()`分配内存,需用`free()`释放以避免内存泄漏。掌握这些技巧是高效数据处理的基础。
82 2
|
6月前
|
C语言
C语言实战 | 弹跳的小球
【7月更文挑战第6天】使用C语言实现了一个小球(小方块)在屏幕上斜向移动并反弹的程序。当小球碰到边界时,其运动方向会发生改变。代码分为三部分,分别处理初始化、主循环和更新位置及边界检测。变量drow和dcol控制移动方向,遇到边界时会反转它们的值。
89 3
C语言实战 | 弹跳的小球
|
5月前
|
移动开发 网络协议 编译器
实战案例3:C语言实现的HTTP服务器
实战案例3:C语言实现的HTTP服务器
381 0
|
6月前
|
存储 编译器 C语言
C语言实战 | “贪吃蛇”游戏
【7月更文挑战第5天】在C语言实战中,本文档介绍了如何构建一个简单的“贪吃蛇”游戏。游戏的核心是控制蛇移动并增长,当吃掉食物时,蛇的身体变长。数据结构使用固定大小的数组表示蛇的位置,变量存储食物位置和蛇的长度。初始化后,利用非阻塞式`getKey()`函数实现WASD键盘控制蛇的运动方向。虽然蛇的边界检测和吃食物后的增长尚未详细说明,但提到了这些问题作为练习留给读者解决,并预告将在后续章节讨论模块化编程以简化复杂代码。
112 0
C语言实战 | “贪吃蛇”游戏

热门文章

最新文章