MetaBlog

2017-07-31Írj Képaláírást


upload:IrjKepalairast/infinite_loop.png

Miért akarják ezek, hogy öljek? Hát nem elég, hogy a hangok mindig azt mondják hogy gyilkolj? De én nem fogok hinni nekik, mert a hangok hazudnak, de ha még ezek is azt mondják hogy öljek akkor most már gyilok lesz hát minek fogyasztja az ilyen a drága oxigént, minek eszik iszik fosik ha aztán annak ilyen kód a vége, hát az én idegeim sincsenek kötélből és már megint a hangok jaj

Tagek:
 
Utoljára módosította UPi 2017.VII.31 15:26-n; 2 hozzászólás;
Bejegyzés módosítása | PermaLink

2017-07-29Írj Képaláírást


upload:IrjKepalairast/From_Clipboard.jpg

Tagek:
 
Utoljára módosította SAdam 2017.VII.29 23:57-n; 2 hozzászólás;
Bejegyzés módosítása | PermaLink
100%

2017-07-27Írj Képaláírást


upload:IrjKepalairast/WP_20170724_001.jpg

Tagek:
 
Utoljára módosította Descant 2017.VII.27 09:23-n; 2 hozzászólás;
Bejegyzés módosítása | PermaLink

AdásszünetSur Ba Programming Challenge


Kedves nézőink,

Megszakítjuk adásunkat, hogy bosszantsuk Önöket.
Továbbá: http://spectrum.ieee.org/static/interactive-the-top-programming-languages-2017

Üdvözlettel,
A rendező gárda.

Tagek:
 
Utoljára módosította UPi 2017.VII.23 16:36-n; 0 hozzászólás;
Bejegyzés módosítása | PermaLink

2017-07-22Írj Képaláírást


upload:Descant/edge.png

A felső sor

Tagek:
 
Utoljára módosította Descant 2017.VII.22 13:10-n; 1 hozzászólás;
Bejegyzés módosítása | PermaLink

WWMD?Írj Képaláírást


"What Would Malcolm Do...?"

upload:IrjKepalairast/IMG_20170702_WA0002.jpeg

...ha egy retardált majom hozzábilincseli a bringáját az övéhez?

Tagek:
 
Utoljára módosította UPi 2017.VII.02 15:30-n; 2 hozzászólás;
Bejegyzés módosítása | PermaLink

A rekurziótól begolyózomSur Ba Programming Challenge


#!/usr/bin/python

import cgi
import cgitb
cgitb.enable()

form = cgi.FieldStorage()

def get_int_param(name, default):
    val = form.getvalue(name)
    if (val is None):
        return default
    return int(val)


def draw_circle(cx, cy, r):
    return '<circle cx="%f" cy="%f" r="%f" style="fill: none; stroke: #000000; " stroke-width="%d" />' % (cx, cy, r, 1)


def draw_circle_fractal(cx, cy, r, depth):
    result = draw_circle(cx, cy, r);
    if (depth > 0):
        r2 = r * 0.464101615
        r3 = r2 * 0.5773502690
        result = result + draw_circle_fractal(cx, cy - r + r2, r2, depth - 1)
        result = result + draw_circle_fractal(cx - r2, cy + r3, r2, depth - 1)
        result = result + draw_circle_fractal(cx + r2, cy + r3, r2, depth - 1)
    return result

print """Content-type: image/svg+xml

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg
   xmlns:svg="http://www.w3.org/2000/svg"
   xmlns="http://www.w3.org/2000/svg"
   viewBox="0 0 600 600"
   version="1.1"
   height="600"
   width="600">
  <g>%s</g>
</svg>
""" % draw_circle_fractal(300300300, get_int_param("depth"4));

http://apocalypse.rulez.org/~upi/surba/circles.py?depth=2 [source]
http://apocalypse.rulez.org/~upi/surba/circles.py?depth=6 [source]
(Lehetőleg 6 feletti mélységben NE, mert megdöglik a számítógép!)

Hát húha. Itt egy csomó minden történt, ami eddig nem történt. Én meg nem szeretem, ha a dolgok másmilyenek! Lássuk, mi minden újdonsággal szolgál a mai csoda!

Függvények: Eddig csak a Python saját beépített függvényeit használtuk fel, mint pl az int, valamint a könyvárból előcsemegézett függvényeket, mint a cgi.FieldStorage. Eljött most az ideje, hogy sajátokat is csináljunk. Például, a get_int_param azt a bravúrt oldja meg nekünk, hogy beolvas és rögtön egész számmá alakít egy paramétert nekünk, ha pedig hiányozna (None az értéke), akkor egy alapértelmezett számot ad vissza helyette.

Ráadásul a függvények más függvényeket is meg tudnak hívni, például a draw_circle_fractal meghívja a draw_circle nevűt. Ha egy függvény pedig önmagát hívja meg, akkor azt rekurzív függvénynek hívjuk, és rettegünk tőle, hogy nehogy végtelen ciklust eredményezzen.

String formattálás: Eddig stringeket csak a + operátorral rakosgattunk össze. Van egy kényelmesebb módszer is: a formattálás, ami a stringet követő % operátorral működik. Fedezzük fel ennek a rejtelmeit!

Feladatok

  • Mi a szent szar a 0.464101615 és 0.5773502690? Ezek hogyan jöttek ki az UPinak?
  • Legyen paraméterezhető a körök vonalvastagsága, alapértelmezetten legyen 1.
  • A páros mélységben található köröket töltsük ki kék, a páratlanokat zöld színnel.
  • Ne három kör legyen egyben, hanem négy.
  • Bónusz feladat: Ne is, inkább öt!
  • Bónuszabb feladat: Rajzoljuk ki a Koch-görbét.
  • Legbónuszabb feladat: Rajzoljuk ki a Sárkány-görbét.
