当前位置: 首页 > article >正文

递归分形!

递归分形递归的基础递归是一种编程思想核心是函数/方法调用自身并且通过一下这两个关键条件控制执行递归的终止条件当满足某个条件时停止调用自身避免无限循环递归递推关系:将复杂问题拆解为规模更小逻辑相同的子问题理解要解决大问题先解决和它逻辑一样的小问题知道小问题简单到不用再拆终止条件。分形的特征分形时将具有自相似性的几何图形——整体和局部的形状完全或者近似相同比如雪花等嵌套都属于分形。谢尔宾斯基地毯方块分形1、核心构造规则基础划分将一个大正方形按 3×3 的九宫格均匀划分为 9 个小正方形。保留中心保留正中心的 1 个小正方形主要图形递归迭代对周围剩余的 8 个 小正方形重复上述保留中心的操作直到正方形尺寸小到无法分辨触发递归终止条件。代码执行流程drawfang步骤1、设定终止条件if(w5){return;}步骤2、绘制当前层级的中心图形g.fillRect(xw/3,yh/3,w/3,h/3);步骤3、递归绘制周边的八个方块自相似这是分形的关键连续调用八次drawfang方法分别对应除了中心外的8个方位。每一个周边的小方块都会独立进入流程再次执行“画中心”逻辑从而形成层层嵌套的视觉效果。drawfang(g,x,y,w/3,h/3);drawfang(g,xw/3,y,w/3,h/3);drawfang(g,x2*w/3,y,w/3,h/3);drawfang(g,x,yh/3,w/3,h/3);drawfang(g,x,y2*h/3,w/3,h/3);drawfang(g,x2*w/3,y2*h/3,w/3,h/3);drawfang(g,x2*w/3,yh/3,w/3,h/3);drawfang(g,xw/3,y2*h/3,w/3,h/3);packageljc_0307;importjava.awt.*;importjavax.swing.*;publicclassdrawextendsJFrame{publicdraw(){setTitle(画图);setSize(800,800);setLocationRelativeTo(null);setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);setLayout(newFlowLayout());setVisible(true);}Overridepublicvoidpaint(Graphicsg){super.paint(g);g.setColor(Color.black);drawfang(g,200,200,400,400);}publicvoiddrawfang(Graphicsg,intx,inty,intw,inth){if(w5){return;}g.fillRect(xw/3,yh/3,w/3,h/3);drawfang(g,x,y,w/3,h/3);drawfang(g,xw/3,y,w/3,h/3);drawfang(g,x2*w/3,y,w/3,h/3);drawfang(g,x,yh/3,w/3,h/3);drawfang(g,x,y2*h/3,w/3,h/3);drawfang(g,x2*w/3,y2*h/3,w/3,h/3);drawfang(g,x2*w/3,yh/3,w/3,h/3);drawfang(g,xw/3,y2*h/3,w/3,h/3);}staticvoidmain(String[]args){newdraw();}}谢尔宾斯基三角形与上一个图形完成相似不过这个将正方形变成了三角形。步骤1、设定终止条件if(w5){return;}步骤2、绘制当前层级的图形g.drawLine(xw/2,y,x,yh);g.drawLine(xw/2,y,xw,yh);g.drawLine(x,yh,xw,yh);步骤3、递归绘制9个三角形自相似这是分形的关键连续调用9次drawsan方法每一个周边的三角形都会独立进入流程再次执行逻辑从而形成层层嵌套的视觉效果。drawsan(g,xw/3,y,w/3,h/3);drawsan(g,xw/6,yh/3,w/3,h/3);drawsan(g,x,y2*h/3,w/3,h/3);drawsan(g,xw/2,yh/3,w/3,h/3);drawsan(g,x2*w/3,y2*h/3,w/3,h/3);drawsan(g,xw/3,y2*h/3,w/3,h/3);drawsan(g,xw/4,y2*h/3,w/6,h/6);drawsan(g,x7*w/12,y2*h/3,w/6,h/6);drawsan(g,x5*w/12,yh/3,w/6,h/6);packageljc_0307;importjava.awt.*;importjavax.swing.*;publicclassdraw2extendsJFrame{publicdraw2(){setTitle(画图);setSize(800,800);setLocationRelativeTo(null);setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);setLayout(newFlowLayout());setVisible(true);}Overridepublicvoidpaint(Graphicsg){super.paint(g);g.setColor(Color.black);drawsan(g,200,200,350,300);}publicvoiddrawsan(Graphicsg,intx,inty,intw,inth){if(w5){return;}g.drawLine(xw/2,y,x,yh);g.drawLine(xw/2,y,xw,yh);g.drawLine(x,yh,xw,yh);drawsan(g,xw/3,y,w/3,h/3);drawsan(g,xw/6,yh/3,w/3,h/3);drawsan(g,x,y2*h/3,w/3,h/3);drawsan(g,xw/2,yh/3,w/3,h/3);drawsan(g,x2*w/3,y2*h/3,w/3,h/3);drawsan(g,xw/3,y2*h/3,w/3,h/3);drawsan(g,xw/4,y2*h/3,w/6,h/6);drawsan(g,x7*w/12,y2*h/3,w/6,h/6);drawsan(g,x5*w/12,yh/3,w/6,h/6);}staticvoidmain(String[]args){newdraw2();}}混沌游戏这个图形是谢尔宾斯基三角形的另一种生成方式——混沌游戏算法也叫“随机选择算法”是分型图形的非递归实现方式核心特征得到的方法有三个不在统一直线上的顶点A,B,C.另有一点p点p随机与ABC其中的一点连线取得中点这个新的中点是新的p点再重复以上过程随机找到一点与p相连得中点。无数个中点最后得到图形这个图形就是谢尔宾斯三角形。代码分析定义基础顶点Pointp1newPoint(200,100);Pointp2newPoint(100,300);Pointp3newPoint(300,300);PointpnewPoint(350,200);//p点绘制初始顶点可视化锚点intr5;for(inti0;ipoints.length;i){Pointpppoints[i];ColorcnewColor(0,0,0);g.setColor(c);g.fillOval(pp.x-r,pp.y-r,r,r);}核心迭代逻辑Colorc2newColor(193,27,27);g.setColor(c2);RandomrandomnewRandom();intXp.x;//初始点x坐标种子点intYp.y;//初始点y坐标 (种子点//迭代10000次次数越多图形越密集for(inti0;i10000;i){//步骤一随机选择一个顶点intchoicerandom.nextInt(3);intx00;inty00;if(choice0){x0p1.x;y0p1.y;}elseif(choice1){x0p2.x;y0p2.y;}elseif(choice2){x0p3.x;y0p3.y;}//步骤二计算当前点与选中顶点的中点坐标X(Xx0)/2;Y(Yy0)/2;//步骤三再中点位置绘制1*1的像素点g.fillOval(X,Y,1,1);}//完整代码packageljc_0307;importjava.awt.*;importjava.util.Random;importjavax.swing.*;publicclassdraw3extendsJFrame{Pointp1newPoint(200,100);Pointp2newPoint(100,300);Pointp3newPoint(300,300);PointpnewPoint(350,200);publicdraw3(){setTitle(画图);setSize(800,800);setLocationRelativeTo(null);setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);setLayout(newFlowLayout());setVisible(true);}Overridepublicvoidpaint(Graphicsg){super.paint(g);g.setColor(Color.black);Point[]points{p1,p2,p3};intr5;for(inti0;ipoints.length;i){Pointpppoints[i];ColorcnewColor(0,0,0);g.setColor(c);g.fillOval(pp.x-r,pp.y-r,r,r);}Colorc2newColor(193,27,27);g.setColor(c2);RandomrandomnewRandom();intXp.x;intYp.y;for(inti0;i10000;i){intchoicerandom.nextInt(3);intx00;inty00;if(choice0){x0p1.x;y0p1.y;}elseif(choice1){x0p2.x;y0p2.y;}elseif(choice2){x0p3.x;y0p3.y;}X(Xx0)/2;Y(Yy0)/2;g.fillOval(X,Y,1,1);}}staticvoidmain(String[]args){newdraw3();}}

