ทำต้นคริสต์มาสที่ปรับขนาดได้ [ปิด]


95

ความท้าทายของคุณ: ทำต้นคริสต์มาส ขนาดจะต้องสามารถเลือกได้โดยวิธีการป้อนข้อมูลบางอย่าง แต่ไม่จำเป็นต้องเกี่ยวข้องโดยตรงกับส่วนใดส่วนหนึ่งของต้นไม้ อย่างไรก็ตามปัจจัยการผลิตที่มีขนาดใหญ่ควรสร้างต้นไม้ที่มีขนาดใหญ่ขึ้น

คุณทำมันได้อย่างไร คุณสามารถทำให้ต้นไม้ในแบบที่คุณชอบนอกเหนือจากการพิมพ์อักขระ Unicode สำหรับต้นไม้เช่น ouputting รูปภาพศิลปะ ASCII กับด้านอื่น ๆ ฯลฯ ไม่ว่าคุณจะทำอะไรก็ตามอย่าลืมว่านี่คือการดังนั้น มีความคิดสร้างสรรค์.

คำตอบที่มีผู้โหวตมากที่สุดในตอนท้ายของเดือนธันวาคมชนะ แต่ฉันจะยอมรับคนอื่นถ้ามันได้รับสูงกว่า


1
คำถามที่ดี;)
Timtech

1
การตกแต่งที่น่าสงสารนั้นไม่ได้บังคับ!
o0 '

@ โลริสฉันคิดว่ามันดีที่พวกเขาไม่ได้บังคับ ด้วยวิธีนี้ผู้คนสามารถทำสิ่งที่พวกเขาต้องการและต้นไม้เศษส่วนที่ยอดเยี่ยมนั้นเป็นคำตอบที่ถูกต้องตามกฎหมาย
Justin

@Quincunx คุณสามารถเพิ่มการตกแต่งแม้กระทั่งต้นไม้เศษส่วน ...
o0 '

@ โลริสใช่ แต่พวกเขาก็มีมากมาย ผู้เขียนต้นไม้เหล่านั้นสามารถเพิ่มการตกแต่งได้หากต้องการ แต่ฉันไม่ต้องการมัน
Justin

คำตอบ:


92

หลาม

เศษส่วนต้นคริสต์มาสโดยใช้แพ็คเกจเต่า:

ป้อนคำอธิบายรูปภาพที่นี่

n = input()*1.

from turtle import *
speed("fastest")
left(90)
forward(3*n)
color("orange", "yellow")
begin_fill()
left(126)
for i in range(5):
    forward(n/5)
    right(144)
    forward(n/5)
    left(72)
end_fill()
right(126)

color("dark green")
backward(n*4.8)
def tree(d, s):
    if d <= 0: return
    forward(s)
    tree(d-1, s*.8)
    right(120)
    tree(d-3, s*.5)
    right(120)
    tree(d-3, s*.5)
    right(120)
    backward(s)
tree(15, n)
backward(n/2)

import time
time.sleep(60)

n คือพารามิเตอร์ size ทรีที่แสดงสำหรับ n = 50 ใช้เวลาหนึ่งหรือสองนาทีในการวาด


2
สิ่งนี้ดูน่ารัก:)
Soner Gönül

80

JavaScript

ป้อนคำอธิบายรูปภาพที่นี่

แสดงต้นไม้การ์ตูนออนไลน์

var size = 400;

var canvas = document.createElement('canvas');
canvas.width = size;
canvas.height = size;
document.body.appendChild(canvas);

var ctx = canvas.getContext('2d');

var p3d = [];

var p = [Math.random(), Math.random(), Math.random(), 0];

for (var i = 0; i < 100000; i++) {
    p3d.push([p[0],p[1],p[2],p[3]]);
    var t = Math.random();
    if (t<0.4) {
        _y = 0.4 * p[1];
        _x = 0.1 * p[0];
        _z = 0.6 * p[2];
        var r = Math.floor(3*t/0.4)/3.0;
        var rc = Math.cos(Math.PI*2.0*r);
        var rs = Math.sin(Math.PI*2.0*r);
        p[1] = _x+0.1*r+0.5*_y*_y;
        p[0] = _y*rc+_z*rs;
        p[2] = _z*rc-_y*rs;
        p[3] = 0.2*t + 0.8*p[3];
    } else {
        p[1] = 0.2 + 0.8*p[1];
        p[0] = 0.8 * p[0];
        p[2] = 0.8 * p[2];
        p[3] = 0.2 + 0.8*p[3];
    }
}

var rot = 0.0;

function render() {
    rot = rot + 0.1;
    var rc = Math.cos(rot);
    var rs = Math.sin(rot);

    ctx.strokeStyle='#FF7F00';
    ctx.lineWidth=2;
    ctx.beginPath();
    ctx.moveTo(size/2,size/8);
    ctx.lineTo(size/2,size*15/16);
    ctx.stroke();

    var img = ctx.getImageData(0, 0, size, size);
    for (var j = 0; j < size*size; j++) {
        img.data[4*j+0] = 0.5*img.data[4*j+0];
        img.data[4*j+1] = 0.5*img.data[4*j+1];
        img.data[4*j+2] = 0.5*img.data[4*j+2];
        img.data[4*j+3] = 255;
    }

    for (var i = 0; i < p3d.length; i++) {
        var px = p3d[i][0];
        var py = 0.5 - p3d[i][1];
        var pz = p3d[i][2];
        var col = Math.floor(128.0*p3d[i][3]);

        var _x = rc*px + rs*pz;
        var _z = rc*pz - rs*px;

        var z = 3.0 * size / (_z + 4.0);
        var x = size / 2 + Math.round(_x * z);        
        var y = size / 2 + Math.round(py * z);

        if(x>=0&&y>=0&&x<size&&y<size) {
            img.data[4 * (y * size + x) + 0] = col;
            img.data[4 * (y * size + x) + 1] = 128+col;
            img.data[4 * (y * size + x) + 2] = col;
            img.data[4 * (y * size + x) + 3] = 255;
        }
    }

    ctx.putImageData(img, 0, 0);
}

setInterval(render, 1000 / 30);

ฉันชอบมัน แต่คุณควรเพิ่มลำตัว
Fels

1
@Fels เพิ่มลำตัว
Howard

2
นี่เป็นสิ่งที่น่าประทับใจมาก แต่เกิดอะไรขึ้นกับพิกเซลสีเขียวที่วนรอบต้นไม้ ฉันไม่ได้ตระหนักว่าซานต้ามีเอลฟ์สีเขียวตัวเล็ก ๆ ที่สามารถบินได้ (พวกเขาไม่ได้เบี่ยงเบนจากความงามของคำตอบของคุณ แต่ฉันสงสัยว่าพวกเขามาจากไหน)
Justin

@Quincunx: พวกเขาดูเหมือนจะเป็นจุดเริ่มต้นตัวอย่างจากก่อนที่การวนซ้ำมาบรรจบกัน ข้าม 100 คะแนนแรกจะกำจัดพวกเขา
Ilmari Karonen

2
เจ๋งจริง ๆ แต่มันก็ดูไม่ค่อยเหมือนต้นคริสต์มาส มันดูเหมือนไม้ที่มีใบเฟิร์นติดอยู่สองสามใบ นอกจากนี้คุณสามารถทำให้มุมมองเลื่อนไปตามแกน y อย่างช้าๆดังนั้น 3D-ness จึงชัดเจนยิ่งขึ้น?
The Guy with The Hat

76

อีกหนึ่งแผนภูมิภาษา Mathematica / Wolframตามคำตอบของ Vitaliy :

PD = .5;
s[t_, f_] := t^.6 - f
dt[cl_, ps_, sg_, hf_, dp_, f_, flag_] :=
    Module[{sv, basePt},
           {PointSize[ps],
            sv = s[t, f];
            Hue[cl (1 + Sin[.02 t])/2, 1, .3 + sg .3 Sin[hf sv]],
            basePt = {-sg s[t, f] Sin[sv], -sg s[t, f] Cos[sv], dp + sv};
            Point[basePt],
           If[flag,
              {Hue[cl (1 + Sin[.1 t])/2, 1, .6 + sg .4 Sin[hf sv]], PointSize[RandomReal[.01]],
               Point[basePt + 1/2 RotationTransform[20 sv, {-Cos[sv], Sin[sv], 0}][{Sin[sv], Cos[sv], 0}]]},
              {}]
          }]

frames = ParallelTable[
                       Graphics3D[Table[{
                                         dt[1, .01, -1, 1, 0, f, True], dt[.45, .01, 1, 1, 0, f, True],
                                         dt[1, .005, -1, 4, .2, f, False], dt[.45, .005, 1, 4, .2, f, False]},
                                        {t, 0, 200, PD}],
                                  ViewPoint -> Left, BoxRatios -> {1, 1, 1.3}, 
                                  ViewVertical -> {0, 0, -1},
                                  ViewCenter -> {{0.5, 0.5, 0.5}, {0.5, 0.55}}, Boxed -> False,
                                  PlotRange -> {{-20, 20}, {-20, 20}, {0, 20}}, Background -> Black],
                       {f, 0, 1, .01}];

Export["tree.gif", frames]

ต้นคริสต์มาส


7
นี่คือหนึ่งที่ดีที่สุด !!
Murta

63

จาวาสคริ

เอาต์พุตของตัวอย่างโค้ดที่กำหนด

นี่คือรหัสกอล์ฟครั้งแรกของฉัน!

var a=40,b=8,c=13,o="<div style='font-family:monospace;text-align:center;color:#094'>",w=1,x=0,y="|#|<br>";for(i=1;i<a;i++){for(j=0;j<w;j++){x%c==0?o+="<span style='color:#D00'>O</span>":o+="+";x++;}i%b==0?w-=4:w+=2;o+="<br>";}document.write(o+"<span style='color:#640'>"+y+y+y+"</span></div>");