Tagek:
 
Utoljára módosította UPi 2017.VI.29 18:12-n; 2 hozzászólás;
Bejegyzés módosítása | PermaLink

Ha egy listát tudnék vezetni az összes esetről...Sur Ba Programming Challenge


...szerencsére tudok. A Pythonban létezik egy "lista" nevű adatszerkezet, ami pont az, amit a név alapján gondolnánk.

Egy üres listát a [] literállal hozhatunk létre, vagy akár rögtön bele is rámolhatunk dolgokat: [10, 20.3, "alma", x] egy listát hoz létre amiben egy egész, egy valós, egy szöveg és az x változó értéke van.

#!/usr/bin/python

import random
import cgitb
cgitb.enable()

numbers = []
for x in range(050):
    numbers.append(random.randrange(01000));

print "Content-type: text/html\n\n"
print "<h1>Numbers!</h1>"
print "<p>I love numbers. Here's a few for you:<br>", numbers, "</p>"
print "<p>The length of the list is "len(numbers)". The third element in the list is ", numbers[2]"</p>"

largest = -1
for num in numbers:
    if (num > largest):
        largest = num

print "<p>The largest number is <b>", largest, "</b>"

http://apocalypse.rulez.org/~upi/surba/list.py [source]

Vegyük észre:

  • A cgitb modul komoly segítséget jelent Python programok hibáinak felderítésében. Ha a program futása közben történik valami gikszer, akkor szépen kiírja színes-szagos formában. Akkor nem segít, ha a program szintaktikai hiba miatt nem értelmezhető, ilyenkor csak a PuTTY-os módszer célravezető.
  • A for egy új ciklus szervező utasítás ami egy megadott intervallumon halad végig, vagy egy lista tartalmán.
  • A print parancs képes egy teljes listát kiírni.
  • A lista hosszát a len eljárással tudhatjuk meg.
  • A listában tetszőleges elemet meg tudunk címezni a lista[szám] formulával. Az elemeket 0-tól számozzuk, mind mindig, tehát a list[2] a harmadik elemet adja vissza.

Feladatok

  • Legyen paraméterezhető a lista mérete!
  • Írjuk ki a legkisebb számot is a listában.
  • Írjuk ki a páros számokat.
  • Hogyan lehetne a második for ciklust úgy megírni, hogy nem használjuk fel azt a tudásunkat, hogy a legkisebb lehetséges szám a 0?
  • Írjuk ki a számok átlagát.
  • Bónusz feladat: Írjuk ki a számokat növekvő sorrendben!
Tagek:
 
Utoljára módosította UPi 2017.VI.28 12:42-n; 3 hozzászólás;
Bejegyzés módosítása | PermaLink

Céges hálóÍrj Képaláírást


upload:image.jpg

Tagek:
 
Utoljára módosította Grizli 2017.VI.27 10:23-n; 3 hozzászólás;
Bejegyzés módosítása | PermaLink

Játék a véletlennelSur Ba Programming Challenge


Kicsit visszatérünk a vektorgrafikához, mert miért ne! Az alábbi program véletlenszerűen rajzol egy négyszöget:

#!/usr/bin/python

import random

coords = ''
= 0
while (< 4):
    coords = coords + str(random.randrange(162)) + ","
    coords = coords + str(random.randrange(162)) + " "
    i = i + 1


print """Content-type: image/svg+xml

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg
   xmlns:svg="http://www.w3.org/2000/svg"
   xmlns="http://www.w3.org/2000/svg"
   viewBox="0 0 64 64"
   version="1.1"
   height="600"
   width="600">
  <g>
    <path d="M """ + coords + """ z" 
      style="fill: none; stroke: #000000;" />
  </g>
</svg>
""";

http://apocalypse.rulez.org/~upi/surba/polygon.py [source]

Vegyük észre:

  • Az import paranccsal lehet a Python terjedelmes könyvtárából elemeket berántani a programunkban. Enélkül csak néhány egészen alapvető és közhasznú függvény áll rendelkezésre.
  • A Pythonban vannak eljárások, ezek közül kettőt látunk itt: a random.randrange és str nevűket.
    • Egy függvényt úgy lehet meghívni, hogy a neve után zárójelek között és vesszővel elválasztva felsoroljuk a paramétereit. Futás közben a eljárás majd szépen lefut, és behelyettesít valamilyen visszatérési értéket a helyére.
    • A random.randrange(1, 62) eljárás egy egész számot generál az [1, 62) intervallumban. Az eljárás két egész szám paramétert vár, és egy egész számmal tér vissza.
    • Mivel a Python + operátora nem hajlandó számot és szöveget "összeadni", ezért a számokat az str(szám) eljárással szöveggé alakítjuk kézi hajtással. Ez az eljárás egy szám paramétert vár és egy szöveggel tér vissza, ami a számnak a tízes számrendszerű reprezentációja lesz.
    • Később megtanuljuk majd, hogyan csináljunk saját eljárásokat is.
  • A koordináta-párokat az elején állítjuk össze, majd ügyesen belegyömöszöljük a kiírt SVG dokumentumba egy óvatlan pillanatban.

Feladatok

  • Legyen a sokszög éleinek a száma is véletlenszerű, háromszögtől nyolcszögig.
  • Legyen a sokszög éleinek száma véletlenszerű 4 és 12 között, de mindenképpen páros.
  • Bónusz feladat: Legyen a sokszög színe is véletlenszerű.
  • Bónusz feladat: Generáljunk négyzetet. Ha elfajuló, akkor pirosra színezzük ki, ha normális, akkor zöldre.
Tagek:
 
Utoljára módosította UPi 2017.VI.26 20:17-n; 0 hozzászólás;
Bejegyzés módosítása | PermaLink