Java:利用递归实现分形[通俗易懂]

Java:利用递归实现分形[通俗易懂]Java:利用递归实现分形分形,具有以非整数维形式充填空间的形态特征。通常被定义为“一个粗糙或零碎的分形,具有以非整数维形式充填空间的形态特征。通常被定义为“一个粗糙或零碎的几何形状,可以分成数个部分,且每一部分都(至少近似地)是整体缩小后的形状”,即具有自相似的性质。例如谢尔宾斯基三角形、谢尔宾斯基地毯、康托尔三分集。如何实现分形根据分形的定义我们知道,图形可被分成数个部分,每一部分都是完整图形的缩小版。以康托尔三分集为例,第一条线段被分成三部分,左右两边的部分又继续被分成三部分,如此循环下去。因此

大家好,又见面了,我是你们的朋友全栈君。

分形,具有以非整数维形式充填空间的形态特征。通常被定义为“一个粗糙或零碎的分形,具有以非整数维形式充填空间的形态特征。通常被定义为“一个粗糙或零碎的几何形状,可以分成数个部分,且每一部分都(至少近似地)是整体缩小后的形状”,即具有自相似的性质。例如谢尔宾斯基三角形谢尔宾斯基地毯康托尔三分集

如何实现分形

根据分形的定义我们知道,图形可被分成数个部分,每一部分都是完整图形的缩小版。以康托尔三分集为例,第一条线段被分成三部分,左右两边的部分又继续被分成三部分,如此循环下去。因此我们可以用递归的方法实现分形。

递归

按照套娃的想法来理解,递归算法有三个要素:

  1. 边界条件(出口)

    边界条件决定了何时终止递归,若没有终止条件程序便会一直运行下去或报错。也就是确定最小的娃娃的大小,当娃娃达到边界大小的时候就不能再套了。

  2. 基本内容

    递归的每一次循环动作都是相同的,每个娃娃的模样都一样,只不过都比上一个小了点,我们需要先画出娃娃的模样。

  3. 递归部分

    套娃的递归方式是把下一个娃娃装在此刻这个娃娃的肚子里,同理,在递归函数里我们要继续调用递归函数,这样才能让函数连续调用,一个套一个。

在写递归算法时一定注意,不要试图弄清每一次循环调用之间的关系,只需写好出口和递归部分,让计算机去进行递归。

分形实例:康托尔三分集

//1.边界条件:线段长度<=0时终止
//2.基本内容:画出一条线段,把该线段分为三部分,画出左右部分
//3.递归部分:线段的左右部分重复调用此函数

public void CantorLine(Graphics gr,int x1,int x2,int y) { 
   
    gr.drawLine(x1, y, x2, y);			//画出一条线段:左端点(x1,y) 右端点(x2,y)
    
    int size=(x2-x1)/3;               	//size是线段长度的三分之一
    if(size<=0) { 
    return; }				//出口
    
    int ax=x1+size,bx=x2-size;			
    int cy=y+50;
    gr.drawLine(x1, cy, ax, cy);		//左部分线段以x1、ax为端点
    gr.drawLine(bx, cy, x2, cy);		//右部分线段以bx、x2为端点
    
//以上为基本内容,每一次执行函数都画出了三条线段
//-------------------------------------------------------//
//以下为递归部分,左右两侧的线段再次调用递归函数
    
    CantorLine(gr,x1,ax,cy);
    CantorLine(gr,bx,x2,cy);
    
}

其他分形

谢尔宾斯基三角形

public void SierpinskiTri(Graphics g,int x1,int x2,int y) { 
   
    if(x2-x1<=20) { 
    return; }		//出口
    int ax=(x1+x2)/2,bx=(x1+ax)/2,cx=(ax+x2)/2;
    int dy=y-(x2-x1)/2;
//基本内容
    Triangle(g,x1,x2,y);
    Triangle(g,x1,ax,y);
    Triangle(g,ax,x2,y);
    g.setColor(Color.lightGray);
    fillTri(g,bx,cx,dy,ax,y);
	g.setColor(Color.black);
//递归部分
    SierpinskiTri(g,bx,cx,dy);
    SierpinskiTri(g,x1,ax,y);
    SierpinskiTri(g,ax,x2,y);
}