มันมาในที่ 295 ตัวอักษร

ขนาดและการตกแต่งของต้นไม้ถูกกำหนดโดยตัวแปร a, b, c:

  • ชุดจำนวนแถวในต้นไม้
  • b ตั้งค่าจำนวนแถวระหว่างความกว้างลดลง (ตั้งค่าต่ำสำหรับต้นไม้ผอมสูงสำหรับต้นไม้อ้วน) ต้องมากกว่าหรือเท่ากับ 3
  • c ตั้งค่าจำนวน baubles (ตั้งค่าเป็นศูนย์สำหรับ none, 1 สำหรับ baubles เท่านั้น, ตัวเลขที่สูงขึ้นสำหรับการจัดวาง baubles ที่หนาแน่นน้อยกว่า)

มันดูดีที่สุดเมื่อ a เป็นผลคูณของ b ดังตัวอย่าง

วางลงในคอนโซลเพื่อสร้างทรี ดูดีขึ้นจากระยะไกล!


1
ลดลงเป็น 264a=40,b=8,c=13,o="<p style='font:monospace;color:#094' align='center'>",w=1,x=0,y="|#|<br>";for(i=1;i<a;i++){for(j=0;j<w;j++){x%c==0?o+="<b style='color:red'>O</b>":o+="+";x++;}i%b==0?w-=4:w+=2;o+="<br>";}document.write(o+"<b style='color:#640'>"+y+y+y+"</b></p>");
user1886419

4
คุณกำลังเล่นกอล์ฟกับการประกวดความนิยมหรือไม่? ว้าวฉันจะเขียนโค้ดที่อ่านได้ดี (เขียนง่ายกว่า) +1
Justin

7
ungh คุณกำลังใช้งานdoc.write? ไม่มี +1 จากฉัน
John Dvorak

2
@JanDvorak ทำไมล่ะ ฉันคิดว่านี่คือการเล่นกอล์ฟ .....
Pacerier

62

C ++

มาทำให้เป็นจริงด้วยจิตวิญญาณของ IOCCC และมีรหัสในรูปของต้นไม้ด้วย! : D

#include <iostream>
using namespace std;

               int
             main(){
              int a
                ; 
               cin
             >>a;int
           w=a*2+5;for
             (int x=
           0;x<a;++x){
         for(int y=2;y>=
       0;--y){for(int z=0;
           z<a+y-x;++z
        ){cout<<" ";}for(
     int z=0;z<x*2-y*2+5;++z
        ){cout<<".";}cout
      <<endl;}}for(int x=0;
    x<w/5+1;++x){for(int z=0;
  z<w/3+1;++z){cout<<" ";}for(
int z=0;z<w-(w/3+1)*2;z+=1){cout
           <<"#";}cout
           <<endl;;;}}

ใช้จำนวนเต็มเป็นอินพุตและส่งคืนต้นคริสต์มาสด้วย "ระดับสแต็ก" จำนวนมาก ตัวอย่างเช่นอินพุตของ

5

ผลตอบแทน:

       .
      ...
     .....
      ...
     .....
    .......
     .....
    .......
   .........
    .......
   .........
  ...........
   .........
  ...........
 .............
      ###
      ###
      ###
      ###

ตัวอย่างผลลัพธ์
John Dvorak

32
รหัสดูเหมือนต้นไม้ chrismas มากกว่าเอาท์พุท ...
Denys Séguret

2
@dystroy สำหรับการบันทึกคำแนะนำไม่ได้บอกว่ามันเป็นผลลัพธ์ที่จะต้องห้ามต้นไม้
Pierre Arlaud

4
@ArlaudPierre: แต่ต้องปรับขนาดได้ซึ่งเป็นไปไม่ได้ที่มีเพียงซอร์สโค้ด ฉันสามารถสร้างโปรแกรมที่ส่งรหัสโปรแกรมในรูปของต้นคริสต์มาสที่ส่งออกต้นคริสต์มาสจริงแต่ฉันคิดว่ามันจะยากมากโดยไม่ต้องหันไปใส่เซมิโคลอนจรจัดในทุกที่
Joe Z.

1
หากคุณวางไว้*ที่ด้านบนของทรี (ซอร์สโค้ด) คุณจะมี +1 ของฉัน
Fabricio

61

จาวาสคริ

Quasirealistic เครื่องกำเนิดต้นสน 3 มิติเต็มขั้นตอน

คุณสมบัติ: การกำหนดค่าที่กว้างขวางพร้อมตัวเลือกการกำหนดค่าเพิ่มเติมที่มีอยู่ในโค้ด ลำต้นคดเคี้ยวไปมา แตกแขนงกิ่ง; แอนิเมชันการเติบโต การหมุนของต้นไม้ที่โตเต็มที่

ไม่มีเนื้อเรื่อง: jQuery, Underscore.js หรือไลบรารี่อื่น ๆ ; การพึ่งพาฮาร์ดแวร์ - ต้องการการสนับสนุนผ้าใบเท่านั้น รหัสยุ่ง (อย่างน้อยนั่นคือเจตนา)

หน้าสด: http://fiddle.jshell.net/honnza/NMva7/show/

แก้ไขหน้า: http://jsfiddle.net/honnza/NMva7/

ภาพหน้าจอ:

ต้นสน

HTML:

<canvas id=c width=200 height=300 style="display:none"></canvas>
<div id=config></div>

javascript:

var TAU = 2*Math.PI,
    deg = TAU/360,

    TRUNK_VIEW      = {lineWidth:3, strokeStyle: "brown", zIndex: 1},
    BRANCH_VIEW     = {lineWidth:1, strokeStyle: "green", zIndex: 2},
    TRUNK_SPACING   = 1.5,
    TRUNK_BIAS_STR  = -0.5,
    TRUNK_SLOPE     = 0.25,
    BRANCH_LEN      = 1,
    BRANCH_P        = 0.01,
    MIN_SLOPE       = -5*deg,
    MAX_SLOPE       = 20*deg,
    INIT_SLOPE      = 10*deg,
    MAX_D_SLOPE     =  5*deg,
    DIR_KEEP_BIAS   = 10,
    GROWTH_MSPF     = 10, //ms per frame
    GROWTH_TPF      = 10, //ticks per frame
    ROTATE_MSPF     = 10,
    ROTATE_RPF      = 1*deg; //radians per frame

var configurables = [
//    {key: "TRUNK_SPACING", name: "Branch spacing", widget: "number",
//     description: "Distance between main branches on the trunk, in pixels"},
    {key: "TRUNK_BIAS_STR", name: "Branch distribution", widget: "number",
     description: "Angular distribution between nearby branches. High values tend towards one-sided trees, highly negative values tend towards planar trees. Zero means that branches grow in independent directions."},
    {key: "TRUNK_SLOPE", name: "Trunk slope", widget: "number",
     description: "Amount of horizontal movement of the trunk while growing"},
    {key: "BRANCH_P", name: "Branch frequency", widget: "number",
     description: "Branch frequency - if =1/100, a single twig will branch off approximately once per 100 px"},
    {key: "MIN_SLOPE", name: "Minimum slope", widget: "number", scale: deg,
     description: "Minimum slope of a branch, in degrees"},
    {key: "MAX_SLOPE", name: "Maximum slope", widget: "number", scale: deg,
     description: "Maximum slope of a branch, in degrees"},
    {key: "INIT_SLOPE", name: "Initial slope", widget: "number", scale: deg,
     description: "Angle at which branches leave the trunk"},
    {key: "DIR_KEEP_BIAS", name: "Directional inertia", widget: "number",
     description: "Tendency of twigs to keep their horizontal direction"},
    {get: function(){return maxY}, set: setCanvasSize, name: "Tree height",
     widget:"number"}
    ];

var config = document.getElementById("config"),
    canvas = document.getElementById("c"),
    maxX   = canvas.width/2,
    maxY   = canvas.height,
    canvasRatio = canvas.width / canvas.height,
    c;

function setCanvasSize(height){
    if(height === 'undefined') return maxY;
    maxY = canvas.height = height;
    canvas.width = height * canvasRatio;
    maxX = canvas.width/2;
x}

var nodes = [{x:0, y:0, z:0, dir:'up', isEnd:true}], buds = [nodes[0]],
    branches = [],
    branch,
    trunkDirBias = {x:0, z:0};

////////////////////////////////////////////////////////////////////////////////

