鱼C论坛

 找回密码
 立即注册
查看: 2199|回复: 2

[已解决]这个代码错在哪,用的编译器是dev cc++ 5.11

[复制链接]
发表于 2022-10-15 20:48:44 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
#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() {
        HANDLE o = GetStdHandle(STD_OUTPUT_HANDLE);
        _TCHAR buffer[25][80] = { _T(' ') };
        _TCHAR ramp[] = _T(".:-=+*#%@");
       
        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(33);
        }
}
最佳答案
2022-10-15 21:12:36
第25行漏个;
  1. #include <stdio.h>
  2. #include <math.h>
  3. #include <windows.h>
  4. #include <tchar.h>

  5. float f(float x, float y, float z) {
  6.         float a = x * x + 9.0f / 4.0f * y * y + z * z - 1;
  7.         return a * a * a - x * x * z * z * z - 9.0f / 80.0f * y * y * z * z * z;
  8. }

  9. float h(float x, float z)
  10. {
  11.         for (float y = 1.0f; y >= 0.0f; y -= 0.001f)
  12.                 if (f(x, y, z) <= 0.0f)
  13.                         return y;
  14.         return 0.0f;
  15. }
  16. int main() {
  17.         HANDLE o = GetStdHandle(STD_OUTPUT_HANDLE);
  18.         _TCHAR buffer[25][80] = { _T(' ') };
  19.         _TCHAR ramp[] = _T(".:-=+*#%@");
  20.       
  21.         for (float t = 0.0f;; t += 0.1f) {
  22.                 int sy =0;
  23.                 float s = sinf(t);  // 这里漏个;
  24.                 float a = s*s*s*s*0.2f;
  25.                 for (float z = 1.3f; z > -1.2f; z -= 0.1f) {
  26.                         _TCHAR* p = &buffer[sy++][0];
  27.                         float tz = z * (1.2f - a);
  28.                         for (float x = -1.5f; x < 1.5f; x += 0.05f) {
  29.                                 float tx = x * (1.2f + a);
  30.                                 float v = f(tx, 0.0f, tz);
  31.                                 if (v <= 0.0f) {
  32.                                         float y0 = h(tx, tz);
  33.                                         float ny = 0.01f;
  34.                                         float nx = h(tx + ny, tz) - y0;
  35.                                         float nz = h(tx, tz + ny) - y0;
  36.                                         float nd = 1.0f / sqrtf(nx * nx + ny * ny +nz * nz);
  37.                                         float d = (nx + ny -nz) * nd * 0.5f + 0.5f;
  38.                                         *p++ = ramp[(int)(d * 5.0f)];      
  39.                                 }
  40.                                 else
  41.                                         *p++ = ' ' ;
  42.                         }
  43.                 }
  44.                
  45.                 for (sy = 0; sy < 25; sy++) {
  46.                         COORD coord = { 0, sy };
  47.                         SetConsoleCursorPosition(o, coord);
  48.                         WriteConsole(o, buffer[sy], 79, NULL, 0);
  49.                 }
  50.                 Sleep(33);
  51.         }
  52. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-10-15 21:12:36 | 显示全部楼层    本楼为最佳答案   
第25行漏个;
  1. #include <stdio.h>
  2. #include <math.h>
  3. #include <windows.h>
  4. #include <tchar.h>

  5. float f(float x, float y, float z) {
  6.         float a = x * x + 9.0f / 4.0f * y * y + z * z - 1;
  7.         return a * a * a - x * x * z * z * z - 9.0f / 80.0f * y * y * z * z * z;
  8. }

  9. float h(float x, float z)
  10. {
  11.         for (float y = 1.0f; y >= 0.0f; y -= 0.001f)
  12.                 if (f(x, y, z) <= 0.0f)
  13.                         return y;
  14.         return 0.0f;
  15. }
  16. int main() {
  17.         HANDLE o = GetStdHandle(STD_OUTPUT_HANDLE);
  18.         _TCHAR buffer[25][80] = { _T(' ') };
  19.         _TCHAR ramp[] = _T(".:-=+*#%@");
  20.       
  21.         for (float t = 0.0f;; t += 0.1f) {
  22.                 int sy =0;
  23.                 float s = sinf(t);  // 这里漏个;
  24.                 float a = s*s*s*s*0.2f;
  25.                 for (float z = 1.3f; z > -1.2f; z -= 0.1f) {
  26.                         _TCHAR* p = &buffer[sy++][0];
  27.                         float tz = z * (1.2f - a);
  28.                         for (float x = -1.5f; x < 1.5f; x += 0.05f) {
  29.                                 float tx = x * (1.2f + a);
  30.                                 float v = f(tx, 0.0f, tz);
  31.                                 if (v <= 0.0f) {
  32.                                         float y0 = h(tx, tz);
  33.                                         float ny = 0.01f;
  34.                                         float nx = h(tx + ny, tz) - y0;
  35.                                         float nz = h(tx, tz + ny) - y0;
  36.                                         float nd = 1.0f / sqrtf(nx * nx + ny * ny +nz * nz);
  37.                                         float d = (nx + ny -nz) * nd * 0.5f + 0.5f;
  38.                                         *p++ = ramp[(int)(d * 5.0f)];      
  39.                                 }
  40.                                 else
  41.                                         *p++ = ' ' ;
  42.                         }
  43.                 }
  44.                
  45.                 for (sy = 0; sy < 25; sy++) {
  46.                         COORD coord = { 0, sy };
  47.                         SetConsoleCursorPosition(o, coord);
  48.                         WriteConsole(o, buffer[sy], 79, NULL, 0);
  49.                 }
  50.                 Sleep(33);
  51.         }
  52. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2022-10-16 09:40:37 | 显示全部楼层
他显示第13行错了,不知道错哪
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-23 11:37

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表