概述
#include <stdio.h> int main() { for (float y = 1.5f; y > -1.5f; y -= 0.1f) { for (float x = -1.5f; x < 1.5f; x += 0.05f) { float z = x * x + y * y - 1; float f = z * z * z - x * x * y * y * y; putchar(f <= 0.0f ? ".:-=+*#%@"[(int)(f * -8.0f)] : ' '); } putchar('n'); } }
#include <stdio.h> int main() { for (float y = 1.5f; y > -1.5f; y -= 0.1f) { for (float x = -1.5f; x < 1.5f; x += 0.05f) { float z = x * x + y * y - 1; float f = z * z * z - x * x * y * y * y; putchar(f <= 0.0f ? ".:-=+*#%@"[(int)(f * -8.0f)] : ' '); } putchar('n'); } }
#include <stdio.h> #include <math.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() { for (float z = 1.5f; z > -1.5f; z -= 0.05f) { for (float x = -1.5f; x < 1.5f; x += 0.025f) { float v = f(x, 0.0f, z); if (v <= 0.0f) { float y0 = h(x, z); float ny = 0.01f; float nx = h(x + ny, z) - y0; float nz = h(x, z + ny) - y0; float nd = 1.0f / sqrtf(nx * nx + ny * ny + nz * nz); float d = (nx + ny - nz) * nd * 0.5f + 0.5f; putchar(".:-=+*#%@"[(int)(d * 5.0f)]); } else putchar(' '); } putchar('n'); } }
#include <math.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() { FILE* fp = fopen("heart.ppm", "w"); int sw = 512, sh = 512; fprintf(fp, "P3n%d %dn255n", sw, sh); for (int sy = 0; sy < sh; sy++) { float z = 1.5f - sy * 3.0f / sh; for (int sx = 0; sx < sw; sx++) { float x = sx * 3.0f / sw - 1.5f; float v = f(x, 0.0f, z); int r = 0; if (v <= 0.0f) { float y0 = h(x, z); float ny = 0.001f; float nx = h(x + ny, z) - y0; float nz = h(x, z + ny) - y0; float nd = 1.0f / sqrtf(nx * nx + ny * ny + nz * nz); float d = (nx + ny - nz) / sqrtf(3) * nd * 0.5f + 0.5f; r = (int)(d * 255.0f); } fprintf(fp, "%d 0 0 ", r); } fputc('n', fp); } fclose(fp); }
#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); } }
#include<stdio.h> #include <Windows.h> #include <math.h> #define Maxnum 1800 #define PI 3.1415926 int Nownum; char *buff[Maxnum]; void main() { void SetToNum(int SetNum);//300M 每格子 共9个格子 Nownum=0; int ix;ix=0; DWORD startTime = 0; double x=-1.11; double y=0; startTime = GetTickCount(); //毫秒数 while(1) { if ( ((GetTickCount() - startTime)%1000) <= 100){ if (ix%2==1){ y=((pow(abs(x),2.0/3)+sqrt(pow(abs(x),4.0/3)-4*(x*x-1)))/2);// x^(2)^(1/3)/2+sqrt(x^(4)^(1/3)-4*(x^2-1))/2;//y+ } else{ y=((pow(abs(x),2.0/3)-sqrt(pow(abs(x),4.0/3)-4*(x*x-1)))/2);// x^(2)^(1/3)/2-sqrt(x^(4)^(1/3)-4*(x^2-1))/2;//y- } SetNum=(int)Maxnum/2*(1+y/1.3); SetToNum(SetNum); x=x+0.1;ix++; if (x>1.11){SetNum=0;SetToNum(SetNum);x=-1.11;printf("Pauseing:10sn");Sleep(10000);} printf("Nownum:%d(%f)n" ,Nownum,x); } } } void SetToNum(int SetNum) { if (SetNum>Maxnum){printf("Error:SetNum>MaxNum!n");return;} if (Nownum<SetNum) { for (Nownum++;Nownum<=SetNum;Nownum++) { buff[Nownum]= new char[1024*1024]; } Nownum--; } else if (Nownum>SetNum) { for (;Nownum>SetNum;Nownum--) { delete buff[Nownum]; } } }
文章来源:https://www.zhihu.com/people/miloyip/activities
转载于:https://www.cnblogs.com/LyShark/p/9064141.html
最后
以上就是花痴秋天为你收集整理的C++命令行画心形<转载>的全部内容,希望文章能够帮你解决C++命令行画心形<转载>所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复