谢尔宾斯基地毯

public void SierpinskiSqr(Graphics gr,int x1,int x2,int y) { 
   
    int size0=(x2-x1)/3;
    if(size0<=0) { 
    return; }		//出口
    int ax=x1+size0,bx=x2-size0,cy=y+size0;
//基本内容
    gr.fillRect(ax, cy, size0, size0);
//递归部分
    SierpinskiSqr(gr,x1,ax,y);
    SierpinskiSqr(gr,ax,bx,y);
    SierpinskiSqr(gr,bx,x2,y);
    SierpinskiSqr(gr,x1,ax,cy);
    SierpinskiSqr(gr,bx,x2,cy);
    SierpinskiSqr(gr,x1,ax,cy+size0);
    SierpinskiSqr(gr,ax,bx,cy+size0);
    SierpinskiSqr(gr,bx,x2,cy+size0);
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Qt QTreeWidget 详解[通俗易懂]

    Qt QTreeWidget 详解[通俗易懂]一.基础设置1.添加顶层节点//添加顶层节点QTreeWidgetItem*topItem1=newQTreeWidgetItem(ui->treeWidget);topItem1->setText(0,”百度”);ui->treeWidget->addTopLevelItem(topItem1);2.设置表头隐藏,展开所有项//隐藏表头ui->treeWidget->setHeade.

    2022年10月1日
    1
  • 微型计算机课设电梯控制8255,东南大学吴健雄学微机课程设计电梯控制器.doc[通俗易懂]

    微型计算机课设电梯控制8255,东南大学吴健雄学微机课程设计电梯控制器.doc[通俗易懂]东南大学吴健雄学微机课程设计电梯控制器东南大学吴健雄学院《微机实验及课程设计》课程设计报告FBIWarning:汇编代码是好几届之前的一个学姐的只是修改了一下后完美运行是我自己写的不需要注明出处,就说是你写的专业:吴健雄学院实验室:计算机硬件实验室组别:同组人员:设计时间:2012年5月17日…

    2022年5月4日
    40
  • 2021.4激活码(破解版激活)

    2021.4激活码(破解版激活),https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月16日
    46
  • java中sort排序_数据结构算法总结

    java中sort排序_数据结构算法总结数组Sort排序正序排序:Arrays.sort(array),会检查数组个数大于286且连续性好就使用归并排序,若小于32使用插入排序,其余情况使用快速排序int[]array={10,3,6,1,4,5,9};Arrays.sort(array);降序排序:先将数组Arrays.asList()转为集合,然后使用Collections.reverse()反转集合,注意如果是基础数据类型(不是数据包装类),不能使用Arrays.asList()方法可以使用Guava的Int..

    2022年8月12日
    11
  • navicat15 mac 激活码【2021.7最新】

    (navicat15 mac 激活码)好多小伙伴总是说激活码老是失效,太麻烦,关注/收藏全栈君太难教程,2021永久激活的方法等着你。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.htmlMLZPB5EL5Q-eyJsaWNlbnNlSWQi…

    2022年3月21日
    213
  • 大数据spark、hadoop、hive、hbase面试题及解析[通俗易懂]

    大数据spark、hadoop、hive、hbase面试题及解析[通俗易懂](1)spark运行流程、源码架构(2)Hbase主键设计、hbase为何这么快?主键设计:1.生成随机数、hash、散列值2.字符串反转3.字符串拼接hbase为何快:https://blog.csdn.net/sghuu/article/details/102955969(3)Hbase读写流程,数据compact流程hbase读写流程:https://blog.csdn.n…

    2022年5月31日
    35

发表回复

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

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