鱼C论坛

 找回密码
 立即注册
查看: 1771|回复: 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行漏个;
#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);
        }
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-10-15 21:12:36 | 显示全部楼层    本楼为最佳答案   
第25行漏个;
#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);
        }
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2022-10-16 09:40:37 | 显示全部楼层
他显示第13行错了,不知道错哪
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-16 17:13

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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