- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在尝试在处理 javascript 时实现一个分形工厂(最高级别 - 6)。即使满足基本条件,我也会收到“超出最大调用堆栈大小”错误。
代码如下:第一个函数自定义画线根据长度、 Angular 和原点画线。增量功能将 Angular 增加 25 度。减量函数将 Angular 减少 25 度。
var customDrawLine = function(x, y, length, angle)
{
var f={x2:'', y2:''};
f.x2 = x+(sqrt(sq(length)/(1+sq(tan (angle)))));
f.y2 = y + ((f.x2-x) * tan (angle));
line(x, y, f.x2, f.y2);
return f;
};
var incrementAngle = function(angle)
{
return (angle+25);
};
var decrementAngle = function(angle)
{
return (angle-25);
};
var fProductionRule = function(x, y, z, degrees, flag)
{
var l = {x1:'', y1:''};
if(flag === 1)
{
for (var a=0; a<2;a++)
{
l = customDrawLine(l.x1, l.y1, z, degrees);
}
}
else
{
l = customDrawLine(l.x1, l.y1, z, degrees);
}
return l;
};
var xProductionRule = function(x, y, degrees, nLevel, flag)
{
var k = {x1:'', y1:''};
var m;
k.x1 = x;
k.y1 = y;
m = degrees;
for(var z=0; z<7; z++)
{
var f = fProductionRule(k.x1, k.y1, (10-z), m, flag);
m = incrementAngle(m);
flag = 1;
{
{
xProductionRule(f.x2,f.y2, m, z);
}
m = decrementAngle(m);
xProductionRule(f.x2,f.y2, m, z);
}
m = decrementAngle(m);
f = fProductionRule(k.x1, k.y1, (10-z), m, flag);
{
m = decrementAngle(m);
f = fProductionRule(k.x1, k.y1, (10-z), m, flag);
xProductionRule(f.x2,f.y2, m, z);
}
m = incrementAngle(m);
xProductionRule(f.x2,f.y2, m, z);
}
};
var drawShape = function(x, y, degrees)
{
xProductionRule(x, y, degrees, 0, 0);
};
drawShape(10, 380, 25);
最佳答案
您的代码包含无限递归,如xProductionRule
无条件地调用自己。
要绘制分形,您必须限制递归的深度,或者阻止渲染特定尺寸(如 1 像素)以下的部分。
我看到了 xProductionRule
有 5 个参数,其中一个称为 nLevel
,但该参数并未在任何地方使用,实际上您仅使用 4 个参数调用该函数。我认为您将使用该参数来限制递归的深度。向函数添加一些检查 ( nLevel < 7
),并使每个递归调用都包含 nLevel+1
作为参数。
在我看来,根据您提到的维基百科文章,您的代码框架应该采用如下结构:
function drawA(depth, ... /* placement information */) {
// here, draw the current branch
// and then continue with it's children
if (depth > 0) {
drawA(depth - 1, ... /* derived placement information */)
drawB(depth - 1, ... /* another derived placement information */)
}
}
function drawB(depth, ... /* placement information */) {
// here, draw the current branch
// and then continue with it's children
if (depth > 0) {
drawA(depth - 1, ... /* derived placement information */)
}
}
drawA(7, ... /* placement of the root branch */)
我看不到需要 7 环的地方。
关于javascript - "Maximum call stack size exceeded"在处理 JS 时实现 Fractal plant 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34370297/
我在我的 Controller 中添加了一个名为移植的自定义操作。我只是想呈现一个下拉表单以根据“tray_id”选择要定位的位置 我的路线是这样的: resources :plants do
题目地址:https://leetcode.com/problems/flower-planting-with-no-adjacent/ 题目描述 Youhave N gardens, label
我有一个用工厂模拟制作的离散事件模拟模型,仅使用充满变量、方法和表格的网络,但不使用任何 Material 流对象。 我的任务是将这个模型转换成Java代码。 我首先使用 ANTLRv4 为 SimT
我有以下问题, 假设我有以下单元格(非常简化):CBA 4.5 01/22/2019 ,我想用VBA种一个BDP()在相邻单元格中运行,以找出 ISIN 是什么。如果没有 excel,我会使用 =BD
我们有市场数据处理程序,可以向 KDB Ticker Plant 发布报价。为此,我们使用 exxeleron q java 库。不幸的是,延迟非常高:当我们尝试插入一批记录时,延迟会达到数百毫秒。您
我的任务是为 C/C++ 类创建一个简单的扫雷克隆。它需要使用 10x10 字符 2D 数组作为雷区。 我需要在 field 上随机放置 5 个地雷。空白处应使用空格(' ')填充,而有地雷的位置应使
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 5 年前。 Improve t
Problem Statement There are N plants in a garden. Each of these plants has been added with some amou
这个相当简单的 SQL 查询在从 LINQ 尝试时被证明是非常令人困惑的。 我有一个 SQL 表 Plant带列ZoneMin . 我想找到列中值的最小值和最大值。 T-SQL 中的答案非常简单: S
这个相当简单的 SQL 查询被证明在从 LINQ 尝试时非常令人困惑。 我有一个包含 ZoneMin 列的 SQL 表 Plant。 我想找到列中值的最小值和最大值。 T-SQL 中的答案非常简单:
我正在尝试在处理 javascript 时实现一个分形工厂(最高级别 - 6)。即使满足基本条件,我也会收到“超出最大调用堆栈大小”错误。 代码如下:第一个函数自定义画线根据长度、 Angular 和
我是一名优秀的程序员,十分优秀!