Java代码输出心形图案

初学编程的小伙伴肯定有过这样一个想法,就是我能不能利用代码来输出一个特定的图案呢?比如一个爱心?那必然是可以的,代码能实现的功能很多,这只是其中的一小小用法。以下是思路与代码。

方法一

暴力解法

我们可以先画出一个正方形,然后,随后我们可以在这个正方形的范围内画出一个爱心图案,最后将爱心图案所涉及到的点一个一个标记起来,最后在有标记点的地方输出小爱心,没有标记点的地方输出空白。这样就能在屏幕上输出一个爱心图案了。

例如:这里我选择的是,使用网格图来作为载体,这样更好进行标记点的位置,也便于代码实现

Java代码实现

注:由于在Java中引用数据类型的默认值为 0 ,所以我们只需要将特定的位置赋值为1起到标记的作用,无需标记其他位置。代码中说的行列是以上面图像作为基础的

java 复制代码
public class test {
    public static void main(String[] args) {
        //根据图像要求,创建一个行长为12,列长为13的二维数组
        int[][] arr=new int[12][13];
        //第一行像素点的赋值
        for(int i=2,j=10; i<5; ++i,--j){
            arr[0][i]=1;
            arr[0][j]=1;
        }
        //第二行像素点的赋值
        int index=1;
        arr[index][1]=1;
        arr[index][5]=1;
        arr[index][11]=1;
        arr[index][7]=1;

        //中间独自一个的格子
        int n=arr[0].length;
        arr[index+1][(n-1)/2]=1;

        //第二行到第五行像素点的赋值
        int i;
        for(i=2; i<6; ++i){
            arr[i][0]=1;
            arr[i][n-1]=1;
        }
        //第六行到最后一行的格子
        int left=1;
        int right=n-2;
        for(; i<arr.length; ++i){
            arr[i][left++]=1;
            arr[i][right--]=1;
        }

        //内部填满
        InternalMarkup(arr);

        //输出函数
        Effect_Output(arr);
    }

    //将爱心内部填满
    public static void InternalMarkup(int[][] arr){

        for(int i=1; i<arr.length; ++i){
            //寻找左边界
            int left=0;
            while(arr[i][left++] == 0);
            //寻找右边界
            int right=arr[i].length-1;
            while(arr[i][right--] == 0);

            //左右边界内的格子标记为 1 ,爱心内部填满
            while(left <= right){
                arr[i][left]=1;
                arr[i][right]=1;
                ++left;
                --right;
            }
        }

        //第一行中间格子需要为零
        arr[1][arr[1].length/2]=0;
        return;
    }

    //按传递的参数输出爱心图案
    public static void Effect_Output(int[][] arr){
        //爱心符号的unicode码
        char target='\u2764';
        for(int i=0; i<arr.length; ++i){
            for(int j=0; j<arr[i].length; ++j){
                //判断该下标的值是否为 1 ,是则输出爱心图案,反之输出空格
                if(arr[i][j] == 1){
                    System.out.print(target+" \t");
                } else{
                    System.out.print(" \t");
                }
            }
            System.out.println();   //换行
        }
    }

运行效果

总结

虽然使用暴力解法,语法变得更简单,但是输出的图像还是太过于生硬了。

方法二

数学公式解法

相信很多人都听说过笛卡尔方程的故事,该方程图形显现出来确实一个心形图像。公式:(X²×Y²-1)³ - X²×Y³=0;

图像

该图片来自网络,侵删

Java代码实现

注:**以下代码部分来自知乎,怎么用JAVA打出来小爱心~~~? - 木木编程的回答 - 知乎https://www.zhihu.com/question/352773471/answer/2494438152**,注释是自己添加的,本人数学比较差,属实是没想出来怎么用数学公式解这题。

java 复制代码
public class test
{
	public static void main(String[] args)
	{
        //需要使用浮点数进行运算
        float x,y;
        //y轴控制的是图像的长度,因为图像打印是由上往下打印,根据图像y从正数开始
        //其中递减的值是可由实际情况调整
        for(y=1.3f; y>-1.1f; y-=0.15f){
            //x轴控制的是图像的宽度,自左向右打印,根据图像x从负数开始
            for(x=-1.2f; x<=1.2f; x+=0.05f){
                //使用中间变量代替较长的运算
                float temp=x*x+y*y-1;
                //pow方法作用是获取x的n次方,第一个参数为x,第二个参数为n
                if( (Math.pow(temp,3) - (x*x*Math.pow(y,3) )) <= 0.0f){
                    //由于unicode码不好进行对齐,所以这里使用 * 号代替
                    System.out.print("*");
                }else{
                    //输出空格
                    System.out.print(" ");
                }
            }
            //换行
            System.out.println();
        }
	}
}

运行效果

总结

使用公式法解,图像优化了很多,且语法也并不复杂,只是对数学不太感冒的人来说不够友好,例如我,但这的确是我所了解到的最优解了。所以想要写出更好更优美的代码,还是要学好用好数学。在此,吾与诸君共勉之。

感谢各位的阅读,如有错误,欢迎指出。

相关推荐
五行星辰11 分钟前
Java链接redis
java·开发语言·redis
编程毕设11 分钟前
【含文档+PPT+源码】基于微信小程序的在线考试与选课教学辅助系统
java·微信小程序·小程序
邪恶的贝利亚12 分钟前
C++之序列容器(vector,list,dueqe)
开发语言·c++
原来是猿12 分钟前
蓝桥备赛(13)- 链表和 list(上)
开发语言·数据结构·c++·算法·链表·list
异常驯兽师14 分钟前
Java集合框架深度解析:List、Set与Map的核心区别与应用指南
java·开发语言·list
项目申报小狂人25 分钟前
高性能算法NGO!北方苍鹰优化算法(Northern Goshawk Optimization,NGO)
算法·数学建模
且听风吟ayan36 分钟前
leetcode day26 重复的子字符串
算法·leetcode·c#
A boy CDEF girl36 分钟前
【JavaEE】定时器
java·java-ee
仟濹1 小时前
【算法 C/C++】二维差分
c语言·c++·算法
*星星之火*1 小时前
【GPT入门】第9课 思维树概念与原理
gpt·算法·深度优先