configurables.forEach(function(el){
    var widget;
    switch(el.widget){
        case 'number':
            widget = document.createElement("input");
            if(el.key){
                widget.value = window[el.key] / (el.scale||1);
                el.set = function(value){window[el.key]=value * (el.scale||1)};
            }else{
                widget.value = el.get();
            }
            widget.onblur = function(){
                el.set(+widget.value);
            };
            break;
        default: throw "unknown widget type";
    }
    var p = document.createElement("p");
    p.textContent = el.name + ": ";
    p.appendChild(widget);
    p.title = el.description;
    config.appendChild(p);
});
var button = document.createElement("input");
button.type = "button";
button.value = "grow";
button.onclick = function(){
    button.value = "stop";
    button.onclick = function(){clearInterval(interval)};
    config.style.display="none";
    canvas.style.display="";
    c=canvas.getContext("2d");
    c.translate(maxX, maxY);                
    c.scale(1, -1);
    interval = setInterval(grow, GROWTH_MSPF);
}
document.body.appendChild(button);
function grow(){
    for(var tick=0; tick<GROWTH_TPF; tick++){
        var budId = 0 | Math.random() * buds.length,
            nodeFrom = buds[budId], nodeTo, branch,
            dir, slope, bias

        if(nodeFrom.dir === 'up' && nodeFrom.isEnd){
            nodeFrom.isEnd = false; 
            rndArg = Math.random()*TAU;
            nodeTo = {
                x:nodeFrom.x + TRUNK_SPACING * TRUNK_SLOPE * Math.sin(rndArg),
                y:nodeFrom.y + TRUNK_SPACING,
                z:nodeFrom.z + TRUNK_SPACING * TRUNK_SLOPE * Math.cos(rndArg), 
                dir:'up', isEnd:true}
            if(nodeTo.y > maxY){
                console.log("end");
                clearInterval(interval);
                rotateInit();
                return;
            }
            nodes.push(nodeTo);
            buds.push(nodeTo);
            branch = {from: nodeFrom, to: nodeTo, view: TRUNK_VIEW};
            branches.push(branch);
            renderBranch(branch);
        }else{ //bud is not a trunk top
            if(!(nodeFrom.dir !== 'up' && Math.random() < BRANCH_P)){
                buds.splice(buds.indexOf(nodeFrom), 1)
            }
            nodeFrom.isEnd = false; 
            if(nodeFrom.dir === 'up'){
                bias = {x:trunkDirBias.x * TRUNK_BIAS_STR,
                        z:trunkDirBias.z * TRUNK_BIAS_STR};
                slope = INIT_SLOPE;
            }else{
                bias = {x:nodeFrom.dir.x * DIR_KEEP_BIAS,
                        z:nodeFrom.dir.z * DIR_KEEP_BIAS};
                slope = nodeFrom.slope;
            }
            var rndLen = Math.random(),
                rndArg = Math.random()*TAU;
            dir = {x: rndLen * Math.sin(rndArg) + bias.x,
                   z: rndLen * Math.cos(rndArg) + bias.z};
            var uvFix = 1/Math.sqrt(dir.x*dir.x + dir.z*dir.z);
            dir = {x:dir.x*uvFix, z:dir.z*uvFix};
            if(nodeFrom.dir === "up") trunkDirBias = dir;
            slope += MAX_D_SLOPE * (2*Math.random() - 1);
            if(slope > MAX_SLOPE) slope = MAX_SLOPE;
            if(slope < MIN_SLOPE) slope = MIN_SLOPE;
            var length = BRANCH_LEN * Math.random();
            nodeTo = {
                x: nodeFrom.x + length * Math.cos(slope) * dir.x,
                y: nodeFrom.y + length * Math.sin(slope),
                z: nodeFrom.z + length * Math.cos(slope) * dir.z,
                dir: dir, slope: slope, isEnd: true
            }
            //if(Math.abs(nodeTo.x)/maxX + nodeTo.y/maxY > 1) return;
            nodes.push(nodeTo);
            buds.push(nodeTo);
            branch = {from: nodeFrom, to: nodeTo, view: BRANCH_VIEW};
            branches.push(branch);
            renderBranch(branch);
        }// end if-is-trunk
    }// end for-tick
}//end func-grow

function rotateInit(){
    branches.sort(function(a,b){
        return (a.view.zIndex-b.view.zIndex);
    });
    interval = setInterval(rotate, ROTATE_MSPF);
}

var time = 0;
var view = {x:1, z:0}
function rotate(){
    time++;
    view = {x: Math.cos(time * ROTATE_RPF),
            z: Math.sin(time * ROTATE_RPF)};
    c.fillStyle = "white"
    c.fillRect(-maxX, 0, 2*maxX, maxY);
    branches.forEach(renderBranch);
    c.stroke();
    c.beginPath();
}

var prevView = null;
function renderBranch(branch){
    if(branch.view !== prevView){
        c.stroke();
        for(k in branch.view) c[k] = branch.view[k];
        c.beginPath();
        prevView = branch.view;
    }
    c.moveTo(view.x * branch.from.x + view.z * branch.from.z,
             branch.from.y);
    c.lineTo(view.x * branch.to.x + view.z * branch.to.z,
             branch.to.y);
}

2
ฉันรู้เพราะคำตอบนี้มีเพียงความคิดเห็นเดียว: เพราะมันทำให้คนพูดไม่ออก
Caridorc

49

ทุบตี

ตัวอย่างผลลัพธ์:

ต้นคริสต์มาส ASCII

ขนาดต้นไม้ (เช่นจำนวนบรรทัด) ถูกส่งผ่านไปยังบรรทัดคำสั่งและถูก จำกัด ไว้ที่ค่า 5 หรือมากกว่า ./xmastree.sh 12ภาพด้านบนถูกผลิตจากคำสั่ง นี่คือซอร์สโค้ด:

