mirror of
https://github.com/artegoser/ONLang
synced 2024-12-23 09:33:44 +03:00
doc: recursion factorial
This commit is contained in:
parent
6dbc9f7ba4
commit
19fc8fa54c
1 changed files with 39 additions and 8 deletions
|
@ -1,28 +1,29 @@
|
||||||
[
|
[
|
||||||
{
|
{
|
||||||
fn: {
|
fn: {
|
||||||
name: "fact",
|
name: "fact_loop",
|
||||||
args: ["n"],
|
args: ["n"],
|
||||||
body: [
|
body: [
|
||||||
{ let: { result: { var: "fact.n" } } },
|
{ let: { result: { var: "n" } } },
|
||||||
{
|
{
|
||||||
loop: [
|
loop: [
|
||||||
//using loop because recursion is not supported
|
//using loop because recursion is not supported*
|
||||||
|
//* - already supported
|
||||||
{
|
{
|
||||||
if: {
|
if: {
|
||||||
condition: { comp: [{ var: "fact.n" }, ">", 1] },
|
condition: { comp: [{ var: "n" }, ">", 1] },
|
||||||
body: [
|
body: [
|
||||||
{
|
{
|
||||||
assign: {
|
assign: {
|
||||||
"fact.n": {
|
n: {
|
||||||
calc: [{ var: "fact.n" }, "-", 1],
|
calc: [{ var: "n" }, "-", 1],
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
assign: {
|
assign: {
|
||||||
result: {
|
result: {
|
||||||
calc: [{ var: "result" }, "*", { var: "fact.n" }],
|
calc: [{ var: "result" }, "*", { var: "n" }],
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -37,11 +38,37 @@
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
fn: {
|
||||||
|
name: "fact",
|
||||||
|
args: ["n"],
|
||||||
|
body: [
|
||||||
|
{
|
||||||
|
if: {
|
||||||
|
condition: { comp: [{ var: "n" }, "==", 1] },
|
||||||
|
body: [{ return: 1 }],
|
||||||
|
else: [
|
||||||
|
{
|
||||||
|
return: {
|
||||||
|
calc: [
|
||||||
|
{ var: "n" },
|
||||||
|
"*",
|
||||||
|
{ fact: [{ calc: [{ var: "n" }, "-", 1] }] },
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
|
||||||
{
|
{
|
||||||
fn: {
|
fn: {
|
||||||
name: "_eq",
|
name: "_eq",
|
||||||
args: ["a", "b"],
|
args: ["a", "b"],
|
||||||
body: [{ return: { comp: [{ var: "_eq.a" }, "==", { var: "_eq.b" }] } }],
|
body: [{ return: { comp: [{ var: "a" }, "==", { var: "b" }] } }],
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -70,6 +97,10 @@
|
||||||
"20! == 2 432 902 008 176 640 000: ",
|
"20! == 2 432 902 008 176 640 000: ",
|
||||||
{ _eq: [{ fact: [20] }, 2432902008176640000] },
|
{ _eq: [{ fact: [20] }, 2432902008176640000] },
|
||||||
],
|
],
|
||||||
|
"",
|
||||||
|
["(loop) 10! == 3 628 800: ", { _eq: [{ fact_loop: [10] }, 3628800] }],
|
||||||
|
["(loop) 11! == 39 916 800: ", { _eq: [{ fact_loop: [11] }, 39916800] }],
|
||||||
|
|
||||||
// [
|
// [
|
||||||
// "21! == 51 090 942 171 709 440 000: ",
|
// "21! == 51 090 942 171 709 440 000: ",
|
||||||
// { _eq: [{ fact: [21] }, 51090942171709440000] },
|
// { _eq: [{ fact: [21] }, 51090942171709440000] },
|
||||||
|
|
Loading…
Add table
Reference in a new issue