<C语言>如何使用C语言代码打印“心形”图案?

<C语言>如何使用C语言代码打印“心形”图案?作者:wsg时间;2017年8月14日//版本一:单个字符的心形图案#includeintmain(void){ floata,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; //这里的@符号即为打印出的心形图案符号,可更

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

作者:wsg

时间;2017年8月14日

//版本一:单个字符的心形图案
#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;
}

<C语言>如何使用C语言代码打印“心形”图案?

空心版:

/* 代码来源于: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;
}

<C语言>如何使用C语言代码打印“心形”图案?

//版本二:可用多个字符组成打印
#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;
}

<C语言>如何使用C语言代码打印“心形”图案?

加颜色版,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;  
}  

<C语言>如何使用C语言代码打印“心形”图案?

加强版:

#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');
    }
}

<C语言>如何使用C语言代码打印“心形”图案?

变形版:

/* 作者:知乎用户
链接: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;
}

<C语言>如何使用C语言代码打印“心形”图案?

算法链接:http://mathworld.wolfram.com/HeartSurface.html
 

代码主要参考网址:https://www.zhihu.com/question/20187195

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/159466.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月26日 上午11:00
下一篇 2022年7月26日 上午11:16


相关推荐

  • 昆仑万维天工超级智能体APP上线后爆火!全球首款Office智能体APP,开启AI办公新时代

    昆仑万维天工超级智能体APP上线后爆火!全球首款Office智能体APP,开启AI办公新时代

    2026年3月16日
    3
  • C语言实现光栅化实现过程,为什么要光栅化?怎么实现光栅化方法?

    C语言实现光栅化实现过程,为什么要光栅化?怎么实现光栅化方法?描述光栅化是在计算机上生成图像的重要步骤 然而无论是 opengl 还是 directx 还是其他的图形接口都封装了光栅化方法 我自己做了个光栅器 接下来就说一下怎样实现光栅化的 为什么要光栅化 图形管线的输入是图元顶点 输出的则是像素 pixel 这个步骤其中还有个中间产物叫做片段 fragment 一个片段相应一个像素 但片段比像素多了用于计算的属性 比如 深度值和法向量 通过片段能够计算出终于将

    2026年3月26日
    3
  • apache的安装教程详解_怎么安装apache

    apache的安装教程详解_怎么安装apache文章目录1、下载Apache2、修改httpd.conf文件3、启动Apache服务1、下载Apache点击:[https://www.apachehaus.com/cgi-bin/download.plx]点击图中红圈的版本下载:下载后,解压文件,把如图这两个文件拿出来放到你的Apache目录下例如:我的放到D盘,如图:2、修改httpd.conf文件在文件夹中查…

    2026年2月7日
    3
  • reentrantlock_lock condition

    reentrantlock_lock conditionReentrantLock锁的底层实现已经阐述过了,那么如何使用,本文进行下样例展示,主要说两个功能:1.lock及中断,2.申请等待时间;lock锁/***@Description:*@author:Erick*@version:1.0*@time:2018-9-25*/publicclassReentrantLockThreadimple…

    2022年10月11日
    9
  • phpstorm激活码2022.01(注册激活)

    (phpstorm激活码2022.01)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年4月1日
    177
  • 汉诺塔递归算法流程图_汉诺塔算法递归表达式

    汉诺塔递归算法流程图_汉诺塔算法递归表达式(5)练习3—汉诺塔(Hanoi)编程实现把A的n个盘子移动到C(盘子编号是[1,n])每次只能移动1个盘子大盘子只能放在小盘子下面1、汉诺塔—1个盘子2、汉诺塔—2个盘子3、汉诺塔—3个盘子3、汉诺塔—思路其实分2种情况讨论即可(1)当n==1时,直接将盘子从A移动到C(2)当n>1时,可以拆分成3大步骤①将n–1个盘子从A移动到B②将编号为n的盘子从A移动到C③将n–1个盘子从B移动到C

    2025年8月5日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号