#!/bin/bash
declare -a a=('.' '~' "'" 'O' "'" '~' '.' '*')
[[ $# = 0 ]] && s=9 || s=$1
[[ $s -gt 5 ]] || s=5
for (( w=1, r=7, n=1; n<=$s; n++ )) ; do
  for (( i=$s-n; i>0; i-- )) ;  do
    echo -n " "
  done
  for (( i=1; i<=w; i++ )) ; do
    echo -n "${a[r]}"
    [[ $r -gt 5 ]] && r=0 || r=$r+1
  done
  w=$w+2
  echo " "
done;
echo " "

นั่นสวยมาก
pandubear

42

ข้อความปฏิเสธความรับผิดชอบ: นี่เป็นไปตามต้นคริสต์มาส LaTeX ของฉันโพสต์ครั้งแรกที่นี่: https://tex.stackexchange.com/a/87921/8463

รหัสต่อไปนี้จะสร้างต้นไม้ chrismtas ด้วยการตกแต่งแบบสุ่ม คุณสามารถเปลี่ยนทั้งขนาดของต้นไม้และเมล็ดสุ่มเพื่อสร้างต้นไม้ที่แตกต่างกัน

ในการเปลี่ยนเมล็ดปรับเปลี่ยนค่าภายใน\pgfmathsetseed{\year * 6}เป็นค่าตัวเลขอื่น ๆ (ค่าเริ่มต้นจะสร้างต้นไม้ใหม่ทุกปี)

หากต้องการเปลี่ยนขนาดของต้นไม้ให้ปรับorder=10ขนาดเป็นใหญ่ขึ้นหรือเล็กลงทั้งนี้ขึ้นอยู่กับขนาดของต้นไม้ที่คุณต้องการ

ตัวอย่าง. order=11:

ป้อนคำอธิบายรูปภาพที่นี่

order=8

ป้อนคำอธิบายรูปภาพที่นี่

\documentclass{article}
\usepackage{tikz}
\usetikzlibrary{calc, lindenmayersystems,shapes,decorations,decorations.shapes}
\begin{document}

\def\pointlistleft{}
\def\pointlistright{}
\pgfmathsetseed{\year * 6}

\makeatletter
\pgfdeclarelindenmayersystem{Christmas tree}{
    \symbol{C}{\pgfgettransform{\t} \expandafter\g@addto@macro\expandafter\pointlistleft\expandafter{\expandafter{\t}}}
    \symbol{c}{\pgfgettransform{\t} \expandafter\g@addto@macro\expandafter\pointlistright\expandafter{\expandafter{\t}}}
    \rule{S -> [+++G][---g]TS}
    \rule{G -> +H[-G]CL}
    \rule{H -> -G[+H]CL}
    \rule{g -> +h[-g]cL}
    \rule{h -> -g[+h]cL}
    \rule{T -> TL}
    \rule{L -> [-FFF][+FFF]F}
}
\makeatother

\begin{tikzpicture}[rotate=90]
\draw [color=green!50!black,l-system={Christmas tree,step=4pt,angle=16,axiom=LLLLLLSLFFF,order=10,randomize angle percent=20}] lindenmayer system -- cycle;

\pgfmathdeclarerandomlist{pointsleft}{\pointlistleft}
\pgfmathdeclarerandomlist{pointsright}{\pointlistright}
\pgfmathdeclarerandomlist{colors}{{red}{blue}{yellow}}

\foreach \i in {0,1,...,5}
{
    \pgfmathrandomitem{\c}{pointsleft}
    \pgfsettransform{\c}
    \pgfgettransformentries{\a}{\b}{\c}{\d}{\xx}{\yy}
    \pgfmathrandomitem{\c}{pointsright}
    \pgfsettransform{\c}
    \pgfgettransformentries{\a}{\b}{\c}{\d}{\XX}{\YY}
    \pgftransformreset

    \pgfmathsetmacro\calcy{min(\yy,\YY)-max((abs(\yy-\YY))/3,25pt)}

    \draw[draw=orange!50!black, fill=orange!50, decorate, decoration={shape backgrounds, shape=star, shape sep=3pt, shape size=4pt}, star points=5] (\xx,\yy) .. controls (\xx,\calcy pt) and (\XX,\calcy pt) .. (\XX,\YY);
}

\foreach \i in {0,1,...,15}
{
    \pgfmathrandomitem{\c}{pointsleft}
    \pgfsettransform{\c}
    \pgftransformresetnontranslations
    \draw[color=black] (0,0) -- (0,-4pt);
    \pgfmathrandomitem{\c}{colors}
    \shadedraw[ball color=\c] (0,-8pt) circle [radius=4pt];
}

\foreach \i in {0,1,...,15}
{
    \pgfmathrandomitem{\c}{pointsright}
    \pgfsettransform{\c}
    \pgftransformresetnontranslations
    \draw[color=black] (0,0) -- (0,-4pt);
    \pgfmathrandomitem{\c}{colors}
    \shadedraw[ball color=\c] (0,-8pt) circle [radius=4pt];
}

\end{tikzpicture}
\end{document}

ฉันจะบอกว่านี้จะขึ้นอยู่บนต้นไม้ Stefan Kottwitz ของโพสต์ครั้งแรกที่นี่ การบอกว่ามันเป็นไปตามต้นไม้ของคุณทำให้ดูเหมือนว่าคุณเขียนโค้ดทั้งหมดสำหรับมันซึ่งไม่เป็นความจริง มีคนอื่นเขียนโค้ดสำหรับต้นไม้จริงมากที่สุด
The Guy with The Hat

@RyanCarlson ความคิดที่จะใช้ระบบ lindenmayer เป็นพื้นฐานสำหรับการตกแต่งเป็นความคิดของฉันและถ้าคุณตรวจสอบอย่างรอบคอบทั้งรหัสที่คุณสามารถมองเห็นได้ว่าส่วน lindenmayer ของรหัสถูกออกแบบใหม่ให้มีส่วนเพิ่มเติม (เช่น รากของต้นไม้ซึ่งต้นกำเนิดขาด) นอกจากนั้นฉันไม่ลืมที่จะอ้างอิงต้นฉบับซึ่งทุกคนสามารถตรวจสอบการอ้างอิง (รวมถึง Peitgen และ Saupe ซึ่งอาจเป็นคนแรกที่จะร่างสมการของต้นไม้)
SztupY

34

Befunge 93

นี่คือต้นไม้ที่ไม่ได้ตกแต่ง:

&::00p20pv
vp010    <
v              p00<
>:0`!#v_" ",1-
v,"/"$<
>10g:2+v
vp01   <
>:0`!#v_" ",1-
v,"\"$<
>91+,00g1-::0`!#v_^
v        *2+1g02<
>:0`!#v_"-",1-
v g02$<
>91+,v
v    <
>:0`!#v_" ",1-
"||"$ <@,,

ตัวอย่างเอาต์พุตอินพุตคือ 10:

          /\
         /  \
        /    \
       /      \
      /        \
     /          \
    /            \
   /              \
  /                \
 /                  \
----------------------
          ||

เพิ่มของตกแต่งกันเถอะ:

&::00p20pv
vp010    <
v              p00<
>:0`!#v_" ",1-
v,"/"$<
>10g:2+v             >"O" v
vp01   <            >?v
>:0`!#v_           >?>>" ">,1-
v,"\"$<             >?<
>91+,00g1-::0`!#v_^  >"*" ^
v        *2+1g02<
>:0`!#v_"-",1-
v g02$<
>91+,v
v    <
>:0`!#v_" ",1-
"||"$ <@,,

ตัวอย่างผลลัพธ์:

          /\
         /O \
        /    \
       /   ** \
      /     *  \
     /    **   O\
    /* O* *  *   \
   / O      O     \
  / *  **   O*     \
 /   *OO   *  OOO * \
----------------------
          ||

32

HTML และ CSS

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Scalable christmas tree</title>
<style>
body {
  background-color: skyblue;
  background-size: 11px 11px, 21px 21px, 31px 31px;
  background-image: radial-gradient(circle at 5px 5px,white,rgba(255,255,255,0) 1px), radial-gradient(circle at 5px 5px,white,rgba(255,255,255,0) 2px), radial-gradient(circle at 5px 5px,white 1px,skyblue 1px);
}
div {
  float: left;
  border-style: solid;
  border-color: transparent;
  border-bottom-color: green;
  border-width: 20px;
  border-top-width: 0;
  border-bottom-width: 30px;
  border-bottom-left-radius: 35%;
  border-bottom-right-radius: 35%;
  box-shadow: red 0 15px 5px -13px;
  animation-name: light;
  animation-duration: 1s;
  animation-direction: alternate;
  animation-iteration-count: infinite;
  -webkit-animation-name: light;
  -webkit-animation-duration: 1s;
  -webkit-animation-direction: alternate;
  -webkit-animation-iteration-count: infinite;
}
section {
  float: left;
}
header {
  color: yellow;
  font-size: 30px;
  text-align: center;
  text-shadow: red 0 0 10px;
  line-height: .5;
  margin-top: 10px;
  animation-name: star;
  animation-duration: 1.5s;
  animation-direction: alternate;
  animation-iteration-count: infinite;
  -webkit-animation-name: star;
  -webkit-animation-duration: 1.5s;
  -webkit-animation-direction: alternate;
  -webkit-animation-iteration-count: infinite;
}
footer {
  float: left;
  width: 100%;
  height: 20px;
  background-image: linear-gradient(to right, transparent 45%, brown 45%, #600 48%, #600 52%, brown 55%, transparent 55%);
}
:target {
  display: none;
}
@keyframes star {
  from { text-shadow: red 0 0 3px; }
  to { text-shadow: red 0 0 30px; }
}
@-webkit-keyframes star {
  from { text-shadow: red 0 0 3px; }
  to { text-shadow: red 0 0 30px; }
}
@keyframes light {
  from { box-shadow: red 0 15px 5px -13px; }
  to { box-shadow: blue 0 15px 5px -13px; }
}
@-webkit-keyframes light {
  from { box-shadow: red 0 15px 5px -13px; }
  to { box-shadow: blue 0 15px 5px -13px; }
}
</style>
</head>
<body>
<section>
<header>&#x2605;</header>
<div id="0"><div id="1"><div id="2"><div id="3"><div id="4"><div id="5"><div id="6"><div id="7"><div id="8"><div id="9"><div id="10"><div id="11"><div id="12"><div id="13"><div id="14"><div id="15"><div id="16"><div id="17"><div id="18"><div id="19"><div id="20"><div id="21"><div id="22"><div id="23"><div id="24">
</div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div>
<footer></footer>
</section>
</body>
</html>

รองรับขนาดระหว่าง 1 และ 25 - เพียงเพิ่มขนาดลงใน URL เป็นตัวระบุส่วน

ทำงานได้ใน Chrome, Explorer และ Firefox ใน Opera น่าเกลียด แต่ส่วนที่ปรับใช้งานได้

การเข้าถึงตัวอย่าง:

http://localhost/xmas.html#5

ต้นคริสต์มาสขนาด 5

การเข้าถึงตัวอย่าง:

http://localhost/xmas.html#15

ต้นคริสต์มาสขนาด 15

ดูสด:

http://dabblet.com/gist/8026898

(มุมมองแบบสดไม่มี CSS นำหน้าผู้ขายและมีลิงก์เพื่อเปลี่ยนขนาด)


1
+1 ฉันชอบความคิดในการใช้:targetมาตราส่วนผลลัพธ์ :-)
squeamish ossifrage

32

ชวา

import java.awt.Dimension;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.Toolkit;
import java.awt.event.MouseEvent;
import java.awt.event.MouseListener;
import java.awt.geom.AffineTransform;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.net.URL;
import javax.imageio.ImageIO;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.SwingUtilities;

/**
 *
 * @author Quincunx
 */
public class ChristmasTree {
    public static double scale = 1.2;

    public static void main(String[] args) {
        SwingUtilities.invokeLater(new Runnable() {
            @Override
            public void run() {
                new ChristmasTree();
            }
        });
    }

    public ChristmasTree() {
        try {
            URL url = new URL("http://imgs.xkcd.com/comics/tree.png");
            BufferedImage img = ImageIO.read(url);

            JFrame frame = new JFrame();
            frame.setUndecorated(true);
            frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
            Dimension d = Toolkit.getDefaultToolkit().getScreenSize();

            BufferedImage result = 
                    new BufferedImage((int)(img.getWidth() * scale), 
                            (int) (img.getHeight() * scale), 
                            BufferedImage.TYPE_INT_RGB);
            Graphics2D g = (Graphics2D) result.getGraphics();
            g.drawRenderedImage(img, AffineTransform.getScaleInstance(scale, scale));

            JImage image = new JImage(result);
            image.setToolTipText("Not only is that terrible in general, but you "
                    + "just KNOW Billy's going to open the root present first, "
                    + "and then everyone will have to wait while the heap is "
                    + "rebuilt.");
            frame.add(image);
            frame.pack();
            frame.setVisible(true);

        } catch (IOException ex) {

        }
    }

    class JImage extends JPanel implements MouseListener {

        BufferedImage img;

        public JImage(){
            this(null);
        }
        public JImage(BufferedImage image){
            img = image;
            setPreferredSize(new Dimension(image.getWidth(), image.getHeight()));
            addMouseListener(this);
        }

        @Override
        public void paintComponent(Graphics g) {
            super.paintComponent(g);
            g.drawImage(img, WIDTH, WIDTH, this);
        }

        public void setImage(BufferedImage image) {
            img = image;
            repaint();
        }

        @Override
        public void mouseClicked(MouseEvent me) {
            System.exit(0);
        }

        @Override
        public void mousePressed(MouseEvent me) {

        }

        @Override
        public void mouseReleased(MouseEvent me) {

        }

        @Override
        public void mouseEntered(MouseEvent me) {

        }

        @Override
        public void mouseExited(MouseEvent me) {

        }
    }
}

หากต้องการเปลี่ยนขนาดให้เปลี่ยนscaleเป็นค่าดับเบิลอื่น ๆ (คงไว้ที่ 1 หากคุณต้องการเห็นอะไร)

เอาต์พุตตัวอย่าง (สำหรับ 1.0 เป็นสเกลขี้เกียจเกินกว่าที่จะจับภาพหน้าจอได้ดังนั้นเพียงโพสต์สิ่งที่ทำ):

ป้อนคำอธิบายรูปภาพที่นี่

โปรแกรมใช้ภาพนี้จากอินเทอร์เน็ตปรับขนาดภาพตามscaleจากนั้นวางไว้ในหน้าต่างที่ไม่ได้ตกแต่งซึ่งมีการแสดงผล การคลิกที่หน้าต่างจะเป็นการปิดโปรแกรม นอกจากนี้ยังมีข้อความเคล็ดลับเครื่องมือ แต่ไม่มีลิงก์


3
นี่ไม่ใช่ "รูปวาด" อะไรเลย
Mrchief

@Mrchief ความท้าทายไม่ใช่การวาดบางสิ่งบางอย่าง มันคือการสร้างต้นไม้ นี่คือการสร้างต้นไม้โดยการถ่ายรูป
Justin

2
คุณสร้างภาพด้วยตัวเอง? ไม่คุณเพิ่งดาวน์โหลดจากที่อื่น คำถามไม่ได้ที่จะดาวน์โหลดภาพและปรับขนาด ตรวจสอบคำตอบอื่น ๆ แล้วคุณจะเข้าใจว่า OP ขออะไรจริงๆ
Mrchief

10
@Mrchief คุณสังเกตเห็นใครเขียน OP หรือไม่ นี่เป็นหนึ่งในวิธีการแก้ปัญหาที่เป็นไปได้มากมายที่ฉันต้องการเมื่อฉันถามคำถามนี้
Justin

3
ฮา! ตบหัว! เนื่องจากโพสต์ของคุณเองฉันไม่เห็นเหตุผลมากมายที่จะโต้แย้งนอกเหนือไปจากการแสดงความคิดเห็นของฉันว่านี่ไม่ใช่สิ่งเดียวกับรหัสของคุณ "ทำ" บางสิ่งบางอย่าง (เช่นคำตอบที่เหลือ) เช่นเดียวกับการดาวน์โหลดภาพยนตร์ไม่เหมือนกับการสร้างภาพยนตร์
Mrchief

28

TI-89 พื้นฐาน

เพียงเพราะฉันต้องการเห็นต้นคริสต์มาสบนเครื่องคิดเลขของฉัน ฉันจะพิมพ์ที่นี่ตามที่ปรากฏบนเครื่องคิดเลข

:tree()
:Prgm
:
:Local size
:Prompt size
:
:Local d,x,y,str,orn
:size→x
:0→y
:{" "," "," "," "," "," "," "," ","°","∫","θ","O","©"}→orn
:size→d
:
:While d≥0
: d-1→d
: ""→str
: 
: While x≥0
:  str&" "→str
:  x-1→x
: EndWhile
: 
: str&"/"→str
: 2*y→x
:
: While x>0
:  str&elementAt(orn,rand(colDim(list▶mat(orn))))→str
:  x-1→x
: EndWhile
: 
: str&"\"→str
: Disp str
: y+1→y
: d→x
:EndWhile
:
:""→str
:
:For x,1,2*(size+2)
: str&"-"→str
:EndFor
:Disp str
:
:""→str
:For x,1,size+1
: str&" "→str
:EndFor
:str&"||"→str
:Disp str
:
:EndPrgm


:elementAt(l,i)
:Func
:Local m
:list▶mat(l)→m
:
:Local cd
:colDim(m)→cd
:
:If i>cd or i≤0 Then
: 1/0
:Else
: If i=cd Then
:  Return sum(mat▶list(subMat(m,1,i))) - sum(mat▶list(subMat(m,1,i+1)))
: Else
:  Return sum(mat▶list(subMat(m,1,i))) - sum(mat▶list(subMat(m,1,i+1)))
: EndIf
:EndIf
:EndFunc

วิธีนี้ทำงานเหมือนกับคำตอบ Befunge ของฉัน แต่ฉันใช้เครื่องประดับที่แตกต่างกัน ใช่elementAtฟังก์ชั่นการใช้ซ้ำของฉันทำให้โปรแกรมช้าลงเนื่องจากมีการแปลงจำนวนมากระหว่างรายการและเมทริกซ์ แต่อย่างที่ฉันเขียนไว้ก่อนหน้านี้ฉันตัดสินใจที่จะแก้ไข นอกจากนี้ฉันได้เรียนรู้ในขณะที่พิมพ์คำตอบนี้ที่©ทำให้เกิดความคิดเห็น (ฉันคิดว่ามันดูเหมือน@แต่เป็นตัวละครอื่น) ไม่เคยรู้เลยว่ามันคืออะไรมาก่อน

ตัวอย่างผลลัพธ์:

size?
7
        /\
       / O\
      /∫   \
     / ©  ∫°\
    / θ ∫   ∫\
   /°  °  ©  ©\
  /O  ∫  O °   \
 / θ  °©  ∫ O  θ\
------------------
        ||

ฉันรักคน's; พวกเขาดูเหมือนอ้อยขนม


รุ่นนี้คืออะไร?
SuperJedi224

@ SuperJedi224 ฉันเพิ่มเข้าไปในคำตอบ
Justin

27

ภาษา Wolfram ( Mathematica )

ตามที่กล่าวถึงในหัวข้อ Reddit ที่โด่งดัง: t * sin (t) tree ต้นคริสต์มาส

PD = .5; s[t_, f_] := t^.6 - f;
 dt[cl_, ps_, sg_, hf_, dp_, f_] := 
    {PointSize[ps], Hue[cl, 1, .6 + sg .4 Sin[hf s[t, f]]], 
     Point[{-sg s[t, f] Sin[s[t, f]], -sg s[t, f] Cos[s[t, f]], dp + s[t, f]}]};

 frames = ParallelTable[

    Graphics3D[Table[{dt[1, .01, -1, 1, 0, f], dt[.45, .01, 1, 1, 0, f], 
                      dt[1, .005, -1, 4, .2, f], dt[.45, .005, 1, 4, .2, f]}, 
 {t, 0, 200, PD}],

     ViewPoint -> Left, BoxRatios -> {1, 1, 1.3}, ViewVertical -> {0, 0, -1}, 
    ViewCenter -> {{0.5, 0.5, 0.5}, {0.5, 0.55}}, Boxed -> False, Lighting -> "Neutral", 
    PlotRange -> {{-20, 20}, {-20, 20}, {0, 20}}, Background -> Black],

   {f, 0, 1, .01}];

Export["tree.gif", frames]

ป้อนคำอธิบายรูปภาพที่นี่


คุณจะตั้งค่าขนาดไหนและส่งผลต่อต้นไม้ที่สร้างอย่างไร
จัดการระหว่าง

2
@ การจัดการนี้เป็นกราฟt*sin(t)ตามที่ฉันพูดในโพสต์ ดังนั้นการวางแผนสำหรับ t ที่มีขนาดใหญ่ขึ้นจะทำให้ต้นไม้ใหญ่ขึ้น:Table[..., {t, 0, 200, PD}]
Vitaliy Kaurov

24

Bash กับ Bc และ ImageMagick

#!/bin/bash

size="${1:-10}"

width=$(( size*25 ))
height=$(( size*size+size*10 ))

cos=( $( bc -l <<< "for (i=0;i<3.14*2;i+=.05) c(i)*100" ) )
sin=( $( bc -l <<< "for (i=0;i<3.14*2;i+=.05) s(i)*100" ) )
cos=( "${cos[@]%.*}" )
sin=( "${sin[@]%.*}" )

cos=( "${cos[@]/%-/0}" )
sin=( "${sin[@]/%-/0}" )

snow=()
needle=()
decor=()
for ((i=2;i<size+2;i++)); do
  for ((j=3;j<=31;j++)); do
    (( x=width/2+i*10+cos[62-j]*i*10/100 ))
    (( y=i*i+sin[j]*i*5/100 ))

    for ((e=0;e<i;e++)); do
      needle+=(
        -draw "line $x,$y $(( x+RANDOM%i-i/2 )),$(( y+RANDOM%i-i/2 ))"
        -draw "line $(( width-x )),$y $(( width-x+RANDOM%i-i/2 )),$(( y+RANDOM%i-i/2 ))"
      )
    done

    (( RANDOM%2 )) && (( x=width-x ))
    snow+=(
      -draw "circle $x,$(( y-i/2 )) $(( x+i/3 )),$(( y-i/2+i/3 ))"
    )

    (( RANDOM%10 )) || decor+=(
      -fill "rgb($(( RANDOM%5*20+50 )),$(( RANDOM%5*20+50 )),$(( RANDOM%5*20+50 )))"
      -draw "circle $x,$(( y+i )) $(( x+i/2 )),$(( y+i+i/2 ))"
    )
  done
done

flake=()
for ((i=0;i<width*height/100;i++)); do
  flake+=(
    -draw "point $(( RANDOM%width )),$(( RANDOM%height ))"
  )
done

convert \
  -size "${width}x$height" \
  xc:skyblue \
  -stroke white \
  -fill white \
  "${snow[@]}" \
  -blur 5x5 \
  "${flake[@]}" \
  -stroke brown \
  -fill brown \
  -draw "polygon $(( width/2 )),0 $(( width/2-size )),$height, $(( width/2+size )),$height" \
  -stroke green \
  -fill none \
  "${needle[@]}" \
  -stroke none \
  -fill red \
  "${decor[@]}" \
  x:

วิ่งตัวอย่าง:

bash-4.1$ ./xmas.sh 5

ตัวอย่างผลลัพธ์:

ต้นคริสต์มาสขนาด 5

วิ่งตัวอย่าง:

bash-4.1$ ./xmas.sh 15

ตัวอย่างผลลัพธ์:

ต้นคริสต์มาสขนาด 15


23

C

เอาต์พุตตัวอย่างสำหรับความลึก = 4, ซูม = 2.0

ต้นไม้

คำตอบนี้ใช้วิธีการที่ค่อนข้างแตกต่างจากคำตอบอื่น ๆ มันสร้างโครงสร้างต้นไม้โดยแยกย่อยซ้ำ แต่ละสาขาจะแสดงเป็นวงกลม ในที่สุดฟังก์ชั่นหลักจะสุ่มตัวอย่างวงกลมและเติมด้วยอักขระเมื่อพบกับวงกลม เนื่องจากทำโดยการสุ่มตัวอย่างฉาก (เช่นการติดตามเรย์) จึงสามารถปรับขนาดได้ภายใน ข้อเสียคือความเร็วเนื่องจากมันข้ามโครงสร้างต้นไม้ทั้งหมดสำหรับ "พิกเซล" ทุกคน!

อาร์กิวเมนต์บรรทัดคำสั่งแรกควบคุมความลึกของการแตกแขนง และสเกลควบคุมที่สอง (2 หมายถึง 200%)

#include <math.h>
#include <stdio.h>
#include <stdlib.h>

#define PI 3.14159265359

float sx, sy;

float sdCircle(float px, float py, float r) {
    float dx = px - sx, dy = py - sy;
    return sqrtf(dx * dx + dy * dy) - r;
}

float opUnion(float d1, float d2) {
    return d1 < d2 ? d1 : d2;
}

#define T px + scale * r * cosf(theta), py + scale * r * sin(theta)

float f(float px, float py, float theta, float scale, int n) {
    float d = 0.0f;
    for (float r = 0.0f; r < 0.8f; r += 0.02f)
        d = opUnion(d, sdCircle(T, 0.05f * scale * (0.95f - r)));

    if (n > 0)
        for (int t = -1; t <= 1; t += 2) {
            float tt = theta + t * 1.8f;
            float ss = scale * 0.9f;
            for (float r = 0.2f; r < 0.8f; r += 0.1f) {
                d = opUnion(d, f(T, tt, ss * 0.5f, n - 1));
                ss *= 0.8f;
            }
        }

    return d;
}

int ribbon() {
    float x = (fmodf(sy, 0.1f) / 0.1f - 0.5f) * 0.5f;
    return sx >= x - 0.05f && sx <= x + 0.05f;
}

int main(int argc, char* argv[]) {
    int n = argc > 1 ? atoi(argv[1]) : 3;
    float zoom = argc > 2 ? atof(argv[2]) : 1.0f;
    for (sy = 0.8f; sy > 0.0f; sy -= 0.02f / zoom, putchar('\n'))
        for (sx = -0.35f; sx < 0.35f; sx += 0.01f / zoom) {
            if (f(0, 0, PI * 0.5f, 1.0f, n) < 0.0f) {
                if (sy < 0.1f)
                    putchar('.');
                else {
                    if (ribbon())
                        putchar('=');
                    else
                        putchar("............................#j&o"[rand() % 32]);
                }
            }
            else
                putchar(' ');
        }
}

2
ฉันคิดว่ามันปลอดภัยที่จะบอกว่านี่เป็นคำตอบที่น่าประทับใจที่สุดทางเทคนิคสำหรับคำถามนี้
Stuntddude

20

Mathematica ASCII

ฉันชอบศิลปะ ASCII ดังนั้นฉันจึงเพิ่มคำตอบที่แตกต่างกันมาก - โดยเฉพาะอย่างยิ่งดังนั้นจึงสั้นใน Mathematica:

Column[Table[Row[RandomChoice[{"+", ".", "*", "~", "^", "o"}, k]], {k, 1, 35, 2}], 
Alignment -> Center]

ป้อนคำอธิบายรูปภาพที่นี่

และตอนนี้ด้วยความซับซ้อนที่เพิ่มขึ้นเล็กน้อยจากต้นไม้ ASCII แบบไดนามิกที่ปรับขนาดได้ ดูอย่างใกล้ชิด - ต้นไม้กำลังเปลี่ยนไป - หิมะเกาะกิ่งไม้แล้วก็ตกลง ;-)

DynamicModule[{atoms, tree, pos, snow, p = .8, sz = 15},

 atoms = {
   Style["+", White],
   Style["*", White],
   Style["o", White],
   Style[".", Green],
   Style["~", Green],
   Style["^", Green],
   Style["^", Green]
   };

 pos = Flatten[Table[{m, n}, {m, 18}, {n, 2 m - 1}], 1];

 tree = Table[RandomChoice[atoms, k], {k, 1, 35, 2}];

 snow = Table[
   RotateLeft[ArrayPad[{RandomChoice[atoms[[1 ;; 2]]]}, {0, sz}, " "],
     RandomInteger[sz]], {sz + 1}];

 Dynamic[Refresh[

   Overlay[{

     tree[[Sequence @@ RandomChoice[pos]]] = RandomChoice[atoms];
     Column[Row /@ tree, Alignment -> Center, Background -> Black],

     Grid[
      snow = 
       RotateRight[
        RotateLeft[#, 
           RandomChoice[{(1 - p)/2, p, (1 - p)/2} -> {-1, 0, 1}]] & /@
          snow
        , {1, 0}]]

     }, Alignment -> Center]

   , UpdateInterval -> 0, TrackedSymbols -> {}]
  ]
 ]

ป้อนคำอธิบายรูปภาพที่นี่


ทำได้ดีนี่. คุณปรับขนาดที่ไหน นั่นคือTableพารามิเตอร์35 ในหรือไม่
จัดการ

@ การจัดการใช่ 35 ในตาราง ขอบคุณ;)
Vitaliy Kaurov

