C语言打印心形图案的多种实现方法
创作时间:
作者:
@小白创作中心
C语言打印心形图案的多种实现方法
引用
CSDN
1.
https://blog.csdn.net/WU9797/article/details/77168963
本文将向你展示如何使用C语言代码打印出各种心形图案。从简单的单个字符心形,到复杂的彩色心形,再到变形的心形图案,每个版本都配有详细的代码示例,部分还附有运行结果的图片。
单个字符的心形图案
#include <stdio.h>
int main(void)
{
float a,x,y;
for(y=1.5f; y>-1.5f; y-=0.1f)
{
for(x=-1.5f; x<1.5f; x+=0.05f)
{
a = x*x+y*y-1;
//这里的@符号即为打印出的心形图案符号,可更改
char ch = a*a*a-x*x*y*y*y<=0.0f?'@':' ';
putchar(ch);
//或者putchar(a*a*a-x*x*y*y*y<=0.0f?'*':' ');
}
printf("\n");
}
return 0;
}
空心版
/* 代码来源于:https://github.com/liuyubobobo/heart-curve-cplusplus/blob/master/main2.cpp */
#include <stdio.h>
#include <math.h>
// The first heart shape in hollow
// (x^2+y^2-1)^3 - x^2*y^3 = 0
// y ~ (-1.1 , 1.3 )
// x ~ (-1.2 , 1.2 )
int main() {
for( float y = 1.3 ; y >= -1.1 ; y -= 0.06 )
{
for( float x = -1.2 ; x <= 1.2 ; x += 0.025 )
{
if( pow((x*x+y*y-1.0),3) - x*x*y*y*y <= 0.0 )
printf(" ");
else
printf("*");
}
printf("\n");
}
return 0;
}
可用多个字符组成打印
#include <stdio.h>

int main(void)
{
float f, x, y, z;
for(y=1.5f; y>-1.5f; y-=0.1f)
{
for(x=-1.5f; x<1.5f; x+=0.05f)
{
z = x*x+y*y-1;
f = z*z*z-x*x*y*y*y;
putchar(f<=0.0f ? "wangxiuhong"[(int)(f*-8.0f)] : ' ');
//这里的wangxiuhong字符可更改成符号或其他字母,汉字不行,图案会变形
}
printf("\n");
}
return 0;
}
加颜色版(Linux平台下可用)
#include <stdio.h>
int main(int argc, char *argv[])
{
float f, x, y, z;
for(y=1.5f; y>-1.5f; y-=0.1f)
{
for(x=-1.5f; x<1.5f; x+=0.05f)
{
z = x*x+y*y-1;
f = z*z*z-x*x*y*y*y;
// ===================================
printf("\033[47m");
char buf[100] = {"happybirthday"};
if (f<=0.0f)
{
printf("\033[1;31m%c\033[0m", buf[(int)(f*-8.0f)]);
}
else
{
printf("%c", ' ');
}
printf("\033[0m");
// =====================================
}
printf("\n");
}
return 0;
}
加强版
#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(int argc, char *argv[])
{
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');
}
}
变形版
/* 作者:知乎用户
链接:https://www.zhihu.com/question/20187195/answer/34478043
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。 */
#include <stdio.h>

int main()
{
int i, j, k, l, m;
char c = '*'; //ASCII码里面 3 就是一个字符小爱心
for (i=1; i<=5; i++) printf("\n"); //开头空出5行
for (i=1; i<=3; i++)
{ //前3行中间有空隙分开来写
for (j=1; j<=32-2*i; j++)
printf(" "); //左边的空格,每下一行左边的空格比上一行少2个 //8*n-2*i
for (k=1; k<=4*i+1; k++)
printf("%c", c);//输出左半部分字符小爱心
for (l=1; l<=13-4*i; l++)
printf(" "); //中间的空格,每下一行的空格比上一行少4个
for (m=1; m<=4*i+1; m++)
printf("%c", c);//输出右半部分字符小爱心
printf("\n"); //每一行输出完毕换行
}
for (i=1; i<=3; i++)
{ //下3行中间没有空格
for (j=1; j<=24+1; j++)
printf(" "); //左边的空格 //8*(n-1)+1
for (k=1; k<=29; k++)
printf("%c", c);//输出字符小爱心
printf("\n"); //每一行输出完毕换行
}
for (i=7; i>=1; i--)
{ //下7行
for (j=1; j<=40-2*i; j++)
printf(" "); //左边的空格,每下一行左边的空格比上一行少2个//8*(n+1)-2*i
for (k=1; k<=4*i-1; k++)
printf("%c", c);//每下一行的字符小爱心比上一行少4个(这个循环是i--)
printf("\n"); //每一行输出完毕换行
}
for (i=1; i<=39; i++)
printf(" "); //最后一行左边的空格
printf("%c\n", c); //最后一个字符小爱心
for (i=1; i<=5; i++)
printf("\n"); //最后空出5行
return 0;
}
算法链接:http://mathworld.wolfram.com/HeartSurface.html
代码主要参考网址:https://www.zhihu.com/question/20187195
热门推荐
绿杨庭院,暖风帘幕,有个人憔悴。
沉香木:珍贵的香料、药材与工艺品原料
白羊座:8个你可能不太了解的特点
大腿内侧起红点的原因是什么?医生专业解析
视频无声?快速排查与恢复声音的方法
浙东运河第一段:从“陡亹”到“斗门”
光伏组件大盘点:类型、特点与应用全解析
燕麦片煮鸡蛋的功效与作用是什么
英超分析技巧:英超联赛因果推断与层次建模分析预测
峨眉山景区内观光车运营时间、停靠站点、路线等介绍
小满到,老传统别丢,牢记做3事,吃2苦,忌1事,顺应时节身体好
厨房里一般应该有哪些调味品 十类家庭厨房必备的基础调料推荐
幸存者偏差与回填偏差:定义、区别及应对策略
什么是“幸存者偏差”?为什么我们总是看不到失败者?
鸡柳是鸡的柳部,那柳部是鸡的哪?
眉毛的生长周期大约是多长时间?
乒乓球世界排名出炉,王楚钦第一,张本智和第三,不如樊振东马龙?
皮秒激光治疗后的饮食禁忌和注意事项
儒家思想的诞生与发展:从春秋战国到宋明理学
如何保护我们脆弱的膝关节?
酒驾与醉驾对子女考公务员政审的影响分析
《龙族》IP新作来袭:动画与手游如何还原经典?
神舟十九号启程太空,天地间如何无缝沟通?上海航天人揭秘通信“神器”
学乐器怎么选:爱好与专业的全方位考量
电脑软件突然打不开了怎么办?原因分析与解决方案
AI时代,中西智慧何为?——上海中西哲学与文化比较研究会2024年学术年会召开
八字命理中的“四大阳刃”究竟指什么
房屋共有权登记所需材料清单
从旅游节目主持人到“比特币女王”,前华人首富背后的女人何一的传奇人生
老年人手臂无力手部麻木的处理方法是什么