MetaBlog

2017-11-18Írj Képaláírást


upload:Ulmar/8F8A7A9E_8A7A_40E8_83D5_17F8E827568D.jpeg

Tagek:
 
Utoljára módosította Ulmar 2017.XI.18 17:26-n; 0 hozzászólás;
Bejegyzés módosítása | PermaLink

2017-10-24Írj Képaláírást


Szombaton ellátogattunk Veszprémbe, ahol (többek között) a következő dolgok fogadtak minket:

upload:IrjKepalairast/mi_ez_veszprem_01.jpg upload:IrjKepalairast/mi_ez_veszprem_02.jpg

Szerintetek ez mire akarja felhívni a gyanutlan látogató figyelmét?

Tagek:
 
Utoljára módosította SAdam 2017.X.24 18:52-n; 1 hozzászólás;
Bejegyzés módosítása | PermaLink

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