19

ฉันทำสิ่งนี้เพื่อความท้าทายใน / r / dailyprogrammer (ไม่แน่ใจว่าการใช้รหัสซ้ำกับจิตวิญญาณ / กฎของสิ่งนี้) แต่:

brainfuck ใช้เป็นตัวเลข (ความยาวของแถวด้านล่างของใบไม้) และอักขระสองตัว ช่องว่างระหว่างแต่ละ

อินพุตตัวอย่าง: 13 = +

ตัวอย่างผลลัพธ์:

      +
     +++
    +++++
   +++++++
  +++++++++
 +++++++++++
+++++++++++++
     ===

รหัส:

                   >
                  ,--
                 -----
                -------
               ---------
              ---------[+
             +++++++++++++
            +++++++++++++++
           +++<[>>++++++++++
          <<-]>--------------
         ---------------------
        -------------[<+>-]>[<<
       +>>-]<,------------------
      --------------],>,,>>++++[<
     ++++++++>-]++++++++++>+<<<<<-
    [>>>>>>+>+<<<<<<<--]>>>>>>>[<<<
   <<<<++>>>>>>>-]<<<<<<<[>>>>>>[<<<
  .>>>>+<-]>[<+>-]<<[<<<.>>>>>+<<-]>>
 [<<+>>-]<<<.>>><-<++<<<<<--]>>...>>>-
