Γιώργος Μανής Επίκουρος Καθηγητής Τμήματος Μηχανικών Η/Υ και Πληροφορικής 29 Οκτωβρίου 2014

Μέγεθος: px
Εμφάνιση ξεκινά από τη σελίδα:

Download "Γιώργος Μανής Επίκουρος Καθηγητής Τμήματος Μηχανικών Η/Υ και Πληροφορικής 29 Οκτωβρίου 2014"

Transcript

1 Γιώργος Μανής Επίκουρος Καθηγητής Τμήματος Μηχανικών Η/Υ και Πληροφορικής 29 Οκτωβρίου 2014

2

3 Python Η Python δημιουργήθηκε το 1990 Ο κύριος στόχος της είναι η αναγνωσιμότητα του κώδικά της και η ευκολία χρήσης της. έχει πολλές βιβλιοθήκες που διευκολύνουν ιδιαίτερα αρκετές συνηθισμένες εργασίες διακρίνεται για την ταχύτητα εκμάθησης της Πηγή: Βικιπαίδεια

4 Python Ανοικτό Λογισμικό Η Python αναπτύσσεται ως ανοιχτό λογισμικό Η διαχείρισή της γίνεται από τον μη κερδοσκοπικό οργανισμό Python Software Foundation Ο κώδικας διανέμεται με την άδεια Python Software Foundation License η οποία είναι συμβατή με την GPL.

5 Python Ανοικτό Λογισμικό Ο κώδικας διανέμεται με την άδεια Python Software Foundation License η οποία είναι συμβατή με την GPL. Οι χρήστες μπορουν: να τρέξουν ένα πρόγραμμα για οποιοδήποτε λόγο. να μελετήσουν τη λειτουργία ενός προγράμματος και να το τροποποιήσουν να διανείμουν αντίγραφα του προγράμματος έτσι ώστε να βοηθήσουν τον πλησίον να βελτιώσουν το πρόγραμμα και να προσφέρουν τις βελτιώσεις στο κοινό, έτσι ώστε να ωφεληθεί ολόκληρη η κοινότητα

6 Python Το όνομα της γλώσσας προέρχεται από την ομάδα Άγγλων κωμικών Μόντυ Πάιθον.

7 Εκδόσεις της Python Αρχικά, η Python ήταν γλώσσα σεναρίων που χρησιμοποιούνταν στο λειτουργικό σύστημα Amoeba, ικανή και για κλήσεις συστήματος. Η Python 2.0 κυκλοφόρησε το 2000 Το 2008 κυκλοφόρησε η έκδοση 3.0. Πολλά από τα καινούργια χαρακτηριστικά αυτής της έκδοσης έχουν μεταφερθεί στις εκδόσεις 2.6 και 2.7 που είναι προς τα πίσω συμβατές. Η Python 3 είναι ιστορικά η πρώτη γλώσσα προγραμματισμού που σπάει την προς τα πίσω συμβατότητα με προηγούμενες εκδόσεις

8 Python Διερμηνευτής ή Μεταφραστής? Οι γλώσσες δεν είναι ούτε διερμηνευτές ούτε μεταφραστές Οι γλώσσες απλά περιγράφουν κανόνες με τους οποίους μπορούμε να «συνεννοηθούμε» με τον υπολογιστή Ο τρόπος μετάφρασης κώδικα σε γλώσσα μηχανής μπορεί να διαχωριστεί με βάση τις δύο αυτές τεχνολογίες Η χρυσή τομή όμως σε σύγχρονες γλώσσες βρίσκεται κάπου ανάμεσα στις δύο φιλοσοφίες, εκμεταλλευόμενες τα πλεονεκτήματα τις κάθε μίας από αυτές

9 Python Διερμηνευτής ή Μεταφραστής? Κάθε υλοποίηση της Python συνοδεύεται και από έναν διερμηνευτή Όταν ένα κώδικας γίνεται import (???) παράγεται bytecode για μία εικονική μηχανή της Python, ο κώδικας αυτός αποθηκεύεται στο δίσκο και δεν ξαναμεταφράζεται, παρά όταν ξαναγίνει import Αλλά το bytecode δεν είναι γλώσσα μηχανής, είναι ανεξάρτητο από το υλικό στο οποίο τρέχει

10 Python Διερμηνευτής ή Μεταφραστής? Υπάρχουν επίσης υλοποιήσεις της Python που ακολουθούν την πρακτική just-in-time compilation Η μετάφραση γίνεται σε χρόνο εκτέλεσης, όχι νωρίτερα Ο κώδικας που θα παραχθεί μπορεί να αποθηκευτεί στο δίσκο έτσι ώστε να μην είναι απαραίτητο να μεταφραστεί πάλι όταν εκτελεστεί

11 Python η Python είναι εξαιρετικά δημοφιλής γλώσσα προγραμματισμού μπορείς να κάνεις εύκολα και γρήγορα ανάπτυξη εφαρμογών Είναι της φιλοσοφίας του ανοικτού κώδικα έχει αναπτυχθεί ήδη πολύ λογισμικό σε Python Υπάρχει μεγάλος αριθμός από διαθέσιμες βιβλιοθήκες μπορεί κανείς να τη χρησιμοποιήσει ως γλώσσα διαδικασιακού ή και αντικειμενοστρεφούς προγραμματισμού