相关文章:

递归分形!

递归分形 递归的基础 递归是一种编程思想,核心是函数/方法调用自身,并且通过一下这两个关键条件控制执行: 递归的终止条件:当满足某个条件时停止调用自身(避免无限循环);递归递推关系:将复杂问题…...

【spring专题】编译spring5.3源码

文章目录 1. 环境配置2. 拉取代码 2.1克隆到gitee2.2 下载到本地2.3 切换分支2.4 重新导入 3. 环境配置 3.1 安装gradle-方法13.2 安装gradle-方法2(推荐)3.3 jdk安装aspectj3.4 idea安装AspectJ插件 4. 项目配置 4.1 修改build.gradle4.2 修改buildSrcuild.gradle4.3 修改gra…...

创建虚拟机步骤

由于我的电脑自带vmware 所以下载vm教程可自行搜索相关内容 下面直接展示创建内容1.双击图标进入将呈现这样的界面单击“创建新的虚拟机”进入后,默认是典型,我选择自定义下一步,再选择 稍后安装系统选择Linux设置虚拟机名称为server01下面可…...

Red Hat Linux 8的安装

1.新建一个虚拟机2.选自定义安装,点击下一步3.这里默认,点击下一步4.选择稍后安装操作系统,然后点击下一步5.先选客户机操作系统Linux,再选版本Red Hat Enterprise 8 64位6.给虚拟机命名,位置我们点击浏览把它安装到D盘…...