--[>+<<<<..>>>--]<.>>[<<<.>>>>+<-]<<<<<
                ...>>>.

1
ในที่สุดคำตอบของสมอง!
Pharap

16

การประมวลผล

เศษส่วนต้นคริสต์มาสดั้งเดิม ตำแหน่ง Mouse Y เป็นตัวกำหนดขนาดใช้ปุ่มลูกศรขึ้นและลงเพื่อเปลี่ยนจำนวนรุ่น

int size = 500;

int depth = 10;

void setup() {
  frameRate(30);
  size(size, size, P2D);
}

void draw() {
  background(255);
  tree(size/2.0, size, 0.0, radians(0), radians(108), (size - mouseY)/3, depth);
  tree(size/2.0, size, 0.0, radians(108), radians(0), (size - mouseY)/3, depth);
}

void keyPressed() {
  if(keyCode == UP) depth++;
  if(keyCode == DOWN) depth--;
  depth = max(depth, 1);
}

void tree(float posX, float posY, float angle, float forkRight, float forkLeft, float length, int generation) {
  if (generation > 0) {
    float nextX = posX + length * sin(angle);
    float nextY = posY - length * cos(angle);

    line(posX, posY, nextX, nextY);

    tree(nextX, nextY, angle + forkRight, forkRight, forkLeft, length*0.6, generation - 1);
    tree(nextX, nextY, angle - forkLeft,  forkRight, forkLeft, length*0.6, generation - 1);
  }
}

ช่างเป็นต้นคริสต์มาสที่น่ารักคุณไม่คิดเหรอ?

Or, if you prefer a fuller tree:

int size = 500;

int depth = 10;

void setup() {
  frameRate(30);
  size(size, size, P2D);
}

void draw() {
  background(255);
  tree(size/2.0 - 5, size, 0.0, 0.0, (size - mouseY)/3, depth);
}

void keyPressed() {
  if(keyCode == UP) depth++;
  if(keyCode == DOWN) depth--;
  depth = max(depth, 1);
}

void tree(float posX, float posY, float angle, float fork, float length, int generation) {
  if (generation > 0) {
    float nextX = posX + length * sin(angle);
    float nextY = posY - length * cos(angle);

    line(posX, posY, nextX, nextY);

    tree(nextX, nextY, angle + fork + radians(108), fork, length*0.6, generation - 1);
    tree(nextX, nextY, angle - fork,                fork, length*0.6, generation - 1);
    tree(nextX, nextY, angle + fork - radians(108), fork, length*0.6, generation - 1);
  }
}

ฉันรู้สึกแย่มากที่ใครบางคนทุบตีฉันเพื่อโพสต์ต้นไม้เศษส่วนแม้ว่าฉันจะอยู่ข้างหน้าพวกเขาในความคิดและในความเป็นจริงเริ่มทำงานกับมัน: /


14

ทับทิม

((1..20).to_a+[6]*4).map{|i|puts ('*'*i*2).center(80)}

สวัสดีปีใหม่

*คุณสามารถปรับแต่งการส่งออกโดยการเปลี่ยน
สำหรับต้นไม้สีเขียว:((1..20).to_a+[6]*4).map{|i|puts "\e[32m"+('*'*i*2).center(80)}

