初学编程的小伙伴肯定有过这样一个想法,就是我能不能利用代码来输出一个特定的图案呢?比如一个爱心?那必然是可以的,代码能实现的功能很多,这只是其中的一小小用法。以下是思路与代码。
方法一
暴力解法:
我们可以先画出一个正方形,然后,随后我们可以在这个正方形的范围内画出一个爱心图案,最后将爱心图案所涉及到的点一个一个标记起来,最后在有标记点的地方输出小爱心,没有标记点的地方输出空白。这样就能在屏幕上输出一个爱心图案了。
例如:这里我选择的是,使用网格图来作为载体,这样更好进行标记点的位置,也便于代码实现
Java代码实现
注:由于在Java中引用数据类型的默认值为 0 ,所以我们只需要将特定的位置赋值为1起到标记的作用,无需标记其他位置。代码中说的行列是以上面图像作为基础的
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,注释是自己添加的,本人数学比较差,属实是没想出来怎么用数学公式解这题。
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(); }}}
运行效果
总结
使用公式法解,图像优化了很多,且语法也并不复杂,只是对数学不太感冒的人来说不够友好,例如我,但这的确是我所了解到的最优解了。所以想要写出更好更优美的代码,还是要学好用好数学。在此,吾与诸君共勉之。
感谢各位的阅读,如有错误,欢迎指出。
来源地址:https://blog.csdn.net/Lion__king/article/details/129201751