号称解放双手的 OpenClaw 为何成不了合格生产力工具?

🍃 予枫:个人主页📚 个人专栏: 《Java 从入门到起飞》《读研码农的干货日常》《Java 面试刷题指南》💻 Debug 这个世界,Return 更好的自己! 引言 近期AI圈爆火的OpenClaw被捧为“AI打工人”,号称…...

学习率调度的艺术:从Warmup到余弦退火,掌握深度学习的训练节奏

引言在深度学习的训练过程中,优化器的选择决定了“如何更新”参数,而学习率(Learning Rate) 则决定了“更新多大步”。作为整个训练过程中最重要的超参数之一,学习率直接决定了模型能否收敛以及收敛的质量。然而&#…...

Java大厂面试实录:谢飞机的搞笑面试之旅

Java大厂面试实录:谢飞机的搞笑面试之旅 前言 今天给大家带来一篇别开生面的面试实录,主角是我们熟悉的"水货程序员"谢飞机,他将面对一位严肃的技术面试官,展开一场充满笑料的技术较量。第一轮:基础篇 面试官…...

TestPilot - 智能测试用例生成工具

一、前言 软件测试活动中,测试用例设计始终是质量保障体系的核心环节之一。然而,在实际项目中,测试用例编写的主要成本往往并不体现在「撰写」动作本身,而体现在需求理解、业务规则提炼、边界条件补全、异常路径覆盖以及历史测试经…...

XMind 2025 免费版安装及使用教程(附安装包)

XMind 2025 免费版安装及使用教程 摘要 本文详细记录了XMind 2025版本的安装、激活及基础使用教程。内容涵盖环境准备、自定义安装路径、激活步骤解析以及核心功能速览,旨在帮助用户构建一个稳定、高效的思维导图工作环境。 目录 XMind 是什么 ✨安装步骤 &…...

Flutter 三方库 regexed_validator 的鸿蒙适配指南 - 实现结构化正则表达式校验、在 OpenHarmony 上打造极致严谨的表单输入实战

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.csdn.net Flutter 三方库 regexed_validator 的鸿蒙适配指南 - 实现结构化正则表达式校验、在 OpenHarmony 上打造极致严谨的表单输入实战 前言 在鸿蒙(OpenHarmony)应用开发…...