12 Διαδραστικός Διερμηνευτής >>> print("hello, world! ) Hello, world! >>> >>> 1/2 0.5 >>> 4/2 2.0

13 Ακέραιοι και Πραγματικοί Οι αριθμοί 3 και 5 είναι ακέραιοι. Οι αριθμοί 3.5 και 5.0 είναι αριθμοί κινητής υποδιαστολής. >>>1//2 0 (ακέραια διαίρεση) >>>1.0// >>>1.0//2 0.0

14 Διαίρεση και Υπόλοιπο >>>10%3 1 (υπόλοιπο διαίρεσης) >>>2.75/ >>>2.75// >>>2.75%

15 Ύψωση σε Δύναμη >>>2**3 8 (Ύψωση σε δύναμη) >>>-3**2-9 >>>(-3)**2 9

16 Αριθμητικά Συστήματα AF στο δεκαεξαδικό σύστημα ισούται με 10*16+15=175 στο δεκαδικό >>>0xAF στο οκταδικό σύστημα ισούται με 1*8+0=8 στο δεκαδικό σύστημα >>>0o10 8

17 Μεταβλητές >>>x=3 (απόδοση τιμής) >>>x*2 6 >>>3*2 6 >>>print(3*2) 6

18 Input >>>input( How old are you? ) How old are you? >>>x=input( x: ) x: 34 >>>x 34

19 Input >>>x=int(input( x: )) x: 34 >>>y=float(input( y: )) y: 42 >>>print(x*y)

20 Συναρτήσεις >>>2**3 8 >>>pow(2,3) 8 >>>10+pow(2,3*5)/ >>>abs(-10) 10 >>>round(3.8) 4

21 Modules Το math είναι module. >>>import math >>>math.floor(3.8) 3 Μπορώ να εισαγάγω συγκεκριμένες συναρτήσεις από ένα module: >>>from math import sqrt >>>sqrt(9) 3.0

22 Μιγαδικοί αριθμοί >>>sqrt(-1) Traceback (most recent call last): File "<pyshell#74>", line 1, in <module> sqrt(-1) ValueError: math domain error

23 Μιγαδικοί αριθμοί >>>import cmath >>>cmath.sqrt(-1) 1j >>>(1+3j)*(9+4j) (-3+31j)

24 Αλφαριθμητικά (strings) Μονά και διπλά εισαγωγικά είναι το ίδιο >>> Hello, world! Hello, world! >>> Let s go! Let s go! Εναλλακτικά: >>> Let\ s go! Let s go!

25 Συνένωση αλφαριθμητικών >>> Hello, + world! Hello, world! Εναλλακτικά: >>> Hello, world! >>>x= Hello, >>>y= world! >>>x+y Hello, world!

26 Δομές δεδομένων Οι βασικές δομές δεδομένων στην Python είναι οι ακολουθίες (sequences). Τα κύρια είδη ακολουθιών είναι οι: Λίστες (lists) Πλειάδες (tuples) Η βασική τους διαφορά είναι ότι οι λίστες μπορούν να μεταβληθούν ενώ οι πλειάδες όχι. Τα αλφαριθμητικά (strings) είναι επίσης ακολουθίες.

27 Λίστες Έστω ότι θέλουμε να φτιάξουμε μία βάση δεδομένων που να περιλαμβάνει ονόματα και ηλικίες. >>>george=[ Γιώργος Μανής, 42] >>>peter=[ Πέτρος Παπαδόπουλος, 50] >>>database=[george, peter] >>>database [[ Γιώργος Μανής, 42], [ Πέτρος Παπαδόπουλος, 50]]

28 Δείκτες θέσης (indexing) >>>greeting= Hello >>>greeting[0] H Οι ακολουθίες στην Python ξεκινούν από το στοιχείο 0. >>>greeting[-1] o Αρνητικός δείκτης θέσης μετράει από τα δεξιά. >>> Hello [1] e

29 Δείκτες θέσης (indexing) >>> fourth = input('year: ')[3] Year: 2005 >>> fourth '5'

30 Slicing >>>numbers=[1, 2, 3, 4, 5, 6, 7, 8, 9, 10] >>>numbers[3:6] [4, 5, 6] Ο πρώτος αριθμός είναι ο δείκτης θέσης του πρώτου στοιχείου, ενώ δεύτερος αριθμός είναι ο δείκτης θέσης του επόμενου στοιχείου από το τελευταίο που θέλουμε να συμπεριλάβουμε. >>>numbers[0:1] [1]

31 Slicing >>>numbers=[1, 2, 3, 4, 5, 6, 7, 8, 9, 10] Αν μετρήσω τα στοιχεία από τα δεξιά: >>>numbers[-3:-1] [8, 9] Έτσι δεν μπορώ να προσπελάσω το τελευταίο στοιχείο: >>>numbers[-3:0] []

32 Slicing Μπορώ να κάνω το εξής: >>>numbers[-3:] [8, 9, 10] Επίσης: >>>numbers[:3] [1, 2, 3] >>>numbers[:] [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

33 Βήμα >>>numbers[0:10:1] [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] >>>numbers[0:10:2] [1, 3, 5, 7, 9] >>>numbers[3:6:3] [4] >>>numbers[::4] [1, 5, 9]

34 Αρνητικό βήμα >>>numbers=[1, 2, 3, 4, 5, 6, 7, 8, 9, 10] >>>numbers[8:3:-1] [9, 8, 7, 6, 5] >>>numbers[10:0:-2] [10, 8, 6, 4, 2] >>>numbers[0:10:-2] [] >>>numbers[::-2] [10, 8, 6, 4, 2] >>>numbers[5::-2] [6, 4, 2] >>>numbers[:5:-2] [10, 8]

35 Πρόσθεση ακολουθιών >>>[1, 2, 3] + [4, 5, 6] [1, 2, 3, 4, 5, 6] >>> Hello, + world! Hello, world >>>[1, 2, 3] + world! Traceback (most recent call last): File "<pyshell#31>", line 1, in <module> [1, 2, 3] + 'world!' TypeError: can only concatenate list (not "str") to list

36 Πολλαπλασιασμός >>> python * 5 'pythonpythonpythonpythonpython >>>[42] * 10 [42, 42, 42, 42, 42, 42, 42, 42, 42, 42]

37 Λίστες

38 Άδεια λίστα και None Άδεια λίστα: [] None: Χρησιμοποιείται όταν θέλουμε μία λίστα π.χ. με 10 στοιχεία αλλά δεν έχουμε ακόμα αναθέσει τιμές: >>>sequence = [None] * 10 >>>sequence [None, None, None, None, None, None, None, None, None, None]

39 Ιδιότητα του μέλους >>>permissions= rw >>> w in permissions True >>> x in permissions False Οι True και False είναι Boolean τιμές: True: Αληθές False: Ψευδές

40 Ιδιότητα του μέλους >>> users = [ χρήστης1', χρήστης3', χρηστης9'] >>> input('enter your user name: ') in users Enter your user name: mlh True >>> subject = '$$$!!! $$$' >>> '$$$' in subject True

41 παράθεση >>> x [1, 5, 4, 7, 8, 9] >>> y [7, 8, 9] >>> x+y [1, 5, 4, 7, 8, 9, 7, 8, 9] >>> a=x+y >>> a [1, 5, 4, 7, 8, 9, 7, 8, 9] >>> x [1, 5, 4, 7, 8, 9] >>> y [7, 8, 9]

42 η συνάρτηση list δημιουργία λίστας >>> list ('Hello') ['H', 'e', 'l', 'l', 'o'] >>> >>> x=list('hello') >>> x ['H', 'e', 'l', 'l', 'o'] >>>

43 min, max, len >>> x=[3,5,2,8,7] >>> min(x) 2 >>> max(x) 8 >>> len(x) 5 >>>

44 τροποποίηση στοιχείων λίστας >>> x=[1,2,3] >>> x [1, 2, 3] >>> x[2]=-1 >>> x [1, 2, -1] >>>

45 διαγραφή στοιχείων λίστας >>> x=[1,2,3] >>> del x[1] >>> x [1, 3] >>> del x[0] >>> del x[0] >>> x [] >>>

46 αντικατάσταση μέρους λίστας >>> list = [1,2,3,4,5,6] >>> list[3:]=[7,8,9] >>> list [1, 2, 3, 7, 8, 9] >>> list[1:2]=[10,11,12,13] >>> list [1, 10, 11, 12, 13, 3, 7, 8, 9]

47 αντικατάσταση μέρους λίστας >>> list[1:1]=[20,21,22] >>> list [1, 20, 21, 22, 10, 11, 12, 13, 3, 7, 8, 9] >>> list[4:]=[] >>> list [1, 20, 21, 22] >>>

48 append >>> lst = [1, 2, 3] >>> lst.append(4) >>> lst [1, 2, 3, 4]

49 count >>> ['to', 'be', 'or', 'not', 'to', 'be'].count('to') 2 >>> x = [[1, 2], 1, 1, [2, 1, [1, 2]]] >>> x.count(1) 2 >>> x.count([1, 2]) 1

50 index >>> a = [1, 5, 4, 7, 8, 9, 7, 8, 9,] >>> a.index(7) 3 >>> a.index(9) 5

51 insert >>> a = [1, 5, 4, 7, 8, 9, 7, 8, 9, -1] >>> >>> a.insert(2,10) >>> a [1, 5, 10, 4, 7, 8, 9, 7, 8, 9, -1]

52 pop >>> a = [1, 5, 10, 4, 7, 8, 9, 7, 8, 9, -1] >>> a.pop() -1 >>> a [1, 5, 10, 4, 7, 8, 9, 7, 8, 9] >>> a.pop(0) 1 >>> a [5, 10, 4, 7, 8, 9, 7, 8, 9] >>> a.pop(2) 4 >>> a [5, 10, 7, 8, 9, 7, 8, 9]

53 remove >>> a [5, 10, 7, 8, 9, 7, 8, 9] >>> >>> a.remove(9) >>> a [5, 10, 7, 8, 7, 8, 9]

54 reverse >>> x = [1, 2, 3] >>> x.reverse() >>> x [3, 2, 1] >>> x = [1, 2, 3] >>> list(reversed(x)) [3, 2, 1] >>> x [1, 2, 3]

55 extend >>> a = [1, 2, 3] >>> b = [4, 5, 6] >>> a.extend(b) >>> a [1, 2, 3, 4, 5, 6] >>> a = [1, 2, 3] >>> b = [4, 5, 6] >>> a + b [1, 2, 3, 4, 5, 6] >>> a [1, 2, 3]

56 sort >>> x = [4, 6, 2, 1, 7, 9] >>> x.sort() >>> x [1, 2, 4, 6, 7, 9] >>> x = [4, 6, 2, 1, 7, 9] >>> y = x.sort() >>> print (y) None

57 sort >>> x = [4, 6, 2, 1, 7, 9] >>> y = x[:] >>> y.sort() >>> x [4, 6, 2, 1, 7, 9] >>> y [1, 2, 4, 6, 7, 9]

58 sort >>> y = x >>> y.sort() >>> x [1, 2, 4, 6, 7, 9] >>> y [1, 2, 4, 6, 7, 9]

59 sort >>> x = [4, 6, 2, 1, 7, 9] >>> y = sorted(x) >>> x [4, 6, 2, 1, 7, 9] >>> y [1, 2, 4, 6, 7, 9]

60 Πλειάδες

61 Πλειάδες Οι πλειάδες δημιουργούνται και δεν τροποποιούνται στη συνέχεια >>> 1, 2, 3 (1, 2, 3) >>> () ()

62 Δημιουργία από συνάρτηση >>> tuple([1, 2, 3]) (1, 2, 3) >>> tuple('abc') ('a', 'b', 'c') >>> tuple((1, 2, 3)) (1, 2, 3)

63 Λειτουργίες σε μία πλειάδα >>> x = 1, 2, 3 >>> x[1] 2 >>> x[0:2] (1, 2)

64 Χρησιμότητα? Θα μπορούσαμε να χρησιμοποιούσαμε και λίστες αντί τις πλειάδες Κάποιες λειτουργίες όμως που θα δούμε αργότερα τις χρησιμοποιούν

65 Λεξικά

66 Λεξικά χρησιμοποιούν κλειδιά και όχι απλούς δείκτες η αναζήτηση βασίζεται στα κλειδιά, τα οποία είναι πλειάδες π.χ. phonebook = { Αλίκη': '2341', Μπέτυ': '9102', Σεσίλ': '3258'}

67 Συνάρτηση dict >>> items = [('name', Γιώργος'), ('age', 42)] >>> d = dict(items) >>> d {'age': 42, 'name': Γιώργος'} >>> d['name'] Γιώργος ή d = dict(name= Γιώργος', age=42) >>> d {'age': 42, 'name': Γιώργος'}

68 Βασικές Λειτουργίες >>> x = [] >>> x[42] = τεστ' Traceback (most recent call last): File "<stdin>", line 1, in? IndexError: list assignment index out of range >>> x = {} >>> x[42] = τεστ' >>> x {42: τεστ'}

69 clear >>> d = {} >>> d['name'] = Γιώργος' >>> d['age'] = 42 >>> d {'age': 42, 'name': Γιώργος'} >>> returned_value = d.clear() >>> d {} >>> print (returned_value) None

70 fromkeys >>> {}.fromkeys(['name', 'age']) {'age': None, 'name': None} >>> dict.fromkeys(['name', 'age']) {'age': None, 'name': None} >>> dict.fromkeys(['name', 'age'], '(unknown)') {'age': '(unknown)', 'name': '(unknown)'}

71 get >>> d = {} >>> print (d['name']) Traceback (most recent call last): File "<stdin>", line 1, in? KeyError: 'name >>> d.get('name', 'N/A') N/A >>> d['name'] = 'Eric' >>> d.get('name') 'Eric' >>> print (d.get('name')) None

72 has_key >>> d = {} >>> d.has_key('name') 0 >>> d['name'] = 'Eric' >>> d.has_key('name') 1

73 items >>> d = {'title': 'Python Web Site', 'url': ' 'spam': 0} >>> d.items() [('url', ' ('spam', 0), ('title', 'Python Web Site')]

74 pop >>> d = {'x': 1, 'y': 2} >>> d.pop('x') 1 >>> d {'y': 2} >>> d = {'x': 1, 'y': 2} >>> d.pop('x') 1 >>> d {'y': 2}

75 popitem >>> d {'url': ' 'spam': 0, 'title': 'Python Web Site'} >>> d.popitem() ('url', ' τυχαίο >>> d {'spam': 0, 'title': 'Python Web Site'}

76 update >>> d = { 'title': 'Python Web Site', 'url': ' 'changed': 'Mar 14 22:09:15 MET 2005' } >>> x = {'title': 'Python Language Website'} >>> d.update(x) >>> d {'url': ' 'changed': 'Mar 14 22:09:15 MET 2005, 'title': 'Python Language Website'}

77 Δομές Έλέγχου

78 Μπλοκ κώδικα Ένα μπλοκ κώδικα είναι μία ομάδα εντολών η οποία θα εκτελεστεί αν μία συνθήκη είναι αληθής ή θα εκτελεστεί πολλές φορές (βρόχος) Στην Python, το μπλοκ δημιουργείται γράφοντας το αντίστοιχο μέρος του κώδικα σε εσοχή (βάζοντας διαστήματα μπροστά). Προτείνονται τέσσερα διαστήματα.

79 Μπλοκ κώδικα this is a line this is another line: this is another block continuing the same block the last line of this block phew, there we escaped the inner block Η αρχή του μπλοκ ορίζεται με «:»

80 Συνθήκες Είχαμε μιλήσει για Boolean τιμές. True, False Στην Python, οι παρακάτω τιμές θεωρούνται ισοδύναμες με False: False None 0 "" () [] {} Οποιαδήποτε άλλη τιμή θεωρείται ισοδύναμη με True.

81 True και False Βασικά, True σημαίνει 1 και False σημαίνει 0. >>> True True >>> False False >>> True == 1 True >>> False == 0 True >>> True + False

82 Τύπος bool Οι τιμές True και False ανήκουν στον τύπο bool. bool('i think, therefore I am') True >>> bool(42) True >>> bool('') False >>> bool(0) False

83 Η εντολή if name = input('what is your name? ') if name.endswith('gumby'): print('hello, Mr. Gumby )

84 elif και else num = eval(input('enter a number: ')) if num > 0: print('the number is positive') elif num < 0: print('the number is negative') else: print('the number is zero')

85 Φωλιασμένα μπλοκ name = input('what is your name? ') if name.endswith('gumby'): if name.startswith('mr.'): print('hello, Mr. Gumby') elif name.startswith('mrs.'): print('hello, Mrs. Gumby') else: print('hello, Gumby') else: print('hello, stranger')

86 Τελεστές σύγκρισης x == y το x ισούται με το y. x < y το x είναι μικρότερο από το y. x > y το x είναι μεγαλύτερο από το y. x >= y το x είναι μεγαλύτερο ή ίσο από το y. x <= y το x είναι μικρότερο ή ίσο από το y. x!= y το x είναι διάφορο του y. x is y x και y είναι το ίδιο αντικείμενο. x is not y x και y είναι διαφορετικά αντικείμενα. x in y το x είναι μέλος της ακολουθίας y. x not in y το x δεν είναι μέλος της ακολουθίας y.

87 Τελεστές σύγκρισης >>> "foo" == "foo" True >>> "foo" == "bar" False >>> "foo" = "foo" SyntaxError: can't assign to literal

88 Ο τελεστής is (τελεστής ταυτότητας) >>> x = y = [1, 2, 3] >>> z = [1, 2, 3] >>> x == y True >>> x == z True >>> x is y True >>> x is z False

89 Ο τελεστής in name = input('what is your name? ') if 's' in name: print('your name contains the letter "s". ) else: print('your name does not contain the letter "s". )

90 Σύγκριση αλφαριθμητικών και ακολουθιών >>> "alpha" < "beta" True [1, 2] < [2, 1] True

91 Boolean τελεστές number = int(input( Δώσε μου αριθμό ανάμεσα στο 1 και το 10: ')) if number <= 10: if number >= 1: print Σωστά!' else: print Λάθος!' else: print Λάθος!'

92 Boolean τελεστές Καλύτερα: number = int(input(' Δώσε μου αριθμό ανάμεσα στο 1 και το 10 : ')) if number <= 10 and number >= 1: print Σωστά!' else: print Λάθος! Ακόμα καλύτερα: if 1<=number<=10:

93 Boolean τελεστές and, or, not όσο πολύπλοκα θέλουμε if ((cash > price) or customer_has_good_credit) and not out_of_stock: give_goods()

94 Ο βρόχος while x = 1 while x <= 100: print(x) x += 1 name = '' while not name: name = input('please enter your name: ') print('hello, %s!' % name)

95 Ο βρόχος for words = ['this', 'is', 'an', 'ex', 'parrot'] for word in words: print(word) numbers = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] for number in numbers: print(number)

96 range for number in range(1,101): print(number) >>>list(range(0,10)) [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] Το δεύτερο όριο δεν συμπεριλαμβάνεται.

97 Επαναλήψεις σε λεξικά d = {'x': 1, 'y': 2, 'z': 3} for key in d: print(key, 'corresponds to', d[key]) Εναλλακτικά: d = {'x': 1, 'y': 2, 'z': 3} for key, value in d.items(): print(key, 'corresponds to', value)

98 Παράλληλες επαναλήψεις names = [ anne', 'beth', 'george', 'damon'] ages = [12, 45, 32, 102] for i in range(len(names)): print(names[i], 'is', ages[i], 'years old')

99 Η συνάρτηση zip >>>list(zip(names,ages)) [('anne', 12), ('beth', 45), ('george', 32), ('damon', 102)] >>>list(zip(range(5), range( ))) [(0, 0), (1, 1), (2, 2), (3, 3), (4, 4)]

100 Παράλληλες επαναλήψεις με zip names = ['anne', 'beth', 'george', 'damon'] ages = [12, 45, 32, 102] for name, age in zip(names, ages): print(name, 'is', age, 'years old')

101 Αντικατάσταση αλφαριθμητικού for string in strings: if 'xxx' in string: index = strings.index(string) strings[index] = '[censored] Εναλλακτικά: index = 0 for string in strings: if 'xxx' in string: strings[index] = '[censored]' index += 1

102 reversed και sorted >>> sorted([4, 3, 6, 8, 3]) [3, 3, 4, 6, 8] >>> sorted('hello, world!') [' ', '!', ',', 'H', 'd', 'e', 'l', 'l', 'l', 'o', 'o', 'r', 'w'] >>> list(reversed('hello, world!')) ['!', 'd', 'l', 'r', 'o', 'w', ' ', ',', 'o', 'l', 'l', 'e', 'H'] >>> ''.join(reversed('hello, world!')) '!dlrow,olleh'

103 Η εντολή break Θέλω να βρω το μεγαλύτερο τέλειο τετράγωνο μικρότερο του 100. from math import sqrt for n in range(99, 0, -1): root = sqrt(n) if root == int(root): print(n) break Η break μας βγάζει έξω από το βρόχο

104 range με βήμα >>>list(range(99, 0, -1)) [99, 98, 97, 96, 95, 94, 93, 92, 91, 90, 89, 88, 87, 86, 85, 84, 83, 82, 81, 80, 79, 78, 77, 76, 75, 74, 73, 72, 71, 70, 69, 68, 67, 66, 65, 64, 63, 62, 61, 60, 59, 58, 57, 56, 55, 54, 53, 52, 51, 50, 49, 48, 47, 46, 45, 44, 43, 42, 41, 40, 39, 38, 37, 36, 35, 34, 33, 32, 31, 30, 29, 28, 27, 26, 25, 24, 23, 22, 21, 20, 19, 18, 17, 16, 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1] >>>list(range(0,10,2)) [0, 2, 4, 6, 8]

105 Ο ιδιωματισμός while True/break word = 'dummy' while word: word = input('please enter a word: ') # do something with the word: print('the word was ' + word) Χρειαζόμαστε την αρχική τιμή στη word.

106 O ιδιωματισμός while True/break Εναλλακτικά: word = input('please enter a word: ') while word: # do something with the word: print('the word was ' + word) word = input('please enter a word: ')

107 O ιδιωματισμός while True/break Με χρήση του while True/break: while True: word = input('please enter a word: ') if not word: break # do something with the word: print('the word was ' + word)

108 Χρήση Boolean σημαίας broke_out = False for x in seq: do_something(x) if condition(x): broke_out = True break do_something_else(x) if not broke_out: print "I didn't break out!"

109 Χρήση else στη for from math import sqrt for n in range(99, 81, -1): root = sqrt(n) if root == int(root): print(n) break else: print("didn't find it!")

110 Περισσότερα για λίστες >>> [x*x for x in range(10)] [0, 1, 4, 9, 16, 25, 36, 49, 64, 81] >>> [x*x for x in range(10) if x % 3 == 0] [0, 9, 36, 81] >>> [(x, y) for x in range(3) for y in range(3)] [(0, 0), (0, 1), (0, 2), (1, 0), (1, 1), (1, 2), (2, 0), (2, 1), (2, 2)]

111 Περισσότερα για λίστες >>> girls = ['alice', 'bernice', 'clarice'] >>> boys = ['chris', 'arnold', 'bob'] >>> [b+'+'+g for b in boys for g in girls if b[0] == g[0]] ['chris+clarice', 'arnold+alice', 'bob+bernice']

112 Η εντολή pass Δεν κάνει τίποτα! if name == 'Ralph': print 'Welcome!' elif name == 'Enid': # Not finished yet... pass elif name == 'Bill Gates': print 'Access Denied'

113 Παραδείγματα

114 Ύψωση σε δύναμη x = int(input('dose ti vasi: ')) y = int(input('dose ti dynami: ')) value = 1 for i in range(0, y): value *= x print('%d eis tin %d = %d' % (x, y, value))

115 Παραγοντικό n! n

116 Παραγοντικό ενός αριθμού x = int(input('dose mou ton arithmo: ')) y = 1 for i in range(1,x+1): y *= i print('to paragontiko tou %d einai %d' % (x,y))

117 Υπολογισμός ψηφίων ακέραιου αριθμού Παράδειγμα: 235=2*100+3*10+5 Πρώτο ψηφίο: 235%10=5 235//10=23 Δεύτερο ψηφίο: 23%10=3 23//10=2 Τρίτο ψηφίο: 2%10=2 2//10=0

118 Υπολογισμός αθροίσματος ψηφίων ακέραιου αριθμού n = int(input('dose mou ton arithmo: ')) dsum = 0 while n>0: dsum += n%10 n//=10 print('to athroisma ton psifion tou arithmou einai %d' % dsum)

119 Πίνακες

120 Πίνακες Μπορούμε να χρησιμοποιήσουμε λίστες ως πίνακες. Μονοδιάστατος πίνακας: Α=[1, 2, 3, 4, 5] Διδιάστατος πίνακας: Β=[[1, 2, 3], [4, 5, 6], [7, 8, 9]] Κάθε γραμμή του πίνακα είναι μία λίστα.

121 Αρχικοποίηση πινάκων Μονοδιάστατος πίνακας Ν=5 Α=[0]*Ν Εναλλακτικά: Α=[0 for i in range(n)] Αντί για 0 μπορούμε να βάλουμε και None.

122 Αρχικοποίηση πινάκων Δισδιάστατος πίνακας Ν=3 pinakas=[[0 for i in range(n)] for i in range(n)] pinakas 0 1 pinakas[0][0] pinakas[0][1] pinakas[0][2] Προσοχή: Είναι pinakas[i][j] και όχι pinakas[i, j] pinakas[1][0] pinakas[1][1] pinakas[1][2] 2 pinakas[2][0] pinakas[2][1] pinakas[2][2] 0 1 2

123 Πρόσθεση πινάκων N = 3 A = [[0.0 for j in range(n)] for i in range(n)] B = [[0.0 for j in range(n)] for i in range(n)] C = [[0.0 for j in range(n)] for i in range(n)] for i in range(n): for j in range(n): A[i][j] = float(input('a[%d][%d]: ' % (i, j))) for i in range(n): for j in range(n): B[i][j] = float(input('b[%d][%d]: ' % (i, j)))

124 Πρόσθεση πινάκων (συνέχεια) for i in range(n): for j in range(n): C[i][j] = A[i][j] + B[i][j] for i in range(n): for j in range(n): print('c[%d][%d]:%7.2f ' % (i, j, C[i][j]), end = '') print('')

125 Πολλαπλασιασμός πινάκων NxN C A B C[ i, j] N 1 A[ i, k] B[ k, j] k 0

126 Πολλαπλασιασμός πινάκων N = 3 A = [[0.0 for j in range(n)] for i in range(n)] B = [[0.0 for j in range(n)] for i in range(n)] C = [[0.0 for j in range(n)] for i in range(n)] for i in range(n): for j in range(n): A[i][j] = float(input('a[%d][%d]: ' % (i, j))) for i in range(n): for j in range(n): B[i][j] = float(input('b[%d][%d]: ' % (i, j)))

127 Πολλαπλασιασμός πινάκων (συνέχεια) for i in range(n): for j in range(n): thiselement = 0.0 for k in range(n): thiselement += A[i][k]*B[k][j] C[i][j] = thiselement for i in range(n): for j in range(n): print('c[%d][%d]:%7.2f ' % (i, j, C[i][j]), end = '') print(' )

128 Ανάστροφος πίνακα N = 3 A = [[0.0 for j in range(n)] for i in range(n)] C = [[0.0 for j in range(n)] for i in range(n)] for i in range(n): for j in range(n): A[i][j] = float(input('a[%d][%d]: ' % (i, j))) for i in range(n): for j in range(n): C[i][j] = A[j][i]

129 Ανάστροφος πίνακα (συνέχεια) for i in range(n): for j in range(n): print('c[%d][%d]:%7.2f ' % (i, j, C[i][j]), end = '') print('')

130 Συναρτήσεις

131 Hello world >>> def helloworld(): print('hello World') >>> helloworld() Hello World >>>

132 Hello world >>> def hello(name): return 'Hello, '+name+'!' >>> hello ('world') 'Hello, world!' >>> hello ('George') 'Hello, George!' >>>

133 Fibonacci numbers fib(0) = 1 fib(1) = 1 fib(n)=fib(n-1)+fib(n-2)

134 Fibonacci numbers >>> def fibs(num): result = [0, 1] for i in range(num-2): result.append(result[-2] + result[-1]) return result >>> fibs(10) [0, 1, 1, 2, 3, 5, 8, 13, 21, 34] >>>

135 Τεκμηρίωση >>> def hello(name): 'prints hello, a comma and a name following them' return 'Hello, '+name+'!' >>> hello('george') 'Hello, George!' >>> hello. doc 'prints hello, a comma and a name following them' >>>

136 Τεκμηρίωση >>> from math import sqrt >>> help(sqrt) Help on built-in function sqrt in module math: sqrt(...) sqrt(x) Return the square root of x.

137 Κάτι σαν συναρτήσεις >>> def OK(): print ('OK'); return print ('????'); >>> OK() OK >>> x=ok() OK >>> x >>>

138 Κάτι σαν συναρτήσεις >>> def OK(): print ('OK'); return print ('????'); >>> OK() OK???? >>> x=ok() OK???? >>> x >>>

139 Παράμετροι def hello(name): return 'Hello, '+name+'!' >>> x='george' >>> hello(x) 'Hello, George!' >>> x 'George'

140 Παράμετροι def hello(name): name='123' return 'Hello, '+name+'!' >>> x='george' >>> hello(x) 'Hello, 123!' >>> x 'George' >>>

141 Παράμετροι >>> def change(n): n[0] = 'Mr. Gumby' >>> names = ['Mrs. Entity', 'Mrs. Thing'] >>> change(names) >>> names ['Mr. Gumby', 'Mrs. Thing']

142 Παράμετροι def hello_1(greeting, name): print '%s, %s!' % (greeting, name) def hello_2(name, greeting): print '%s, %s!' % (name, greeting) >>> hello_1('hello', 'world') Hello, world! >>> hello_2('hello', 'world') Hello, world!

143 Παράμετροι >>> hello_1(greeting='hello', name='world') Hello, world! >>> hello_1(name='world', greeting='hello') Hello, world! The names do, however (as you may have gathered): >>> hello_2(greeting='hello', name='world') world, Hello!

144 Παράμετροι Πιο ευανάγνωστος κώδικας >>> store('mr. Brainsample', 10, 20, 13, 5) >>> store(patient='mr. Brainsample', hour=10, minute=20, day=13, month=5)

145 Παράμετροι def hello_3(greeting='hello', name='world'): print '%s, %s!' % (greeting, name) >>> hello_3() Hello, world! >>> hello_3('greetings') Greetings, world! >>> hello_3('greetings', 'universe') Greetings, universe! >>> hello_3(name='gumby') Hello, Gumby!

146 Παράμετροι >>> def hello(greetings='hello',name='world'): print(greetings+', '+name) >>> hello() Hello, world >>> hello(greetings='hi') Hi, world >>> hello(name='mike') Hello, Mike

147 Παράμετροι >>> hello(name='mike',greetings='hi') Hi, Mike >>> hello('hi','mike') Hi, Mike >>> hello('mike','hi') Mike, Hi >>> hello('hi') Hi, world >>> hello('mike') Mike, world

148 Μεταβλητός αριθμός παραμέτρων def print_params(*params): print (params) >>> print_params('testing') ('Testing',) >>> print_params(1, 2, 3) (1, 2, 3)

149 Μεταβλητός αριθμός παραμέτρων def print_params_2(title, *params): print (title) print (params) print_params_2('params:', 1, 2, 3) Params: (1, 2, 3) >>> print_params_2('nothing:') Nothing: ()

150 Μεταβλητός αριθμός παραμέτρων def print_params_3(**params): print (params) >>> print_params_3(x=1, y=2, z=3) {'z': 3, 'x': 1, 'y': 2}

151 Μεταβλητός αριθμός παραμέτρων def print_params_4(x, y, z=3, *pospar, **keypar): print (x, y, z) print (pospar) print (keypar) >>> print_params_4(1, 2, 3, 5, 6, 7, foo=1, bar=2) (5, 6, 7) {'foo': 1, 'bar': 2} >>> print_params_4(1, 2) () {}

152 Κατανομή στις παραμέτρους def add(x, y): return x + y params = (1, 2) >>> add(*params) 3

153 Κατανομή στις παραμέτρους >>> params = {'name': 'Sir Robin', 'greeting': 'Well met'} >>> hello_3(**params) Well met, Sir Robin!

154 Κατανομή στις παραμέτρους >>> def with_stars(**kwds): print (kwds['name'], 'is', kwds['age'], 'years old ) >>> def without_stars(kwds): print (kwds['name'], 'is', kwds['age'], 'years old ) >>> args = {'name': 'Mr. Gumby', 'age': 42} >>> with_stars(**args) Mr. Gumby is 42 years old >>> without_stars(args) Mr. Gumby is 42 years old

155 Παραδείγματα def power(x, y, *others): if others: print ('Received redundant parameters:', others) return pow(x, y) >>> power(2,3) 8 >>> power(3,2) 9 >>> power(y=3,x=2) 8

156 Ταξινόμηση

157 Ταξινόμηση Η Python έχει ενσωματωμένη μέθοδο για ταξινόμηση λιστών: >>> seq = [34, 67, 8, 123, 4, 100, 95] >>>seq.sort() >>>seq [4, 8, 34, 67, 95, 100, 123]

158 Η συνάρτηση sorted >>>sorted([4, 3, 6, 8, 3]) [3, 3, 4, 6, 8]

159 Ταξινόμηση με επιλογή (selection sort) def SortIntegerArray(array): n=len(array) for lh in range(0,n): rh=findsmallestinteger(array, lh, n-1) SwapIntegerElements(array, lh, rh) def FindSmallestInteger(array, low, high): spos=low for i in range(low, high+1): if array[i]<array[spos]: spos=i return(spos)

160 Ταξινόμηση με επιλογή (selection sort) def SwapIntegerElements(array, p1, p2): array[p1], array[p2] = array[p2], array[p1]

161 bubblesort def bubblesort(numbers): array_size=len(numbers) for i in range(array_size-1, -1, -1): for j in range(1,i+1): if numbers[j-1]>numbers[j]: numbers[j-1], numbers[j]=numbers[j], numbers[j-1]

162 Insertionsort def InsertionSort(numbers): array_size=len(numbers) for i in range(1, array_size): index=numbers[i] j=i while (j>0) and numbers[j-1]>index: numbers[j]=numbers[j-1] j=j-1 numbers[j]=index

163 Αναζήτηση στην Python >>>x=[232, 2, 21, 1, 2] >>>21 in x True >>>3 in x False Δεν μου λέει σε ποια θέση της λίστας βρίσκεται το στοιχείο που ψάχνω.

164 Η μέθοδος index >>>[2, 3, 4, 2, 1].index(2) 0 >>>[2, 3, 4, 2, 1].index(5) Traceback (most recent call last): File "<pyshell#24>", line 1, in <module> [2, 3, 4, 2, 1].index(5) ValueError: 5 is not in list

165 Γραμμική Αναζήτηση (Linear Search) Ψάχνουμε την θέση μιας τιμής κλειδί Γραμμική Αναζήτηση (Linear search) Απλούστερη δυνατή Σύγκρινε σειριακά κάθε στοιχείο του πίνακα με την τιμή-κλειδί Χρήσιμο για μικρούς και ΜΗ ταξινομημένους πίνακες

166 linearsearch def linearsearch(a, key): array_size=len(a) for i in range(array_size): if key==a[i]: return i return -1

167 Δυαδική Αναζήτηση (Binary Search) Δυαδική Αναζήτηση Σε ταξινομημένους πίνακες μόνο Συγκρίνει το middle στοιχείο με το ζητούμενο key Αν είναι ίσα βρέθηκε Αν key < middle, ψάχνει στο 1ο μισό του πίνακα Αν key > middle, ψάχνει στο 2ο μισό του πίνακα Επανάληψη Πολύ γρήγορη Στη χειρότερη περίπτωση n βήματα, για 2 n > αριθμό στοιχείων Πίνακας 30 στοιχείων χρειάζεται το πολύ 5 βήματα 2 5 > 30 δηλαδή 5 βήματα

168 binarysearch def binarysearch(a, key, low, high): while low<=high: middle=(low+high)//2 if key==a[middle]: return middle elif key<middle: high=middle-1 else: low=middle+1 return -1

Γιώργος Μανής Επίκουρος Καθηγητής Τμήματος Μηχανικών Η/Υ και Πληροφορικής Mάρτιος 2015

Γιώργος Μανής Επίκουρος Καθηγητής Τμήματος Μηχανικών Η/Υ και Πληροφορικής Mάρτιος 2015 Γιώργος Μανής Επίκουρος Καθηγητής Τμήματος Μηχανικών Η/Υ και Πληροφορικής Mάρτιος 2015 Python Η Python δημιουργήθηκε το 1990 Ο κύριος στόχος της είναι η αναγνωσιμότητα του κώδικά της και η ευκολία χρήσης

Διαβάστε περισσότερα

Γιώργος Μανής Επίκουρος Καθηγητής Τμήματος Μηχανικών Η/Υ και Πληροφορικής 3 Μαϊου 2015

Γιώργος Μανής Επίκουρος Καθηγητής Τμήματος Μηχανικών Η/Υ και Πληροφορικής 3 Μαϊου 2015 Γιώργος Μανής Επίκουρος Καθηγητής Τμήματος Μηχανικών Η/Υ και Πληροφορικής 3 Μαϊου 2015 Δομές Δεδομένων της Python αλφαριθμητικά πλειάδες λίστες λεξικά πίνακες? Strings >>> Hello, world! Hello, world!

Διαβάστε περισσότερα

Γιώργος Μανής Επίκουρος Καθηγητής Τμήματος Μηχανικών Η/Υ και Πληροφορικής 6 Οκτωβρίου 2014

Γιώργος Μανής Επίκουρος Καθηγητής Τμήματος Μηχανικών Η/Υ και Πληροφορικής 6 Οκτωβρίου 2014 Γιώργος Μανής Επίκουρος Καθηγητής Τμήματος Μηχανικών Η/Υ και Πληροφορικής 6 Οκτωβρίου 2014 Δομές Δεδομένων της Python strings πλειάδες λίστες λεξικά πίνακες? Strings >>> Hello, world! Hello, world! s=

Διαβάστε περισσότερα

Γιώργοσ Μανήσ Επίκουροσ Καθηγητήσ Τμήματοσ Μηχανικών Η/Υ και Πληροφορικήσ 2 Ιουλίου 2014

Γιώργοσ Μανήσ Επίκουροσ Καθηγητήσ Τμήματοσ Μηχανικών Η/Υ και Πληροφορικήσ 2 Ιουλίου 2014 Γιώργοσ Μανήσ Επίκουροσ Καθηγητήσ Τμήματοσ Μηχανικών Η/Υ και Πληροφορικήσ 2 Ιουλίου 2014 Python Η Python δθμιουργικθκε το 1990 Ο κφριοσ ςτόχοσ τθσ είναι θ αναγνωςιμότητα του κϊδικά τθσ και θ ευκολία χριςθσ

Διαβάστε περισσότερα

ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό. Έλεγχος Ροής Προγράµµατος Χειµερινό Εξάµηνο 2014

ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό. Έλεγχος Ροής Προγράµµατος Χειµερινό Εξάµηνο 2014 ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό Έλεγχος Ροής Προγράµµατος Χειµερινό Εξάµηνο 2014 Ροή προγράµµατος n n Μέχρι τώρα έχουµε δει προγράµµατα απλής ροής Οι εντολές εκτελούνται η µία µετά την άλλη σύµφωνα

Διαβάστε περισσότερα

ΜΥΥ105: Εισαγωγή στον Προγραμματισμό. Λεξικά Χειμερινό Εξάμηνο 2016

ΜΥΥ105: Εισαγωγή στον Προγραμματισμό. Λεξικά Χειμερινό Εξάμηνο 2016 ΜΥΥ105: Εισαγωγή στον Προγραμματισμό Λεξικά Χειμερινό Εξάμηνο 2016 Γιατί Λεξικά; Στις ακολουθίες (π.χ. λίστες, αλφαριθμητικά) μπορούμε να αναφερόμαστε σε ένα στοιχείο με τον αριθμητικό δείκτη του (π.χ.

Διαβάστε περισσότερα

ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό. Λεξικά Χειµερινό Εξάµηνο 2014

ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό. Λεξικά Χειµερινό Εξάµηνο 2014 ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό Λεξικά Χειµερινό Εξάµηνο 2014 Γιατί Λεξικά; Στις ακολουθίες (π.χ. λίστες, αλφαριθµητικά) µπορούµε να αναφερόµαστε σε ένα στοιχείο µε τον αριθµητικό δείκτη του (π.χ.

Διαβάστε περισσότερα

ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό. Λίστες και Πλειάδες Χειµερινό Εξάµηνο 2014

ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό. Λίστες και Πλειάδες Χειµερινό Εξάµηνο 2014 ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό Λίστες και Πλειάδες Χειµερινό Εξάµηνο 2014 Δοµές δεδοµένων Μια δοµή δεδοµένων είναι µια δοµηµένη (οργανωµένη) συλλογή στοιχείων (π.χ., ψηφίων, χαρακτήρων, αριθµών,

Διαβάστε περισσότερα

ΜΥΥ105: Εισαγωγή στον Προγραμματισμό. Ακολουθίες: Λίστες και Πλειάδες Χειμερινό Εξάμηνο 2016

ΜΥΥ105: Εισαγωγή στον Προγραμματισμό. Ακολουθίες: Λίστες και Πλειάδες Χειμερινό Εξάμηνο 2016 ΜΥΥ105: Εισαγωγή στον Προγραμματισμό Ακολουθίες: Λίστες και Πλειάδες Χειμερινό Εξάμηνο 2016 Δομές δεδομένων Μια δομή δεδομένων είναι μια δομημένη (οργανωμένη) συλλογή στοιχείων (π.χ., ψηφίων, χαρακτήρων,

Διαβάστε περισσότερα

ΜΥΥ105: Εισαγωγή στον Προγραμματισμό. Συναρτήσεις Χειμερινό Εξάμηνο 2016

ΜΥΥ105: Εισαγωγή στον Προγραμματισμό. Συναρτήσεις Χειμερινό Εξάμηνο 2016 ΜΥΥ105: Εισαγωγή στον Προγραμματισμό Συναρτήσεις Χειμερινό Εξάμηνο 2016 Δόμηση προγράμματος Μέχρι τώρα έχουμε δει πως να χρησιμοποιούμε έτοιμες συναρτήσεις και μεθόδους στα προγράμματά μας (π.χ. len(),

Διαβάστε περισσότερα

Εισαγωγή στον Προγ/μό Υπολογιστών

Εισαγωγή στον Προγ/μό Υπολογιστών Εισαγωγή στον Προγ/μό Υπολογιστών Διάλεξη 1 Εκφράσεις, κλητικές εκφράσεις, ονόματα Περιεχόμενα Εκφράσεις (expressions) Τελεστές (operators) της Python Κλητικές εκφράσεις (call expressions) Ονόματα (names)

Διαβάστε περισσότερα

ΜΥΥ105: Εισαγωγή στον Προγραμματισμό. Αναζήτηση και Ταξινόμηση Χειμερινό Εξάμηνο 2016

ΜΥΥ105: Εισαγωγή στον Προγραμματισμό. Αναζήτηση και Ταξινόμηση Χειμερινό Εξάμηνο 2016 ΜΥΥ105: Εισαγωγή στον Προγραμματισμό Αναζήτηση και Ταξινόμηση Χειμερινό Εξάμηνο 2016 Αναζήτηση και Ταξινόμηση Βασικές λειτουργίες σε προγράμματα Αναζήτηση (searching): Βρες ένα ζητούμενο στοιχείο σε μια

Διαβάστε περισσότερα

ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό. Συναρτήσεις Χειµερινό Εξάµηνο 2014

ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό. Συναρτήσεις Χειµερινό Εξάµηνο 2014 ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό Συναρτήσεις Χειµερινό Εξάµηνο 2014 Δόµηση προγράµµατος Μέχρι τώρα έχουµε δει πως να χρησιµοποιούµε έτοιµες συναρτήσεις και µεθόδους στα προγράµµατά µας (π.χ. len(),

Διαβάστε περισσότερα

ΜΥΥ105: Εισαγωγή στον Προγραμματισμό. Έλεγχος Ροής Προγράμματος

ΜΥΥ105: Εισαγωγή στον Προγραμματισμό. Έλεγχος Ροής Προγράμματος ΜΥΥ105: Εισαγωγή στον Προγραμματισμό Έλεγχος Ροής Προγράμματος Ροή προγράμματος Μέχρι τώρα έχουμε δει προγράμματα απλής ροής Οι εντολές εκτελούνται η μία μετά την άλλη σύμφωνα με την ακολουθία γραμμών

Διαβάστε περισσότερα

Θέματα Προγραμματισμού Η/Υ

Θέματα Προγραμματισμού Η/Υ Πρόγραμμα Μεταπτυχιακών Σπουδών Πληροφορική και Υπολογιστική Βιοϊατρική Θέματα Προγραμματισμού Η/Υ Ενότητα 10: Θεματική Ενότητα: Λίστες (Lists) και Πλειάδες (Tuples) ΘΕΜΑΤΑ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Η/Υ Θεματική

Διαβάστε περισσότερα

Γλώσσα προγραμματισμού python

Γλώσσα προγραμματισμού python Προηγούμενο Σημειώσεις Επόμενο Γλώσσα προγραμματισμού python Η γλώσσα αυτή γράφτηκε από τον Ολλανδό προγραμματιστή Guido van Rossum στα τέλη της δεκαετίας 1980-90. Η έκδοση 2.0 δημοσιεύτηκε στις 16 Οκτωβρίου

Διαβάστε περισσότερα

ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό. Εισαγωγή στην Python Χειµερινό Εξάµηνο 2014

ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό. Εισαγωγή στην Python Χειµερινό Εξάµηνο 2014 ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό Εισαγωγή στην Python Χειµερινό Εξάµηνο 2014 Εγκατάσταση Από το www.python.org è Downloads Υπάρχουν εκτενείς οδηγίες για όλα τα λειτουργικά (π.χ., Windows, Mac OS X)

Διαβάστε περισσότερα

ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό. Αναζήτηση και Ταξινόµηση Χειµερινό Εξάµηνο 2014

ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό. Αναζήτηση και Ταξινόµηση Χειµερινό Εξάµηνο 2014 ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό Αναζήτηση και Ταξινόµηση Χειµερινό Εξάµηνο 2014 Αναζήτηση και Ταξινόµηση Βασικές λειτουργίες σε προγράµµατα Αναζήτηση (searching): Βρες ένα ζητούµενο στοιχείο σε µια

Διαβάστε περισσότερα

Βασικές Ασκήσεις από τα Εργαστήρια της Python. Πέμπτη Εργ. 3 17:15 και 19:15

Βασικές Ασκήσεις από τα Εργαστήρια της Python. Πέμπτη Εργ. 3 17:15 και 19:15 Βασικές Ασκήσεις από τα Εργαστήρια της Python Πέμπτη Εργ. 3 17:15 και 19:15 Αντί να χρησιμοποιούμε πολλές ομοειδείς μεταβλητές του ίδιου τύπου, όπως παραδείγματος χάριν, οι 7 μέσες θερμοκρασίες μίας εβδομάδας,

Διαβάστε περισσότερα

ΜΥΥ105: Εισαγωγή στον Προγραμματισμό. Εισαγωγή στην Python Χειμερινό Εξάμηνο 2016

ΜΥΥ105: Εισαγωγή στον Προγραμματισμό. Εισαγωγή στην Python Χειμερινό Εξάμηνο 2016 ΜΥΥ105: Εισαγωγή στον Προγραμματισμό Εισαγωγή στην Python Χειμερινό Εξάμηνο 2016 H Γλώσσα Python Δημιουργήθηκε από τον Guido van Rossum ο οποίος εξακολουθεί να την εξελίσσει. Benevolent Dictator for Life

Διαβάστε περισσότερα

Βασικά στοιχεία γλώσσας προγραμματισμού. Σπάχος Κυριάκος Καθηγητής Πληροφορικής ΠΕ19

Βασικά στοιχεία γλώσσας προγραμματισμού. Σπάχος Κυριάκος Καθηγητής Πληροφορικής ΠΕ19 Βασικά στοιχεία γλώσσας προγραμματισμού Σπάχος Κυριάκος Καθηγητής Πληροφορικής ΠΕ19 Ας θυμηθούμε ξανά την παλιά μας «αγάπη» Η Python είναι μία σύγχρονη, διερμηνευόμενη, υψηλού επιπέδου γλώσσα γενικής χρήσης

Διαβάστε περισσότερα

Πληρουορική Γ Γσμμασίοσ

Πληρουορική Γ Γσμμασίοσ Πληρουορική Γ Γσμμασίοσ Προγραμματισμός και Αλγόριθμοι Από το και τημ Χελώμα στημ Ευριπίδης Βραχνός http://evripides.mysch.gr/ 2014 2015 1 Προγραμματισμός Ζάννειο Πρότυπο Πειραματικό Γυμνάσιο Πειραιά Ενότητα:

Διαβάστε περισσότερα

ΠΛΗΡΟΦΟΡΙΚΗ Ι (Python) Ενότητα 4

ΠΛΗΡΟΦΟΡΙΚΗ Ι (Python) Ενότητα 4 ΠΛΗΡΟΦΟΡΙΚΗ Ι (Python) Ενότητα 4 Λίστες (Lists) Λίστα (list) στην Python ονομάζεται μια δυναμική δομή δεδομένων (στην πραγματικότητα, ένα αντικείμενο) που περιέχει πολλαπλά δεδομένα. Ουσιαστικά, η λίστα

Διαβάστε περισσότερα

Θέματα Προγραμματισμού Η/Υ

Θέματα Προγραμματισμού Η/Υ Πρόγραμμα Μεταπτυχιακών Σπουδών Πληροφορική και Υπολογιστική Βιοϊατρική Θέματα Προγραμματισμού Η/Υ Ενότητα 4: Θεματική Ενότητα: Είσοδος/έξοδος, μεταβλητές, αναθέσεις ΘΕΜΑΤΑ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Η/Υ Θεματική

Διαβάστε περισσότερα

ΜΥΥ105: Εισαγωγή στον Προγραμματισμό. Αλφαριθμητικά Χειμερινό Εξάμηνο 2016

ΜΥΥ105: Εισαγωγή στον Προγραμματισμό. Αλφαριθμητικά Χειμερινό Εξάμηνο 2016 ΜΥΥ105: Εισαγωγή στον Προγραμματισμό Αλφαριθμητικά Χειμερινό Εξάμηνο 2016 Λειτουργίες σε αλφαριθμητικά Μπορούμε να εφαρμόσουμε όλες τις λειτουργίες που έχουμε δει για πλειάδες και λίστες (π.χ. slicing)

Διαβάστε περισσότερα

ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό. Έλεγχος Ροής - Παραδείγµατα Χειµερινό Εξάµηνο 2014

ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό. Έλεγχος Ροής - Παραδείγµατα Χειµερινό Εξάµηνο 2014 ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό Έλεγχος Ροής - Παραδείγµατα Χειµερινό Εξάµηνο 2014 Δίσεκτο έτος Ένα έτος είναι δίσεκτο αν διαιρείται ακριβώς µε το 400 ή διαιρείται ακριβώς µε το 4 και δεν διαιρείται

Διαβάστε περισσότερα

ΠΛΗΡΟΦΟΡΙΚΗ ΤΕΧΝΟΛΟΓΙΑ ΚΑΙ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ Η/Υ

ΠΛΗΡΟΦΟΡΙΚΗ ΤΕΧΝΟΛΟΓΙΑ ΚΑΙ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ Η/Υ ΠΑΝΕΠΙΣΤΗΜΙΟ AΙΓΑIΟΥ & ΑΕΙ ΠΕΙΡΑΙΑ Τ.Τ. Τμήματα Ναυτιλίας και Επιχειρηματικών Υπηρεσιών & Μηχ. Αυτοματισμού ΤΕ ΠΛΗΡΟΦΟΡΙΚΗ ΤΕΧΝΟΛΟΓΙΑ ΚΑΙ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ Η/Υ Εισαγωγή στη Python Νικόλαος Ζ. Ζάχαρης Αναπληρωτής

Διαβάστε περισσότερα

Εισαγωγή στον Προγ/μό Υπολογιστών

Εισαγωγή στον Προγ/μό Υπολογιστών Εισαγωγή στον Προγ/μό Υπολογιστών Διάλεξη 7 Ακολουθίες (Sequences) Περιεχόμενα 1. Ακολουθίες 2. Λίστα (list) 3. Επαναληπτικοί υπολογισμοί ακολουθιών 4. Επεξεργασία ακολουθιών 5. Τελεστές ακολουθιών 6.

Διαβάστε περισσότερα

Διάλεξη 2. Μεταβλητές - Δομές Δεδομένων - Eίσοδος δεδομένων - Έξοδος: Μορφοποίηση - Συναρτήσεις. Διοργάνωση : ΚΕΛ ΣΑΤΜ

Διάλεξη 2. Μεταβλητές - Δομές Δεδομένων - Eίσοδος δεδομένων - Έξοδος: Μορφοποίηση - Συναρτήσεις. Διοργάνωση : ΚΕΛ ΣΑΤΜ Διάλεξη 2 Μεταβλητές - Δομές Δεδομένων - Eίσοδος δεδομένων - Έξοδος: Μορφοποίηση - Συναρτήσεις Διοργάνωση : ΚΕΛ ΣΑΤΜ Διαφάνειες: Skaros, MadAGu Παρουσίαση: MadAGu Άδεια: Creative Commons 3.0 2 Internal

Διαβάστε περισσότερα

ΜΥΥ105: Εισαγωγή στον Προγραμματισμό. Σφάλματα, εξαιρέσεις, εκσφαλμάτωση Χειμερινό Εξάμηνο 2016

ΜΥΥ105: Εισαγωγή στον Προγραμματισμό. Σφάλματα, εξαιρέσεις, εκσφαλμάτωση Χειμερινό Εξάμηνο 2016 ΜΥΥ105: Εισαγωγή στον Προγραμματισμό Σφάλματα, εξαιρέσεις, εκσφαλμάτωση Χειμερινό Εξάμηνο 2016 Τύποι Σφαλμάτων Συντακτικά λάθη (syntax errors) Λάθη κατά την εκτέλεση (run-time errors) Λογικά σφάλματα 2

Διαβάστε περισσότερα

ΠΑΝΕΠΙΣΤΗΜΙΟ AΙΓΑIΟΥ & ΑΕΙ ΠΕΙΡΑΙΑ Τ.Τ. Τμήματα Ναυτιλίας και Επιχειρηματικών Υπηρεσιών & Μηχ. Αυτοματισμού ΤΕ. Εισαγωγή στη Python

ΠΑΝΕΠΙΣΤΗΜΙΟ AΙΓΑIΟΥ & ΑΕΙ ΠΕΙΡΑΙΑ Τ.Τ. Τμήματα Ναυτιλίας και Επιχειρηματικών Υπηρεσιών & Μηχ. Αυτοματισμού ΤΕ. Εισαγωγή στη Python ΠΑΝΕΠΙΣΤΗΜΙΟ AΙΓΑIΟΥ & ΑΕΙ ΠΕΙΡΑΙΑ Τ.Τ. Τμήματα Ναυτιλίας και Επιχειρηματικών Υπηρεσιών & Μηχ. Αυτοματισμού ΤΕ ΠΛΗΡΟΦΟΡΙΚΗ ΤΕΧΝΟΛΟΓΙΑ ΚΑΙ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ Η/Υ Εισαγωγή στη Python Νικόλαος Ζ. Ζάχαρης Αναπληρωτής

Διαβάστε περισσότερα

Σημειωματάριο Τετάρτης 18 Οκτ. 2017

Σημειωματάριο Τετάρτης 18 Οκτ. 2017 Σημειωματάριο Τετάρτης 18 Οκτ. 2017 Περισσότερα για λίστες και ανακύκλωση Είδαμε σήμερα διάφορα προβλήματα και λύσεις για λίστες. Είδαμε επίσης την ανακύκλωση while. Στο επόμενο βλέπουμε πώς μπορούμε να

Διαβάστε περισσότερα

ΠΛΗΡΟΦΟΡΙΚΗ Ι (Python) Ενότητα 5. Λεξικά (Dictionaries)

ΠΛΗΡΟΦΟΡΙΚΗ Ι (Python) Ενότητα 5. Λεξικά (Dictionaries) ΠΛΗΡΟΦΟΡΙΚΗ Ι (Python) Ενότητα 5 Λεξικά (Dictionaries) Τα λεξικά είναι μια μεταβλητή δομή δεδομένων της Python για την αποθήκευση συλλογών δεδομένων της μορφής: κλειδί τιμή. Δηλαδή, κάθε στοιχείο σε ένα

Διαβάστε περισσότερα

Βασικά Στοιχεία Python 3

Βασικά Στοιχεία Python 3 Βασικά Στοιχεία Python 3 Compiler Lecture s 1.0 documentation Βασικά Στοιχεία Python 3 Στη συνέχεια παρουσιάζονται ορισμένα ενδιαφέροντα στοιχεία της Python 3. Αυτό που ακολουθεί δεν είναι tutorial, αν

Διαβάστε περισσότερα

Εισαγωγή στην Γλώσσα Προγραμματισμού Python. 12/10/16 1

Εισαγωγή στην Γλώσσα Προγραμματισμού Python. 12/10/16 1 Εισαγωγή στην Γλώσσα Προγραμματισμού Python 12/10/16 costis@teicrete.gr 1 Διάφορες Γλώσσες Προγραμματισμού C or C++ Java Perl Scheme Fortran Python Matlab 12/10/16 costis@teicrete.gr 2 Περίληψη Παρουσίασης

Διαβάστε περισσότερα

Λίστες. Lista=[ red, green, blue ] Το πλήθος των στοιχείων μια λίστας δίνεται από τη συνάρτηση len(): Len(Lista)

Λίστες. Lista=[ red, green, blue ] Το πλήθος των στοιχείων μια λίστας δίνεται από τη συνάρτηση len(): Len(Lista) Λίστες Η πιο σημαντική ακολουθία της Python, μοιάζουν με τους πίνακες των παραδοσιακών γλωσσών αλλά είναι πολύ ποιο ευέλικτες: μπορεί να περιέχουν στοιχεία διαφορετικού τύπου και μας παρέχουν τη δυνατότητα

Διαβάστε περισσότερα

Στόχοι και αντικείμενο ενότητας. Πέρασμα Πίνακα σε Συνάρτηση (συν.) Πέρασμα Πίνακα σε Συνάρτηση. #8.. Ειδικά Θέματα Αλγορίθμων

Στόχοι και αντικείμενο ενότητας. Πέρασμα Πίνακα σε Συνάρτηση (συν.) Πέρασμα Πίνακα σε Συνάρτηση. #8.. Ειδικά Θέματα Αλγορίθμων Στόχοι και αντικείμενο ενότητας Πέρασμα Πίνακα σε Συνάρτηση #8.. Ειδικά Θέματα Αλγορίθμων Προβλήματα Αναζήτησης Γραμμική Αναζήτηση (Linear Search) Ενημέρωση Μέτρηση Δυαδική Αναζήτηση (Binary Search) Προβλήματα

Διαβάστε περισσότερα

Διάλεξη 1. Πράξεις Τελεστές Έλεγχος Ροής

Διάλεξη 1. Πράξεις Τελεστές Έλεγχος Ροής Διάλεξη 1 Πράξεις Τελεστές Έλεγχος Ροής Διοργάνωση : ΚΕΛ ΣΑΤΜ Διαφάνειες: Skaros, MadAGu Παρουσίαση: MadAGu Άδεια: Creative Commons 3.0 Αριθμητικοί Τελεστές- Αριθμητικές Πράξεις 2 Internal use only Αριθμητικοί

Διαβάστε περισσότερα

Γλώσσες Προγραμματισμού Εφαρμογών - ΜΕΠΒ20

Γλώσσες Προγραμματισμού Εφαρμογών - ΜΕΠΒ20 Γλώσσες Προγραμματισμού Εφαρμογών - ΜΕΠΒ20 Διάλεξη 2 Τύποι, Υπό Όρους Εκτέλεση Παπαϊωάννου Αθανάσιος Π.Μ.Σ. «Εφαρμοσμένη Πληροφορική» Χειμερινό Εξάμηνο 20 16-20 17 Αριθμητικές Εκφράσεις Τελεστής Πράξη

Διαβάστε περισσότερα

Φύλλο Εργασίας 3. Μια γρήγορη επανάληψη από τα προηγούμενα

Φύλλο Εργασίας 3. Μια γρήγορη επανάληψη από τα προηγούμενα 3 Φύλλο Εργασίας 3 Στο φύλλο εργασιών 3 θα ασχοληθούμε με τις λίστες μια δομή της γλώσσας python που έχει την δομή ενός πίνακα. Θα χρησιμοποιήσουμε τις βασικές εντολές από τις λίστες και θα κατασκευάσουμε

Διαβάστε περισσότερα

Ενότητα: Δυαδική Αναζήτηση Σχέδιο Δραστηριότητας: Παιχνίδι: Βρες τον αριθμό

Ενότητα: Δυαδική Αναζήτηση Σχέδιο Δραστηριότητας: Παιχνίδι: Βρες τον αριθμό Ενότητα: Δυαδική Αναζήτηση Σχέδιο Δραστηριότητας: Παιχνίδι: Βρες τον αριθμό 1 Εισαγωγή Σκεφτείτε έναν αριθμό από το 1 έως το 1000 και απαντήστε στην ερώτηση: Ο αριθμός που σκεφτήκατε είναι μεγαλύτερος

Διαβάστε περισσότερα

Πληροφορική ΙΙ Θεματική Ενότητα 10

Πληροφορική ΙΙ Θεματική Ενότητα 10 Ανοικτά Ακαδημαϊκά Μαθήματα στο ΤΕΙ Ιονίων Νήσων Πληροφορική ΙΙ Θεματική Ενότητα 10 Λίστες (Lists) και Πλειάδες (Tuples) Το περιεχόμενο του μαθήματος διατίθεται με άδεια Creative Commons εκτός και αν αναφέρεται

Διαβάστε περισσότερα

ΜΑΘΗΜΑΤΑ PYTHON. Καθηγητής Ι. Δημητρίου.

ΜΑΘΗΜΑΤΑ PYTHON. Καθηγητής Ι. Δημητρίου. ΜΑΘΗΜΑΤΑ PYTHON To 1991 o Guido van Rossman δημιούργησε την Python ως μια ανοιχτού λογισμικού ανεξάρτητη πλατφόρμας γενικού σκοπού γλώσσα προγραμματισμού (open source platformindependent). Είναι βασικά

Διαβάστε περισσότερα

Εισαγωγή στον Προγραμματισμό Python Μάθημα 4: Συναρτήσεις (functions) και δομοστοιχεία (modules) στην Python

Εισαγωγή στον Προγραμματισμό Python Μάθημα 4: Συναρτήσεις (functions) και δομοστοιχεία (modules) στην Python Εισαγωγή στον Προγραμματισμό Python Μάθημα 4: Συναρτήσεις (functions) και δομοστοιχεία (modules) στην Python Νοέμβριος 2014 Χ. Αλεξανδράκη, Γ. Δημητρακάκης Συναρτήσεις (Functions) Στον προγραμματισμό,

Διαβάστε περισσότερα

ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό. Σφάλµατα, εξαιρέσεις, εκσφαλµάτωση Χειµερινό Εξάµηνο 2014

ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό. Σφάλµατα, εξαιρέσεις, εκσφαλµάτωση Χειµερινό Εξάµηνο 2014 ΜΥΥ105: Εισαγωγή στον Προγραµµατισµό Σφάλµατα, εξαιρέσεις, εκσφαλµάτωση Χειµερινό Εξάµηνο 2014 Τύποι Σφαλµάτων Συντακτικά λάθη (syntax errors) Λάθη κατά την εκτέλεση (run-time errors) Λογικά σφάλµατα 2

Διαβάστε περισσότερα

ΓΛΩΣΣΙΚΗ ΤΕΧΝΟΛΟΓΙΑ. Python & NLTK: Εισαγωγή

ΓΛΩΣΣΙΚΗ ΤΕΧΝΟΛΟΓΙΑ. Python & NLTK: Εισαγωγή ΓΛΩΣΣΙΚΗ ΤΕΧΝΟΛΟΓΙΑ Python & NLTK: Εισαγωγή Εισαγωγή Γιατί Python? Παρουσίαση NLTK Πηγές και χρήσιμα εργαλεία Φροντιστήριο σε Python Στο φροντιστήριο: Εισαγωγή στην Python Ζητήματα προγραμματισμού για

Διαβάστε περισσότερα

Εισαγωγή στην Επιστήμη Υπολογιστών. Εισαγωγή στην Python

Εισαγωγή στην Επιστήμη Υπολογιστών. Εισαγωγή στην Python Εισαγωγή στην Επιστήμη Υπολογιστών Εισαγωγή στην Python Python scripts Ένα πρόγραμμα στην Python (συχνά αποκαλείται script) αποτελείται από μία ακολουθία ορισμών και εντολών. H ακολουθία των ορισμών και

Διαβάστε περισσότερα

Βασικά στοιχεία γλώσσας προγραμματισμού

Βασικά στοιχεία γλώσσας προγραμματισμού Βασικά στοιχεία γλώσσας προγραμματισμού Κέρος Α. Ιωάννης Καθηγητής Πληροφορικής ΠΕ19 1 ο ΕΠΑΛ Κιλκίς Ας θυμηθούμε ξανά την παλιά μας «αγάπη» Η Python είναι μία σύγχρονη, διερμηνευόμενη, υψηλού επιπέδου

Διαβάστε περισσότερα

print( x is positive ) Στο διερμηνευτή Python, προσοχή στη στοίχιση, διότι γίνεται από το χρήστη:

print( x is positive ) Στο διερμηνευτή Python, προσοχή στη στοίχιση, διότι γίνεται από το χρήστη: 37 ΛΑΜΒΑΝΟΝΤΑΣ ΑΠΟΦΑΣΕΙΣ 1. Εκτέλεση υπό συνθήκη if x >0: print('x is positive') x > = 0 print( x is positive ) Σχήμα: Η λογική του if then Στο διερμηνευτή Python, προσοχή στη στοίχιση, διότι γίνεται από

Διαβάστε περισσότερα

2.1. Εντολές. 2.2. Σχόλια. 2.3. Τύποι Δεδομένων

2.1. Εντολές. 2.2. Σχόλια. 2.3. Τύποι Δεδομένων 2 Βασικές Εντολές 2.1. Εντολές Οι στην Java ακολουθούν το πρότυπο της γλώσσας C. Έτσι, κάθε εντολή που γράφουμε στη Java θα πρέπει να τελειώνει με το ερωτηματικό (;). Όπως και η C έτσι και η Java επιτρέπει

Διαβάστε περισσότερα

Σημειώσεις του εργαστηριακού μαθήματος Πληροφορική ΙΙ. Εισαγωγή στην γλώσσα προγραμματισμού

Σημειώσεις του εργαστηριακού μαθήματος Πληροφορική ΙΙ. Εισαγωγή στην γλώσσα προγραμματισμού Σημειώσεις του εργαστηριακού μαθήματος Πληροφορική ΙΙ Εισαγωγή στην γλώσσα προγραμματισμού Ακαδημαϊκό έτος 2016-2017, Εαρινό εξάμηνο Οι σημειώσεις βασίζονται στα συγγράμματα: A byte of Python (ελληνική

Διαβάστε περισσότερα

Δυναμικές Ιστοσελίδες Εισαγωγή στην Javascript για προγραμματισμό στην πλευρά του client

Δυναμικές Ιστοσελίδες Εισαγωγή στην Javascript για προγραμματισμό στην πλευρά του client ΕΣΔ 516 Τεχνολογίες Διαδικτύου Δυναμικές Ιστοσελίδες Εισαγωγή στην Javascript για προγραμματισμό στην πλευρά του client Περιεχόμενα Περιεχόμενα Javascript και HTML Βασική σύνταξη Μεταβλητές Τελεστές Συναρτήσεις

Διαβάστε περισσότερα

Θέματα Προγραμματισμού Η/Υ

Θέματα Προγραμματισμού Η/Υ Πρόγραμμα Μεταπτυχιακών Σπουδών Πληροφορική και Υπολογιστική Βιοϊατρική Θέματα Προγραμματισμού Η/Υ Ενότητα 7: Θεματική Ενότητα: Δομές επανάληψης ΘΕΜΑΤΑ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Η/Υ Θεματική Ενότητα 7 Δομές επανάληψης

Διαβάστε περισσότερα

Εισαγωγή στον Προγραμματισμό Python Μάθημα 1: Μεταβλητές, τελεστές, είσοδος/έξοδος προγράμματος, συνθήκη ελέγχου if Νοέμβριος 2014 Χ. Αλεξανδράκη, Γ.

Εισαγωγή στον Προγραμματισμό Python Μάθημα 1: Μεταβλητές, τελεστές, είσοδος/έξοδος προγράμματος, συνθήκη ελέγχου if Νοέμβριος 2014 Χ. Αλεξανδράκη, Γ. Εισαγωγή στον Προγραμματισμό Python Μάθημα 1: Μεταβλητές, τελεστές, είσοδος/έξοδος προγράμματος, συνθήκη ελέγχου if Νοέμβριος 2014 Χ. Αλεξανδράκη, Γ. Δημητρακάκης Σύνοψη Μαθήματος Προηγούμενο μάθημα Αλγόριθμοι

Διαβάστε περισσότερα

Λογικές εκφράσεις και μεταβλητές

Λογικές εκφράσεις και μεταβλητές Προηγούμενο Σημειώσεις Επόμενο Λογικές εκφράσεις και μεταβλητές Μπορούμε να γράψουμε μία λογική έκφραση η οποία θα είναι είτε αληθής είτε ψευδής. Μία συνηθισμένη λογική έκφραση είναι αυτή που ελέγχει αν

Διαβάστε περισσότερα

Είδη εντολών. Απλές εντολές. Εντολές ελέγχου. Εκτελούν κάποια ενέργεια. Ορίζουν τον τρόπο με τον οποίο εκτελούνται άλλες εντολές

Είδη εντολών. Απλές εντολές. Εντολές ελέγχου. Εκτελούν κάποια ενέργεια. Ορίζουν τον τρόπο με τον οποίο εκτελούνται άλλες εντολές Μορφές Εντολών Είδη εντολών Απλές εντολές Εκτελούν κάποια ενέργεια Εντολές ελέγχου Ορίζουν τον τρόπο με τον οποίο εκτελούνται άλλες εντολές Εντολές και παραστάσεις Μιαεντολήείναιμιαπαράστασηπου ακολουθείται

Διαβάστε περισσότερα

Πληροφορική ΙΙ Θεματική Ενότητα 3

Πληροφορική ΙΙ Θεματική Ενότητα 3 Ανοικτά Ακαδημαϊκά Μαθήματα στο ΤΕΙ Ιονίων Νήσων Πληροφορική ΙΙ Θεματική Ενότητα 3 Είσοδος/έξοδος, μεταβλητές, αναθέσεις Το περιεχόμενο του μαθήματος διατίθεται με άδεια Creative Commons εκτός και αν αναφέρεται

Διαβάστε περισσότερα

Ενότητα 3 ΕΙΣΑΓΩΓΗ ΣΤΗ ΓΛΩΣΣΑ PYTHON

Ενότητα 3 ΕΙΣΑΓΩΓΗ ΣΤΗ ΓΛΩΣΣΑ PYTHON Ενότητα 3 ΕΙΣΑΓΩΓΗ ΣΤΗ ΓΛΩΣΣΑ PYTHON Εγκατάσταση της Python Τη γλώσσα Python μπορούμε να την «κατεβάσουμε» από το επίσημο Web Site : https://www.python.org/downloads/ Για τους σκοπούς του μαθήματος θα

Διαβάστε περισσότερα

Γλωσσική Τεχνολογία. Εισαγωγικό Φροντιστήριο

Γλωσσική Τεχνολογία. Εισαγωγικό Φροντιστήριο Γλωσσική Τεχνολογία Εισαγωγικό Φροντιστήριο Project του μαθήματος Εργασία 2 ατόμων Προφορική εξέταση για: Project (80%) Θεωρία (20%) Στο φροντιστήριο: Συζητάμε σχεδιαστικές επιλογές Λύνουμε ζητήματα υλοποίησης

Διαβάστε περισσότερα

Γλώσσες Προγραμματισμού Εφαρμογών - ΜΕΠΒ20

Γλώσσες Προγραμματισμού Εφαρμογών - ΜΕΠΒ20 Γλώσσες Προγραμματισμού Εφαρμογών - ΜΕΠΒ20 Διάλεξη 4 Ανακυκλώσεις Παπαϊωάννου Αθανάσιος Π.Μ.Σ. «Εφαρμοσμένη Πληροφορική» Χειμερινό Εξάμηνο 20 16-20 17 Συναρτήσεις: Παράμετρος key/value Μπορούμε να περάσουμε

Διαβάστε περισσότερα

Στόχοι και αντικείμενο ενότητας. Εκφράσεις. Η έννοια του τελεστή. #2.. Εισαγωγή στη C (Μέρος Δεύτερο) Η έννοια του Τελεστή

Στόχοι και αντικείμενο ενότητας. Εκφράσεις. Η έννοια του τελεστή. #2.. Εισαγωγή στη C (Μέρος Δεύτερο) Η έννοια του Τελεστή Στόχοι και αντικείμενο ενότητας Η έννοια του Τελεστή #2.. Εισαγωγή στη C (Μέρος Δεύτερο) Εκφράσεις Προτεραιότητα Προσεταιριστικότητα Χρήση παρενθέσεων Μετατροπές Τύπων Υπονοούμενες και ρητές μετατροπές

Διαβάστε περισσότερα

Προγραμματιστικά Εργαλεία και Τεχνολογίες για Επιστήμη Δεδομένων

Προγραμματιστικά Εργαλεία και Τεχνολογίες για Επιστήμη Δεδομένων Προγραμματιστικά Εργαλεία και Τεχνολογίες για Επιστήμη Δεδομένων Παράδοση 20/12/2018, Νίκος Παπασπύρου. Εισαγωγή στις γλώσσες σεναρίων (scripting languages) Βλ. π.χ. Κεφάλαιο 13 του βιβλίου Πραγματολογία

Διαβάστε περισσότερα

11/23/2014. Στόχοι. Λογισμικό Υπολογιστή

11/23/2014. Στόχοι. Λογισμικό Υπολογιστή ονάδα Δικτύων και Επικοινωνιών ΗΥ Τομέας Πληροφορικής, αθηματικών και Στατιστικής ΓΕΩΠΟΙΚΟ ΠΑΕΠΙΣΤΗΙΟ ΑΘΗΩ Εισαγωγή στην Επιστήμη των ΗΥ άθημα-4 url: http://openeclass.aua.gr (AOA0) Λογισμικό Υπολογιστή

Διαβάστε περισσότερα

Εξαιρέσεις Εισαγωγή. Εξαιρέσεις. ηµήτρης Λεβεντέας

Εξαιρέσεις Εισαγωγή. Εξαιρέσεις. ηµήτρης Λεβεντέας Εισαγωγή Εξαιρέσεις ηµήτρης Λεβεντέας 20 Μαΐου 2010 Εισαγωγή Ορισµός Τι είναι Ορισµός Ο χειρισµός εξαιρέσεων είναι µια κατασκευή η οποία µας επιτρέπει να χειριστούµε ειδικές συνθήκες που αλλάζουν την ϕυσιολογική

Διαβάστε περισσότερα

Διαδικασιακός Προγραμματισμός

Διαδικασιακός Προγραμματισμός Τμήμα ΜΗΧΑΝΙΚΩΝ ΠΛΗΡΟΦΟΡΙΚΗΣ ΤΕ ΤΕΙ ΔΥΤΙΚΗΣ ΕΛΛΑΔΑΣ Διαδικασιακός Προγραμματισμός Διάλεξη 12 η Αναζήτηση/Ταξινόμηση Πίνακα Οι διαλέξεις βασίζονται στο βιβλίο των Τσελίκη και Τσελίκα C: Από τη Θεωρία στην

Διαβάστε περισσότερα

Θέματα Προγραμματισμού Η/Υ

Θέματα Προγραμματισμού Η/Υ Πρόγραμμα Μεταπτυχιακών Σπουδών Πληροφορική και Υπολογιστική Βιοϊατρική Θέματα Προγραμματισμού Η/Υ Ενότητα 8: Θεματική Ενότητα: Συναρτήσεις ΘΕΜΑΤΑ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Η/Υ Θεματική Ενότητα 8 Συναρτήσεις Πληροφορική

Διαβάστε περισσότερα

JAVASCRIPT 1. Διδάσκοντες: Π. Αγγελάτος, Δ. Ζήνδρος Επιμέλεια διαφανειών: Π. Αγγελάτος Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών

JAVASCRIPT 1. Διδάσκοντες: Π. Αγγελάτος, Δ. Ζήνδρος Επιμέλεια διαφανειών: Π. Αγγελάτος Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών JAVASCRIPT 1 Διδάσκοντες: Π. Αγγελάτος, Δ. Ζήνδρος Επιμέλεια διαφανειών: Π. Αγγελάτος Σχολή Ηλεκτρολόγων Μηχανικών και Μηχανικών Υπολογιστών Άδεια Χρήσης Το παρόν εκπαιδευτικό υλικό υπόκειται σε άδειες

Διαβάστε περισσότερα

Προγραμματισμός Η/Υ. Ενότητα 8: Ειδικά Θέματα Αλγορίθμων

Προγραμματισμός Η/Υ. Ενότητα 8: Ειδικά Θέματα Αλγορίθμων Προγραμματισμός Η/Υ Ενότητα 8: Ειδικά Θέματα Αλγορίθμων Νίκος Καρακαπιλίδης, Καθηγητής Δημήτρης Σαραβάνος, Καθηγητής Πολυτεχνική Σχολή Τμήμα Μηχανολόγων & Αεροναυπηγών Μηχανικών Σκοποί ενότητας Κατανόηση

Διαβάστε περισσότερα

Εισαγωγή στον Προγραμματισμό

Εισαγωγή στον Προγραμματισμό Εισαγωγή στον Προγραμματισμό Έλεγχος Δημήτρης Μιχαήλ Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο Ακ. Έτος 2012-2013 Σχεσιακοί Τελεστές και Ισότητας Ένα πρόγραμμα εκτός από αριθμητικές πράξεις

Διαβάστε περισσότερα

ΠΛΗΡΟΦΟΡΙΚΗ Ι JAVA Τμήμα θεωρίας με Α.Μ. σε 3, 7, 8 & 9 22/11/07

ΠΛΗΡΟΦΟΡΙΚΗ Ι JAVA Τμήμα θεωρίας με Α.Μ. σε 3, 7, 8 & 9 22/11/07 Ακαδ έτος 2007-2008 ΠΛΗΡΟΦΟΡΙΚΗ Ι Φερεντίνος 22/11/07 ΠΛΗΡΟΦΟΡΙΚΗ Ι JAVA Τμήμα θεωρίας με ΑΜ σε 3, 7, 8 & 9 22/11/07 Παράδειγμα με if/else if και user input: import javautil*; public class Grades public

Διαβάστε περισσότερα

Διαχείριση Περιεχομένου Παγκόσμιου Ιστού και Γλωσσικά Εργαλεία ΕΙΣΑΓΩΓΙΚΟ ΦΡΟΝΤΙΣΤΗΡΙΟ

Διαχείριση Περιεχομένου Παγκόσμιου Ιστού και Γλωσσικά Εργαλεία ΕΙΣΑΓΩΓΙΚΟ ΦΡΟΝΤΙΣΤΗΡΙΟ Διαχείριση Περιεχομένου Παγκόσμιου Ιστού και Γλωσσικά Εργαλεία ΕΙΣΑΓΩΓΙΚΟ ΦΡΟΝΤΙΣΤΗΡΙΟ Project του μαθήματος Εργασία 2 ατόμων Προφορική εξέταση για: Project (80%) Θεωρία (20%) Στο φροντιστήριο: Συζητάμε

Διαβάστε περισσότερα

ΜΥΥ105: Εισαγωγή στον Προγραμματισμό. Συναρτήσεις

ΜΥΥ105: Εισαγωγή στον Προγραμματισμό. Συναρτήσεις ΜΥΥ105: Εισαγωγή στον Προγραμματισμό Συναρτήσεις Δόμηση προγράμματος Μέχρι τώρα έχουμε δει πως να χρησιμοποιούμε έτοιμες συναρτήσεις και μεθόδους στα προγράμματά μας (π.χ. le(), max(), prit()) Μπορούμε

Διαβάστε περισσότερα

Στοιχειώδης προγραμματισμός σε C++

Στοιχειώδης προγραμματισμός σε C++ Στοιχειώδης προγραμματισμός σε C++ Σύντομο Ιστορικό. Το πρόγραμμα Hello World. Ο τελεστής εξόδου. Μεταβλητές και δηλώσεις τους. Αντικείμενα, μεταβλητές, σταθερές. Ο τελεστής εισόδου. Θεμελιώδεις τύποι.

Διαβάστε περισσότερα

Στόχοι και αντικείμενο ενότητας. Προτάσεις επανάληψης. Έλεγχος ροής προγράμματος. #5.. Εντολές Επανάληψης

Στόχοι και αντικείμενο ενότητας. Προτάσεις επανάληψης. Έλεγχος ροής προγράμματος. #5.. Εντολές Επανάληψης Στόχοι και αντικείμενο ενότητας Έλεγχος ροής προγράμματος (βλ. ενότητα #4) Δομή επανάληψης #5.. Εντολές Επανάληψης Προτάσεις επανάληψης Εντολές while, do while Εντολή for Περί βρόχων (loops) Τελεστές,

Διαβάστε περισσότερα

ΕΙΣΑΓΩΓΗ ΣΤΟΥΣ Η/Υ (ΟΜΑΔΑ ΘΕΜΑΤΩΝ A)

ΕΙΣΑΓΩΓΗ ΣΤΟΥΣ Η/Υ (ΟΜΑΔΑ ΘΕΜΑΤΩΝ A) ΑΣΚΗΣΗ 1 Δίνεται η λογική συνάρτηση: F = ((A AND B) OR (B AND C) OR (A AND C)) ΕΙΣΑΓΩΓΗ ΣΤΟΥΣ Η/Υ (ΟΜΑΔΑ ΘΕΜΑΤΩΝ A) α) Σχεδιάστε το λογικό κύκλωμα που υλοποιεί τη συνάρτηση F. β) Σχηματίστε τον πίνακα

Διαβάστε περισσότερα

Διορθώσεις σελ

Διορθώσεις σελ Διορθώσεις σελ. 73-74 # Τώρα ο άνθρωπος σκέφτεται έναν αριθμό από 1 έως 1000 Ν = 1000 print Σκέψου έναν αριθμό από το 1 έως το, Ν guesses = 0 found = False first = 1 last = N while not found and guesses

Διαβάστε περισσότερα

Εισαγωγή στον Προγραμματισμό

Εισαγωγή στον Προγραμματισμό Εισαγωγή στον Προγραμματισμό Μάθημα 1ο Εφαρμογές Πληροφορικής Τάξη Α 2017-18 Επισκόπηση Βασικές έννοιες προγραμματισμού Εισαγωγή στην Python Γιατί να ξεκινήσω να προγραμματίζω με Python? 2 Βασικές έννοιες

Διαβάστε περισσότερα

Τιμές και τύποι, μεταβλητές Ένα πρώτο σημαντικό βήμα για να μάθουμε να προγραμματίζουμε είναι να

Τιμές και τύποι, μεταβλητές Ένα πρώτο σημαντικό βήμα για να μάθουμε να προγραμματίζουμε είναι να Κεφ.3 Τιμές και τύποι, μεταβλητές Κεφάλαιο 3 Τιμές και τύποι, μεταβλητές Ένα πρώτο σημαντικό βήμα για να μάθουμε να προγραμματίζουμε είναι να κατανοήσουμε τους βασικούς τύπους δεδομένων της Python: τους

Διαβάστε περισσότερα

ΗΥ-150. Προγραμματισμός

ΗΥ-150. Προγραμματισμός ΗΥ-150 Εντολές Ελέγχου Ροής Σειριακή εκτέλεση εντολών Όλα τα προγράμματα «γράφονται» χρησιμοποιώντας 3 είδη εντολών: Σειριακές εντολές (sequential built in C) Εντολές απόφασης (if, if/else, switch) Περιλαμβάνει

Διαβάστε περισσότερα

ΗΥ-150. Προγραμματισμός

ΗΥ-150. Προγραμματισμός ΗΥ-150 Εντολές Ελέγχου Ροής Σειριακή εκτέλεση εντολών Όλα τα προγράμματα «γράφονται» χρησιμοποιώντας 3 είδη εντολών: Σειριακές εντολές (sequential built in C) Εντολές απόφασης (if, if/else, switch) Περιλαμβάνει

Διαβάστε περισσότερα

Θέματα Προγραμματισμού Διαδικτύου ~ PHP ~

Θέματα Προγραμματισμού Διαδικτύου ~ PHP ~ Θέματα Προγραμματισμού Διαδικτύου ~ PHP ~ Στελιος Σφακιανάκης Εαρινό 2019 Αυτή η εργασία χορηγείται με άδεια Creative Commons Αναφορά Δημιουργού - Μη Εμπορική Χρήση - Παρόμοια Διανομή 1 Server-side programming

Διαβάστε περισσότερα

Εισαγωγή στην Επιστήμη Υπολογιστών. Εισαγωγή στην Python

Εισαγωγή στην Επιστήμη Υπολογιστών. Εισαγωγή στην Python Εισαγωγή στην Επιστήμη Υπολογιστών Εισαγωγή στην Python Β Μέρος Δομή Ελέγχου if-elif-else Επαναληπτική Δομή Ελέγχου while Επαναληπτική Δομή Ελέγχου for Αλληλεπίδραση χρήστη-προγράμματος Συναρτήσεις Η δομή

Διαβάστε περισσότερα

alpha Language age (3/5) alpha Language Φροντιστήριο Syntax Directed Translation and

alpha Language age (3/5) alpha Language Φροντιστήριο Syntax Directed Translation and alpha Language (1/5) ΗΥ-340 Γλώσσες και Μεταφραστές Φροντιστήριο Syntax Directed Translation and alpha Language Στην alpha δεν υπάρχει main() συνάρτηση, ο κώδικας ξεκινάει την εκτέλεση από την αρχή του

Διαβάστε περισσότερα

ΕΠΛ131 Αρχές Προγραμματισμού

ΕΠΛ131 Αρχές Προγραμματισμού ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΥΠΡΟΥ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ ΕΠΛ131 Αρχές Προγραμματισμού Ακαδημαϊκό Έτος 2016/17 Χειμερινό Εξάμηνο ΕΝΔΙΑΜΕΣΗ ΕΞΕΤΑΣΗ ΗΜΕΡΟΜΗΝΙΑ: 29 Οκτωβρίου 2016 ΔΙΑΡΚΕΙΑ: 10:00πμ 12:30μμ ΑΙΘΟΥΣΕΣ: Κτήριο

Διαβάστε περισσότερα

Θέματα Προγραμματισμού Η/Υ

Θέματα Προγραμματισμού Η/Υ Πρόγραμμα Μεταπτυχιακών Σπουδών Πληροφορική και Υπολογιστική Βιοϊατρική Θέματα Προγραμματισμού Η/Υ Ενότητα 5: Θεματική Ενότητα: Μεταβλητές και Μαθηματικοί και λογικοί τελεστές ΘΕΜΑΤΑ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Η/Υ

Διαβάστε περισσότερα

ιαδικαστικός Προγραμματισμός

ιαδικαστικός Προγραμματισμός ΤΜΗΜΑ ΕΦΑΡΜΟΣΜΕΝΗΣ ΠΛΗΡΟΦΟΡΙΚΗΣ ιαδικαστικός Προγραμματισμός Α Εξάμηνο Μάθημα 2 ο : Εντολές ελέγχου > εντολές υπό συνθήκη Στόχοι μαθήματος Να κατανοήσετε τη σχέση μεταξύ εντολών και παραστάσεων. Να αναγνωρίζετε

Διαβάστε περισσότερα

Θέματα Προγραμματισμού Η/Υ

Θέματα Προγραμματισμού Η/Υ Πρόγραμμα Μεταπτυχιακών Σπουδών Πληροφορική και Υπολογιστική Βιοϊατρική Θέματα Προγραμματισμού Η/Υ Ενότητα 6: Θεματική Ενότητα: Λογικοί Τελεστές Έλεγχος ροής ΘΕΜΑΤΑ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Η/Υ Θεματική Ενότητα

Διαβάστε περισσότερα

ΜΑΘΗΜΑΤΑ PYTHON. Καθηγητής Ι. Δημητρίου.

ΜΑΘΗΜΑΤΑ PYTHON. Καθηγητής Ι. Δημητρίου. ΜΑΘΗΜΑΤΑ PYTHON To 1991 o Guido van Rossman δημιούργησε την Python ως μια ανοιχτού λογισμικού ανεξάρτητη πλατφόρμας γενικού σκοπού γλώσσα προγραμματισμού (open source platformindependent). Είναι βασικά

Διαβάστε περισσότερα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Εισαγωγή στη Java II

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Εισαγωγή στη Java II ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Εισαγωγή στη Java II HelloWorld.java class HelloWorld public static void main(string args[]) // print message System.out.println( Hello world! ); javac HelloWorld.java

Διαβάστε περισσότερα

Προγραμματισμός Υπολογιστών & Εφαρμογές Python. Κ.Π. Γιαλούρης

Προγραμματισμός Υπολογιστών & Εφαρμογές Python. Κ.Π. Γιαλούρης Προγραμματισμός Υπολογιστών & Κ.Π. Γιαλούρης Στόχοι του σημερινού μαθήματος Εξοικείωση με τα περιβάλλοντα της Python Κατανόηση βασικών εννοιών & τεχνικών Τύπος δεδομένων Μεταβλητή Εντολή ανάθεση τιμής

Διαβάστε περισσότερα

Αντικειμενοστρεφής Προγραμματισμός -Python. Κ.Π. Γιαλούρης

Αντικειμενοστρεφής Προγραμματισμός -Python. Κ.Π. Γιαλούρης Κ.Π. Γιαλούρης Στόχοι του σημερινού μαθήματος Εξοικείωση με τα περιβάλλοντα της Python Κατανόηση βασικών εννοιών & τεχνικών Τύπος δεδομένων Μεταβλητή Εντολή ανάθεση τιμής / εντολή αντικατάστασης Εισαγωγή

Διαβάστε περισσότερα

Σημειωματάριο Τετάρτης 4 Οκτ. 2017

Σημειωματάριο Τετάρτης 4 Οκτ. 2017 Σημειωματάριο Τετάρτης 4 Οκτ. 2017 Strings (λέξεις) Ένας από τους κύριους τύπους δεδομένων στην Python είναι τα strings (κείμενα, λέξεις). Όταν γράφουμε ένα κείμενο σε απλά ή διπλά εισαγωγικά τότε αυτό

Διαβάστε περισσότερα

Γραφικά υπολογιστών Εργαστήριο 1 Εισαγωγή στην Python

Γραφικά υπολογιστών Εργαστήριο 1 Εισαγωγή στην Python Γραφικά υπολογιστών Εργαστήριο 1 Εισαγωγή στην Python Σκοπός της 1ης άσκησης είναι η εξοικείωση με τη γλώσσα προγραμματισμού Python, την οποία και θα χρησιμοποιήσουμε και στις υπόλοιπες εργαστηριακές ασκήσεις.

Διαβάστε περισσότερα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Εισαγωγή στη Java II

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Εισαγωγή στη Java II ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ Εισαγωγή στη Java II Strings Η κλάση String είναι προκαθορισμένη κλάση της Java που μας επιτρέπει να χειριζόμαστε αλφαριθμητικά. Ο τελεστής + μας επιτρέπει

Διαβάστε περισσότερα

Εισαγωγή στη γλώσσα προγραμματισμού C++

Εισαγωγή στη γλώσσα προγραμματισμού C++ Εισαγωγή στη γλώσσα προγραμματισμού C++ Περιβάλλον Εργασίας 2 Περιβάλλον Εργασίας 1. Χρήση απλού κειμενογράφου και Μεταγλωττιστή 2. Ολοκληρωμένα Περιβάλλοντα Εργασίας (Integrated Development Environments)

Διαβάστε περισσότερα

ΜΥΥ105: Εισαγωγή στον Προγραμματισμό. Έλεγχος Ροής - Παραδείγματα

ΜΥΥ105: Εισαγωγή στον Προγραμματισμό. Έλεγχος Ροής - Παραδείγματα ΜΥΥ105: Εισαγωγή στον Προγραμματισμό Έλεγχος Ροής - Παραδείγματα Δίσεκτο έτος Ένα έτος είναι δίσεκτο αν διαιρείται ακριβώς με το 400 ή διαιρείται ακριβώς με το 4 και δεν διαιρείται ακριβώς με το 100 Υπολογίστε

Διαβάστε περισσότερα

ΕΞΕΤΑΖΟΜΕΝΟ ΜΑΘΗΜΑ: ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΥΠΟΛΟΓΙΣΤΩΝ ΣΥΝΟΛΟ ΣΕΛΙΔΩΝ: ΕΞΙ (6)

ΕΞΕΤΑΖΟΜΕΝΟ ΜΑΘΗΜΑ: ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΥΠΟΛΟΓΙΣΤΩΝ ΣΥΝΟΛΟ ΣΕΛΙΔΩΝ: ΕΞΙ (6) ΑΡΧΗ 1ΗΣ ΣΕΛΙΔΑΣ ΕΠΑΝΑΛΗΠΤΙΚΕΣ ΠΑΝΕΛΛΑΔΙΚΕΣ ΕΞΕΤΑΣΕΙΣ HMEΡΗΣΙΩΝ ΚΑΙ ΕΣΠΕΡΙΝΩΝ ΕΠΑΓΓΕΛΜΑΤΙΚΩΝ ΛΥΚΕΙΩΝ ΠΑΡΑΣΚΕΥΗ 22 ΣΕΠΤΕΜΒΡΙΟΥ 2017 ΘΕΜΑ Α ΕΞΕΤΑΖΟΜΕΝΟ ΜΑΘΗΜΑ: ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΥΠΟΛΟΓΙΣΤΩΝ ΣΥΝΟΛΟ ΣΕΛΙΔΩΝ:

Διαβάστε περισσότερα

ΛΕΙΤΟΥΡΓΙΚΑ ΣΥΣΤΗΜΑΤΑ I

ΛΕΙΤΟΥΡΓΙΚΑ ΣΥΣΤΗΜΑΤΑ I ΛΕΙΤΟΥΡΓΙΚΑ ΣΥΣΤΗΜΑΤΑ I Πιτροπάκης Νικόλαος Υποψήφιος Διδάκτορας Contact: npitrop@unipi.gr Υφαντόπουλος Νικόλαος Υποψήφιος Διδάκτορας Contact: nifantop@unipi.gr If at first you don't succeed, call it version

Διαβάστε περισσότερα

Εργαστήριο 7: Ο αλγόριθμος ταξινόμησης Radix Sort

Εργαστήριο 7: Ο αλγόριθμος ταξινόμησης Radix Sort Εργαστήριο 7: Ο αλγόριθμος ταξινόμησης Radix Sort Στην ενότητα αυτή θα μελετηθούν τα εξής επιμέρους θέματα: -Ο αλγόριθμος ταξινόμησης Radix Sort -Δυο εκδοχές: Most Significant Digit (MSD) και Least Significant

Διαβάστε περισσότερα

ΛΕΙΤΟΥΡΓΙΚΑ ΣΥΣΤΗΜΑΤΑ Ι

ΛΕΙΤΟΥΡΓΙΚΑ ΣΥΣΤΗΜΑΤΑ Ι ΛΕΙΤΟΥΡΓΙΚΑ ΣΥΣΤΗΜΑΤΑ Ι Λύβας Χρήστος chrislibas@ssl-unipi.gr Μανουσόπουλος Χρήστος cman@unipi.gr Αρχική επιμέλεια Πιτροπάκης Νικόλαος και Υφαντόπουλος Νικόλαος >_ ΔΕΣΜΕΥΜΕΝΑ ΟΝΟΜΑΤΑ +- Υπάρχουν ορισμένες

Διαβάστε περισσότερα