วิธีที่ 2 (ต้นคริสต์มาสที่ดูไม่เหมือนลูกศร)

((1..6).to_a+(3..9).to_a+(6..12).to_a+[3]*4).map{|i|puts "\e[32m"+('*'*i*4).center(80)}

สวัสดีปีใหม่

วิธีที่ 3

((1..20).to_a+[6]*4).map{|i|puts' '*(20-i)+'*'*(2*i-1)}

2
นี่คือลูกศรมากกว่าจากนั้นต้นคริสต์มาส!
klingt.net

4
@ klingt.net * กว่า
NARKOZ

ใช้เวลาในการจุดไฟต้นคริสต์มาส
NARKOZ

และสถานที่ที่คุณระบุขนาด?
จัดการ

@ การจัดการในช่วง 1..20, 1..6ฯลฯ
NARKOZ

14

กราฟิกเต่า

ป้อนคำอธิบายรูปภาพที่นี่

ขึ้นอยู่กับคุณสมบัติของเกลียวออยเลอร์

รหัส:

ป้อนคำอธิบายรูปภาพที่นี่

สเกลจะถูกกำหนดโดยขนาดขั้นตอน ( move forward by: 6) รุ่นโต้ตอบสามารถใช้ได้ที่นี่

PS แรงบันดาลใจจากนี้คำถาม


"ปรับขนาดได้" นี้อยู่ที่ไหน นอกจากนั้นนี่ยอดเยี่ยมมาก!
Justin

@Quincunx move forward by 6คุณสามารถเปลี่ยนขนาดได้โดยการเปลี่ยน ตัวอย่างเช่น10จะสร้างต้นไม้ที่มีขนาดใหญ่ขึ้น ที่จริงแล้วไม่มีการป้อนข้อมูลใน "ภาษา" นี้ (หรือรหัสทั้งหมดสามารถถือว่าเป็นอินพุต;))
ybeltukov

14

การประมวลผล

ฉันสร้างตัวสร้างต้นไม้นี้โดยใช้ระบบ L และเต่า

ต้นไม้หนึ่งต้น

รหัส:

//My code, made from scratch:
final int THE_ITERATIONS = 7;
final float SCALE = 1;
final int ANGLE = 130;
final int SIZE = 4;

final int ITERATIONS = THE_ITERATIONS - 1;

int lineLength;

String lSystem;
ArrayList<Turtle> turtles;

int turtleIndex;
int lSystemIndex;

void setup()
{
  size(320, 420);
  background(255);
  translate(width / 2, height - 70);

  lineLength = ITERATIONS * 2 + 2;

  lSystem = "[-F][+F]F";

  turtles = new ArrayList<Turtle>(ITERATIONS + 1);
  lSystemIndex = 0;

  calculateLSystem();
  println(lSystem);

  turtles.add(new Turtle(0, 0));

  doTurtles();
  save("Tree.png");
}

void doTurtles()
{
  while(lSystemIndex < lSystem.length())
  {
    print("\"" + lSystem.charAt(lSystemIndex) + "\": ");
    if(lSystem.charAt(lSystemIndex) == 'F')
    {
      turtleForward();
    }
    else if(lSystem.charAt(lSystemIndex) == '[')
    {
      lineLength -= 2;
      addTurtle();
      println(turtles.size());
    }
    else if(lSystem.charAt(lSystemIndex) == ']')
    {
      lineLength += 2;
      removeTurtle();
      println(turtles.size());
    }
    else if(lSystem.charAt(lSystemIndex) == '+')
    {
      turtleRight();
    }
    else if(lSystem.charAt(lSystemIndex) == '-')
    {
      turtleLeft();
    }
    lSystemIndex++;
  }
}

void addTurtle()
{
  turtles.add(new Turtle(turtles.get(turtles.size() - 1)));
}

void removeTurtle()
{
  turtles.remove(turtles.size() - 1);
}

void turtleLeft()
{
  turtles.get(turtles.size() - 1).left(ANGLE + random(-5, 5));
}

void turtleRight()
{
  turtles.get(turtles.size() - 1).right(ANGLE + random(-5, 5));
}

void turtleForward()
{
  print(turtles.get(turtles.size() - 1) + ": ");
  strokeWeight(min(lineLength / SIZE, 1));
  stroke(5 + random(16), 90 + random(16), 15 + random(16));
  if(turtles.size() == 1)
  {
    strokeWeight(lineLength / 2);
    stroke(100, 75, 25);
  }
  turtles.get(turtles.size() - 1).right(random(-3, 3));
  turtles.get(turtles.size() - 1).forward(lineLength);
}

void calculateLSystem()
{
  for(int i = 0; i < ITERATIONS; i++)
  {
    lSystem = lSystem.replaceAll("F", "F[-F][+F][F]");
  }
  lSystem = "FF" + lSystem;
}

void draw()
{

}

//——————————————————————————————————————————————————————
// Turtle code, heavily based on code by Jamie Matthews
// http://j4mie.org/blog/simple-turtle-for-processing/
//——————————————————————————————————————————————————————

class Turtle {
  float x, y; // Current position of the turtle
  float angle = -90; // Current heading of the turtle
  boolean penDown = true; // Is pen down?
  int lineLength;

  // Set up initial position
  Turtle (float xin, float yin) {
    x = xin;
    y = yin;
    //lineLength = lineLengthin;
  }

  Turtle (Turtle turtle) {
    x = turtle.x;
    y = turtle.y;
    angle = turtle.angle;
    //lineLength = turtle.lineLength - 1;
  }

  // Move forward by the specified distance
  void forward (float distance) {
    distance = distance * SIZE * random(0.9, 1.1);
    // Calculate the new position
    float xtarget = x+cos(radians(angle)) * distance;
    float ytarget = y+sin(radians(angle)) * distance;

    // If the pen is down, draw a line to the new position
    if (penDown) line(x, y, xtarget, ytarget);
    println(x + ", " + y + ", " + xtarget + ", " + ytarget);
    // Update position
    x = xtarget;
    y = ytarget;
  }

  // Turn left by given angle
  void left (float turnangle) {
    angle -= turnangle;
    println(angle);
  }

  // Turn right by given angle
  void right (float turnangle) {
    angle += turnangle;
    println(angle);
  }
}

2
ใช่ ระบบ L!
luser droog

1
ฉันเห็นด้วยว่ามันเป็นสิ่งที่สมจริงที่สุด :)
Timtech

@ Timtech ฉันไม่เห็นด้วย ผมคิดว่านี่เป็นครั้งที่สองที่สมจริงที่สุดหลังจากม.ค. Dvorak คำตอบของ ฉันหมายถึงดูที่เข็มเหล่านี้ (บนอันนี้)! พวกมันรวมกันเป็นกลุ่มในรูปแบบที่ฉันไม่ได้เห็นบนต้นไม้เขียวชอุ่ม อย่างไรก็ตามต้นไม้ของแจนดูเหมือนจะเป็นต้นอ่อนมากสำหรับฉัน
Justin

1
@Quincunx ฉันต้องพลาดไป ถึงอย่างนี้ก็ดูดีทีเดียว
Timtech

@Quincunx Jan's tree - และ Howard's เกินไป - มันเจ๋งมาก แต่ไม่จำเป็นต้องสมจริงมากนัก แจนยังยอมรับว่าต้นไม้เป็นเพียง "quasirealistic" - RyanCarlson 10 วินาทีที่แล้ว
The Guy with The Hat

12

JavaScript (ทำงานบนหน้าใดก็ได้ในคอนโซล)

ฉันเล่นกอล์ฟ แต่ก็ตัดสินใจไม่ทำอย่างที่คุณเห็นว่ามีจำนวนเวทมนตร์มากมาย: P

// size
s = 300

document.write('<canvas id=c width=' + s + ' height=' + s + '>')
c = document.getElementById('c').getContext('2d')
c.fillStyle = '#0D0'
for (var i = s / 3; i <= s / 3 * 2; i += s / 6) {
  c.moveTo(s / 2, s / 10)
  c.lineTo(s / 3, i)
  c.lineTo(s / 3 * 2, i)
  c.fill()
}
c.fillStyle = '#DA0'
c.fillRect(s / 2 - s / 20, s / 3 * 2, s / 10, s / 6)

ผลลัพธ์สำหรับ s = 300:

ภาพหน้าจอ

s = 600:

ภาพหน้าจอ


2
คุณกำลังจะตกแต่งต้นไม้หรือไม่? :-)
Justin

1
@Quincunx อาจเป็นไปได้ว่าฉันจะทำงานต่อไป :) :)
Doorknob

2
GAH! อัฒภาคอยู่ที่ไหน!
Andrew Larsson


10

ภาษาผู้สร้างเกม

spr_tree

spr_tree

ต้นไม้สร้างเหตุการณ์

image_speed=0
size=get_integer("How big do you want me to be?#Integer between 1 and 10, please!",10)
image_index=size-1

ห้อง 402 คูณ 599

ต้นไม้ถูกวางไว้ที่ (0,0)

โบนัส! คุณสามารถปรับขนาดต้นคริสต์มาสหลังจากป้อนข้อมูลเริ่มต้นด้วยปุ่ม 0-9


8

AppleScript + SE คำตอบ

หยิบขึ้นมาโดยบังเอิญในขณะที่แก้ไขคำตอบในคำถามนี้ ไปคิด

ใช้สิ่งนี้โดยเรียกใช้รหัสพิมพ์หมายเลขที่คุณต้องการรูดไปที่โพสต์ SE และคลิกในช่องข้อความ วิธีนี้ใช้ประโยชน์จากความจริงที่ว่าราคาสแต็ค