2026见证历史:腾讯、阿里、字节“百虾大战”爆发!哪只“AI小龙虾”才是你的命定打工人?

导语:从“聊天”到“执行”,AI的操作系统时刻来了如果说2023年是Chatbot(聊天机器人)的元年,那么2026年就是Agent(智能体)的爆发年。开源框架OpenClaw(小龙虾)凭借“系统…...

Flutter 三方库 getx_translator 鸿蒙适配指南 - 实现极速响应式翻译、在 OpenHarmony 上打造毫秒级语言切换工作流实战

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.csdn.net Flutter 三方库 getx_translator 鸿蒙适配指南 - 实现极速响应式翻译、在 OpenHarmony 上打造毫秒级语言切换工作流实战 前言 在参与构建鸿蒙(OpenHarmony)生态、处…...

UG NX 移除参数

在UG NX中,“移除参数”(也称为“消参”)是一个用于断开模型与其特征历史关联的关键操作。执行后,模型的建模步骤将被清除,变成一个没有参数的“体”。 简单来说,参数化模型像一个记录了所有“施工步骤”的…...

智能厨房置物架:AI Agent的食材新鲜度监测

智能厨房置物架:AI Agent的食材新鲜度监测 关键词:智能厨房置物架、AI Agent、食材新鲜度监测、传感器技术、机器学习 摘要:本文围绕智能厨房置物架利用AI Agent进行食材新鲜度监测展开深入探讨。首先介绍了该技术的背景,包括目的、预期读者、文档结构和相关术语。接着阐述…...

贾子哲学体系:思想主权与贾子猜想引领的东方原创跨学科理论创新与实证研究

贾子哲学体系:思想主权与贾子猜想引领的东方原创跨学科理论创新与实证研究摘要: 本文首度系统性构建贾子哲学体系(Kucius Philosophy),以“思想主权”为核心公理,确立AI时代人类主体性。核心创新“贾子猜想…...

Flutter 三方库 lyrics_parser 的鸿蒙适配指南 - 实现毫秒级精度的 LRC 歌词解析、在 OpenHarmony 上打造极致的音乐视听同步体验

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.csdn.net Flutter 三方库 lyrics_parser 的鸿蒙适配指南 - 实现毫秒级精度的 LRC 歌词解析、在 OpenHarmony 上打造极致的音乐视听同步体验 前言 在鸿蒙(OpenHarmony)生态的…...

3分钟搞懂深度学习AI:实操篇:ResNet

github仓库及代码(额外补充,持续更新): yiyu0716/3mins-dl: 专为零基础小白打造的深度学习极简指南。这里没有令人头疼的公式,只有通俗易懂的知识拆解。每天只需 3 分钟,带你利用碎片时间轻松看懂 AI 核心概…...

Flutter 三方库 laravel_exception 鸿蒙适配指南 - 实现工业级跨端错误对账与异常监控防线

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.csdn.net Flutter 三方库 laravel_exception 鸿蒙适配指南 - 实现工业级跨端错误对账与异常监控防线 前言 在参与构建鸿蒙(OpenHarmony)生态下的中大型企业级应用时&#xf…...

AI 辅助编程阶段化开发 SOP

AI 辅助编程阶段化开发 SOP1. 提出需求(明确需求)2. 整理需求文档3. 检查需求文档4. 架构设计5. 核实全局架构文档6. 拆分需求7. 阶段性方案8. 输出阶段性开发文档9. 分阶段独立开发以及任务拆分10. 阶段性评审11. 系统集成与联调📌 附录&…...

攻防世界 misc题心仪的公司

1.工具:Wireshark2.解题:我们打开附件,看到了一个webshell.pcapng文件,我们知道这是流量分析题,我们可以用Wireshark打开,我们先尝试搜索一下flag,方法:①按CTRLF,出现如…...

VMware安装RedHat Linux9全攻略

一、安装VMware Workstation Pro 17 1、从网盘下载VMware Workstation Pro 17: https://pan.baidu.com/s/1yKzk3c7k_EfRe0EabRFd1g?pwdRHCE 2、进入安装引导程序: 单击图中安装引导程序的下一步 同意用户许可协议,再单机下一步 更改安装位…...

必看!AI拓客软件源头厂家哪家强?

在当前数字化营销的时代,AI拓客软件成为了企业获取客户的重要工具。本文将对市场上几款主流的AI拓客软件进行深度测评,帮助您选择最适合的产品。一、测评背景与目的随着市场竞争的加剧,企业对于高效、低成本的获客方式的需求日益增加。AI拓客…...

Flutter 三方库 hotp 的鸿蒙适配指南 - 实现 RFC 4226 标准双因素认证、在 OpenHarmony 上打造极致安全的动态令牌实战

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.csdn.net Flutter 三方库 hotp 的鸿蒙适配指南 - 实现 RFC 4226 标准双因素认证、在 OpenHarmony 上打造极致安全的动态令牌实战 前言 在鸿蒙(OpenHarmony)生态的金融管理、…...

常用开源免费的串口录波 / 串口虚拟示波器软件

FX5U RS2串口发送接收指令使用注意事项 https://rxxw-control.blog.csdn.net/article/details/121553172?spm=1011.2415.3001.5331https://rxxw-control.blog.csdn.net/article/details/121553172?spm=1011.2415.3001.5331虚拟串口软件使用介绍...

MCP:AI 世界的“USB-C”接口——深度解析模型上下文协议

MCP:AI 世界的“USB-C”接口——深度解析模型上下文协议 导读:在 2024 年之前,让 AI 连接你的本地文件、数据库或企业内部系统,就像给每台设备定制专用充电器一样繁琐。Anthropic 推出的 MCP (Model Context Protocol) 彻底改变了…...

Flutter 三方库 shelf_router_discovery 鸿蒙适配指南 - 实现服务端路由自动注册、在 OpenHarmony 上打造极致解耦的云端治理实战

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.csdn.net Flutter 三方库 shelf_router_discovery 鸿蒙适配指南 - 实现服务端路由自动注册、在 OpenHarmony 上打造极致解耦的云端治理实战 前言 在鸿蒙(OpenHarmony)生态的…...

江苏哪里有三防布厂家?跑断腿摸出的实体大厂

开春这阵子,各大工程供应链的交流群里简直炸开了锅。做重工机械设备改造的、接了大型造船厂外包单子的、还有搞煤矿设备换新升级的,全都在满世界地到处寻价备料。我在好几个几百人的大群里潜水,每天至少能看到几十个人在重复问同一句话&#…...

太猛了!用 OpenClaw-RL,AI 边聊天边自我进化,「白嫖」用户交互数据训出更强模型?

研究背景 每一个已经上线的 AI Agent,其实每天都在"丢弃金矿"。每次 Agent 执行完一个动作 ,环境就会给它一个下一状态信号 ——可能是用户的回复、工具的执行结果、GUI 界面的变化,或者是测试的通过与否。现有的系统把这些信号仅…...

Flutter 三方库 sample_downloader 鸿蒙适配指南 - 实现海量样本数据自动化并行采集、在 OpenHarmony 上打造高效下载调度防御线实战

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.csdn.net Flutter 三方库 sample_downloader 鸿蒙适配指南 - 实现海量样本数据自动化并行采集、在 OpenHarmony 上打造高效下载调度防御线实战 前言 在参与构建鸿蒙(OpenHarmony&#x…...

从PDF到RAG知识库

打造可配置、可扩展的自动化预处理流水线:从PDF到RAG知识库在构建RAG(检索增强生成)系统的过程中,文档预处理是决定检索质量的基础环节。然而,面对多源异构文档(如PDF、图片、扫描件)&#xff0…...