tell application "System Events"
    set layers to (display dialog "" default answer "")'s text returned as number
    delay 5
    repeat layers times
        keystroke ">"
    end repeat
end tell

เอาท์พุท (อินพุต 50):

>


6

ตกแต่งฟอร์แทรนต้นไม้

    character(len=36) :: f='/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\'
    character(len=18) :: g = '                  '
    character(len=14) :: p = ".x$.+oO+oO.#,~"
    character(len=10) :: q

    n = iargc()
    if (n /= 1) then 
        k = len(g)
    else
        call getarg(1,q) 
        read(q,*) k
    end if
    l = modulo(k,len(g))+1
    do i=1,l
        j = mod(i,len(p)-1)+1
        print *,g(1:l-i),p(j:j),f(1:2*i),p(j+1:J+1)
        end do
    print *,g(1:l-1),f(1:4)
    end

ต้นไม้มีขนาดที่ จำกัด แต่เชื่อว่ามันสะท้อนชีวิตของต้นคริสต์มาสได้อย่างแม่นยำ

จากต้นไม้ทารก:

$./tree
 x/\$
 /\/\

ถึงต้นไม้วัยรุ่น:

$./tree 6
       x/\$
      $/\/\.
     ./\/\/\+
    +/\/\/\/\o
   o/\/\/\/\/\O
  O/\/\/\/\/\/\+
 +/\/\/\/\/\/\/\o
       /\/\

ถึงผู้ใหญ่:

$./tree 17
                  x/\$
                 $/\/\.
                ./\/\/\+
               +/\/\/\/\o
              o/\/\/\/\/\O
             O/\/\/\/\/\/\+
            +/\/\/\/\/\/\/\o
           o/\/\/\/\/\/\/\/\O
          O/\/\/\/\/\/\/\/\/\.
         ./\/\/\/\/\/\/\/\/\/\#
        #/\/\/\/\/\/\/\/\/\/\/\,
       ,/\/\/\/\/\/\/\/\/\/\/\/\~
      ./\/\/\/\/\/\/\/\/\/\/\/\/\x
     x/\/\/\/\/\/\/\/\/\/\/\/\/\/\$
    $/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\.
   ./\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\+
  +/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\o
 o/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\/\O
                  /\/\    

5

ชวา

import java.awt.Color;
import java.awt.Graphics2D;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
import java.util.*;

import javax.imageio.ImageIO;


public class ChristmasTree {
    static class Point{
        Point(int a,int b){x=a;y=b;}
        int x,y;
        double distance(Point o){
            int dx=x-o.x;
            int dy=y-o.y;
            return Math.sqrt(dx*dx+dy*dy);
        }
    }
    static int siz;
    static BufferedImage b;
    static Random r=new Random();
    public static void main(String[]args) throws IOException{

        if(args.length==0){
            siz=(new Scanner(System.in)).nextInt();
        }else{
            siz=Integer.parseInt(args[0]);
        }
        b=new BufferedImage(20*siz,30*siz,BufferedImage.TYPE_INT_RGB);
        Graphics2D g=(Graphics2D)b.getGraphics();
        g.setColor(new Color(140,70,20));
        int h=b.getHeight();h*=0.4;
        for(int i=(int)(0.4*b.getWidth());i<(int)(0.6*b.getWidth());i++){
            if(r.nextDouble()<0.3){
                g.drawLine(i,b.getHeight(),i+r.nextInt(2)-1,h);
            }
        }
        for(int i=h;i<b.getHeight();i++){
            if(r.nextDouble()<0.3){
                g.drawLine((int)(0.4*b.getWidth()),i,(int)(0.6*b.getWidth()),i);
            }
        }
        for(int i=0;i<siz;i++){
            g.setColor(new Color(r.nextInt(4),150+r.nextInt(15),20+r.nextInt(7)));
            g.drawLine(b.getWidth()/2-(int)(b.getWidth()*0.42*i/siz),(int)(b.getHeight()*0.9)+r.nextInt(5)-2,b.getWidth()/2+(int)(b.getWidth()*0.42*i/siz),(int)(b.getHeight()*0.9)+r.nextInt(5)-2);
            g.setColor(new Color(r.nextInt(4),150+r.nextInt(15),20+r.nextInt(7)));
            g.drawLine(b.getWidth()/2-(int)(b.getWidth()*0.42*i/siz),(int)(b.getHeight()*0.9),b.getWidth()/2,(int)(b.getHeight()*(0.1+(.06*i)/siz)));
            g.setColor(new Color(r.nextInt(4),150+r.nextInt(15),20+r.nextInt(7)));
            g.drawLine(b.getWidth()/2+(int)(b.getWidth()*0.42*i/siz),(int)(b.getHeight()*0.9),b.getWidth()/2,(int)(b.getHeight()*(0.1+(.06*i)/siz)));
        }
        g.setColor(new Color(150,120,40));
        g.fillOval((b.getWidth()-siz-2)/2,b.getHeight()/10,siz+2,siz+2);
        g.setColor(new Color(250,240,80));
        g.fillOval((b.getWidth()-siz)/2,b.getHeight()/10,siz,siz);
        List<Color>c=Arrays.asList(new Color(0,255,0),new Color(255,0,0),new Color(130,0,100),new Color(0,0,200),new Color(110,0,200),new Color(200,205,210),new Color(0,240,255),new Color(255,100,0));
        List<Point>pts=new ArrayList<>();
        pts.add(new Point((b.getWidth()-siz)/2,b.getHeight()/10));
        loop:for(int i=0;i<8+siz/4;i++){
            int y=r.nextInt((8*b.getHeight())/11);
            int x=1+(int)(b.getWidth()*0.35*y/((8*b.getHeight())/11));
            x=r.nextInt(2*x)-x+b.getWidth()/2;
            y+=b.getHeight()/8;
            g.setColor(c.get(r.nextInt(c.size())));
            x-=siz/2;
            Point p=new Point(x,y);
            for(Point q:pts){
                if(q.distance(p)<1+2*siz)continue loop;
            }
            pts.add(p);
            g.fillOval(x,y,siz,siz);
        }
        ImageIO.write(b,"png",new File("tree.png"));
    }
}

ตัวอย่างผลลัพธ์:

size = 3:

ป้อนคำอธิบายรูปภาพที่นี่

size = 4:

ป้อนคำอธิบายรูปภาพที่นี่

size = 5:

ป้อนคำอธิบายรูปภาพที่นี่

size = 12:

ป้อนคำอธิบายรูปภาพที่นี่

size = 20:

ป้อนคำอธิบายรูปภาพที่นี่


1
ฉันไม่ได้สังเกตเรื่องนี้มาก่อน +1 สุดยอดมาก
ปาเก็ตตี้

4

REBOL

ด้วยภาษาถิ่นเพื่อแสดงสัญลักษณ์ make-treeการเปลี่ยนขนาดของต้นไม้เพียงแค่เปลี่ยนพารามิเตอร์ของ

make-tree: func [int /local tr] [
  tr: copy []
  length: (int * 2) + 3
  repeat i int [
      repeat j 3 [
            ast: to-integer ((i * 2) - 1 + (j * 2) - 2)
            sp: to-integer (length - ast) / 2
            append/dup tr space sp 
            append/dup tr "*" ast 
            append tr lf
      ]
  ]
  append/dup tr space (length - 1) / 2
  append tr "|"
  append tr lf
  tr
]

print make-tree 3

ต้นไม้ที่มี 3 ชั้น ต้นไม้ที่มี 5 ชั้น


3
คุณจะตั้งค่าขนาดไหนและส่งผลต่อต้นไม้ที่สร้างอย่างไร
จัดการ

@Manatwork เพื่อเปลี่ยนtreeบล็อก คุณสามารถปรับขนาดหรือเปลี่ยนสัญลักษณ์บางอย่างตามที่คุณต้องการ
Wayne Cui

@WayneTsui สิ่งนี้ไม่เป็นไปตามข้อกำหนดของ OP "ขนาดต้องเลือกได้โดยวิธีการป้อนข้อมูลบางอย่าง"และ"อินพุตที่มีขนาดใหญ่ควรสร้างต้นไม้ที่มีขนาดใหญ่กว่า"
ulidtko

1
ฟังก์ชั่น make-tree ใหม่จาก @kealist
Wayne Cui

4

หลาม

import sys
w = sys.stdout.write
def t(n,s):
    for i in range(n):
        for a in range(n-i):
            w(" ")
        w("[")
        for l in range(i<<1):
            if i==n-1:
                w("_")
            else:
                w("~")
        w("]")
        print("")
    for o in range(s):
        for i in range(n):
            w(" ")
        print("[]")

t(10, 2)

ป้อนคำอธิบายรูปภาพที่นี่


1

Ti-Basic 84

ขอขนาด:

              :
            Input 
           S:Lbl 1
            S-1→S
              :
             "||
            "+""→
           Str1:" 
             "→Str2
         :Disp Str2+
        "   **":Disp 
       Str2+"  "+"*"+
      Str1+"*":Disp " 
     "+Str1+"*-"+"||-*
    ":Disp Str1+"*--||-
   -*":Disp "   *---||--
  -*":Disp "  *----||----
 *":Disp Str1+"   "+Str2+"
":If S>0:Goto 2:Goto 1:Lbl 
              2

เอาท์พุท (ขนาด 1):

       **
      *||*
     *-||-*
    *--||--*
   *---||---*
  *----||----*
       ||

1
เลือกขนาดได้ที่ไหน? นี่เป็นต้นไม้ขนาดคงที่
Justin

1
แก้ไข @Quincunx แล้ว
Timtech

4
-1; คุณไม่สามารถแทรกช่องว่างโดยพลการลงในโปรแกรม TI-Basic
lirtosiast
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.