ΕΙΣΑΓΩΓΗ ΣΤΗΝ ΓΛΩΣΣΑ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ C

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

Download "ΕΙΣΑΓΩΓΗ ΣΤΗΝ ΓΛΩΣΣΑ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ C"

Transcript

1 ΕΙΣΑΓΩΓΗ ΣΤΗΝ ΓΛΩΣΣΑ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ C Ιανουάριος 2013

2 Τι είναι ένα πρόγραμμα; Πρόγραμμα είναι μία σειρά από οδηγίες που δίνουμε στον υπολογιστή προκειμένου αυτός να κάνει κάποια συγκεκριμένη εργασία Πώς λαμβάνει τις οδηγίες αυτές ο υπολογιστής; Κανονικά, επειδή ο υπολογιστής είναι ένα μηχάνημα δεν έχει δηλαδή έμφυτη ευφυΐα- για να μπορούμε να συνεννοηθούμε μαζί του θα έπρεπε να του μιλούσαμε απ ευθείας στην γλώσσα του. Η γλώσσα αυτή ονομάζεται γλώσσα μηχανής και όλες οι λέξεις της αποτελούνται από δύο και μόνο σύμβολα: το 0 και το 1. Αυτό συμβαίνει γιατί ο υπολογιστής αποτελείται από δισεκατομμύρια κυκλώματα μέσα από τα οποία είτε περνάει (1), είτε δεν περνάει ρεύμα (0). Έτσι για παράδειγμα εάν θέλαμε να του λέγαμε πρόσθεσε, θα έπρεπε να δίναμε την εντολή: Πράγματι, στους πρώτους υπολογιστές ο προγραμματισμός γινόταν με αυτόν τον τρόπο: εντολή προς εντολή οι προγραμματιστές έπρεπε να ανοίγουν και να κλείνουν εκατοντάδες κυκλώματα μέσω ειδικών διακοπτών και λυχνιών προκειμένου να καθοδηγήσουν το μηχάνημα. Σήμερα βέβαια τα πράγματα έχουν απλοποιηθεί σημαντικά. Αφενός δεν χρειάζεται εμείς να ανοίγουμε και να κλείνουμε κυκλώματα, αφετέρου οι γλώσσες που χρησιμοποιούμε για να επικοινωνήσουμε μαζί του έχουν αντικαταστήσει τις ατελείωτες αυτές σειρές από 0 και 1 με απλούστερα σύμβολα και με φράσεις-εντολές που πλησιάζουν πολύ την ανθρώπινη γλώσσα. Τι είναι μία γλώσσα προγραμματισμού; Το σύνολο αυτών των ειδικών συμβόλων και φράσεων-εντολών -οι οποίες πλησιάζουν αρκετά την δική μας γλώσσα- ονομάζεται γλώσσα προγραμματισμού. Σήμερα συναντούμε αρκετές τέτοιες γλώσσες προγραμματισμού, κάθε μία από τις οποίες εξειδικεύεται στην επίλυση συγκεκριμένων προβλημάτων. Τέτοιες γλώσσες είναι η BASIC, η FORTRAN, η PASCAL, η C αλλά και άλλες νεότερης γενιάς όπως η JAVA, η C++, η Visual Basic κ.α. Πώς ο υπολογιστής καταλαβαίνει μία γλώσσα προγραμματισμού; Όλες οι παραπάνω γλώσσες για να γίνουν τελικά οδηγίες για τον υπολογιστή, πρέπει οπωσδήποτε να μεταφραστούν στην γλώσσα που αυτός καταλαβαίνει, δηλαδή στην γλώσσα μηχανής. Αυτό γίνεται με την βοήθεια ενός ειδικού προγράμματος που είναι επιφορτισμένο με αυτήν και μόνο την δουλειά: να μεταφέρει δηλαδή εντολή προς εντολή και σύμβολο προς σύμβολο ό,τι εμείς γράψαμε με τη συγκεκριμένη γλώσσα προγραμματισμού στη γλώσσα μηχανής, σε σειρές τελικά από 0 και 1. Το πρόγραμμα αυτό ονομάζεται μεταγλωττιστής (compiler) ή σε άλλα περιβάλλοντα διερμηνέας (interpreter). Η χρησιμοποιεί ένα τέτοιο πρόγραμμα - μεταγλωττιστή (compiler). 2

3 Ποια είναι τα βήματα προγραμματισμού στην γλώσσα C ; Στην : 1. Γράφουμε αρχικά τις εντολές που θέλουμε να απαρτίσουν το πρόγραμμά μας με βάση τους κανόνες σύνταξης, τις εντολές και τα ειδικά σύμβολα που η γλώσσα C διαθέτει. Αυτό συνήθως γίνεται με την βοήθεια ενός επεξεργαστή κειμένου (text editor) ή ακόμη καλύτερα μέσω ενός ειδικού περιβάλλοντος ανάπτυξης κώδικα (SDK, Software Development Kit). Όταν ολοκληρώσουμε το πρόγραμμα το αποθηκεύουμε στο σκληρό δίσκο με την μορφή: οποιοδήποτε_όνομα.c. Το αρχείο αυτό -η κατάληξη του οποίου πρέπει να είναι πάντα σε.c 1 - αποτελεί τον πηγαίο κώδικα (source code), όπως συνηθίζουμε να λέμε, η μορφή δηλαδή εκείνη του προγράμματος που πλησιάζει στην δική μας γλώσσα παρά στη γλώσσα μηχανής. 2. Στη συνέχεια δίνουμε την εντολή μεταγλώττισης (compile), η οποία βρίσκεται συνήθως σε ένα από τα menu του περιβάλλοντος ανάπτυξης, προκειμένου ο πηγαίος κώδικας να μεταφραστεί σε γλώσσα μηχανής. Το πρόγραμμα-μεταγλωττιστής πριν κάνει την μετάφραση, ελέγχει εάν υπάρχουν καθόλου πιθανά συντακτικά λάθη που κάναμε γράφοντας τον πηγαίο κώδικα. Εάν αυτό συμβαίνει -πράγμα διόλου απίθανο, ειδικά για τα πρώτα μας προγράμματα- μας τα υποδεικνύει, χωρίς να προχωρήσει στη μεταγλώττιση. Σε αυτήν την περίπτωση επιστρέφουμε στον πηγαίο μας κώδικα και διορθώνουμε τα λάθη μας, φροντίζοντας να αποθηκεύσουμε πάλι το πρόγραμμα με την διορθωμένη του μορφή. Όταν τελικά ο μεταγλωττιστής δεν εντοπίσει λάθη, προχωράει στη μεταγλώττιση του πηγαίου σε γλώσσα μηχανής. Το αρχείο το οποίο περιέχει το μεταγλωττισμένο πρόγραμμά μας ονομάζεται αντικείμενο πρόγραμμα (object code). Έχει το ίδιο όνομα με το πηγαίο και ξεχωρίζει απ αυτό μόνο στην κατάληξή του: οποιοδήποτε_όνομα.obj. Σε κάποια άλλα περιβάλλοντα το ενδιάμεσο αυτό αρχείο μπορεί να μην εμφανίζεται και ο μεταγλωττιστής να παράγει απευθείας το.exe αρχείο, όπως αυτό αναλύεται στο βήμα Το τελικό αρχείο που πρέπει να φτιάξουμε προκειμένου το πρόγραμμά μας να εκτελεστεί απ τον υπολογιστή είναι το οποιοδήποτε_όνομα.exe (η κατάληξη exe σημαίνει executable, δηλαδή εκτελέσιμο). Αυτό γίνεται με την εντολή make exe που επίσης δίνεται από τα menu του περιβάλλοντος ανάπτυξης κώδικα. Τόσο το αρχείο οποιοδήποτε_όνομα.obj όσο και το αρχείο οποιοδήποτε_όνομα.exe περιέχουν το πρόγραμμά μας σε μορφή γλώσσας μηχανής (σε 0 και 1). Ποια είναι τότε η διαφορά τους; Εάν παρατηρήσουμε προσεκτικότερα θα δούμε ότι το.exe αρχείο έχει μεγαλύτερο μέγεθος από το.obj. Τι παραπάνω προστέθηκε στο εκτελέσιμο αρχείο; Η απάντηση βρίσκεται στο ότι όταν εμείς γράφουμε ένα πηγαίο κώδικα, πολλές από τις λειτουργίες που περιγράφουμε σε αυτόν δεν περιλαμβάνονται με την πλήρη τους μορφή. Αυτές οι λειτουργίες αφορούν εντολές που χρησιμοποιούμε πολύ συχνά σε ένα πρόγραμμα -πχ. εντολές εισόδου-εξόδου, μαθηματικές συναρτήσεις, εντολές γραφικών κλπ.- και οι οποίες ακριβώς επειδή χρησιμοποιούνται πολύ συχνά από όλους τους προγραμματιστές, δεν χρειάζεται να γράφουμε την πλήρη τους ανάπτυξη στον πηγαίο κώδικα. Η πλήρης τους ανάπτυξη βρίσκεται μέσα σε ειδικές βιβλιοθήκες της C και είναι αυτές που προστίθενται κατά την τελική φάση της μεταγλώττισης, όταν δηλαδή δημιουργούμε τον εκτελέσιμο κώδικα, έτσι ώστε ο κώδικας να εκτελεστεί σωστά από τον υπολογιστή. 1 Σε άλλες περιπτώσεις, εάν το περιβάλλον ανάπτυξης αφορά τη γλώσσα C++, ενδέχεται η κατάληξη του πηγαίου κώδικα να εμφανίζεται και ως.cpp. 3

4 Το οποιοδήποτε_όνομα.exe αρχείο, περιέχει λοιπόν σε γλώσσα μηχανής το πρόγραμμα που γράψαμε εμείς συν όλες τις απαραίτητες επεξηγήσεις εντολών που χρησιμοποιήσαμε σε αυτό. (σημείωση: το εκτελέσιμο αρχείο μπορεί να το συναντήσουμε και χωρίς την κατάληξη exe, δηλαδή με το όνομά του και μόνο: οποιοδήποτε_όνομα) 4. Το πρόγραμμά μας είναι έτοιμο. Μπορεί να μεταφερθεί και να εκτελεστεί σε οποιοδήποτε άλλο μηχάνημα τρέχει το ίδιο λειτουργικό σύστημα. Οποιεσδήποτε αλλαγές θέλουμε να κάνουμε σε αυτό πρέπει να ακολουθήσουμε ξανά τα βήματα 1-3. παράδειγμα αρχείων που χρησιμοποιεί η C: το αρχείο Prg3.c είναι ο πηγαίος κώδικας το αρχείο Prg3.obj η μεταγλώττισή του σε γλώσσα μηχανής (object code) το αρχείο Prg3.exe το εκτελέσιμο αρχείο (ή εφαρμογή) (παρατηρήστε τη διαφορά μεγέθους μεταξύ obj και exe αρχείου) το αρχείο Prg3.bak είναι εφεδρικό αντίγραφο (backup) του πηγαίου μας κώδικα 4

5 Η δομή ενός προγράμματος στην γλώσσα C Ένα πρόγραμμα σε C έχει συνήθως αυτή τη μορφή: main( ){ εντολή 1; εντολή 2; /* αυτό δεν είναι εντολή, αλλά ένα σχόλιο */ εντολή 3;. εντολή Ν; Οι εντολές γράφονται με τη σειρά που θα εκτελεστούν, τερματίζουν με το ελληνικό ερωτηματικό (;) και εμπεριέχονται μέσα σε δύο αγκύλες ξεκινώντας απ την ανοικτή και καταλήγοντας στην κλειστή αγκύλη. Οι δύο αυτές αγκύλες στην ουσία σηματοδοτούν την αρχή και το τέλος της κύριας ενότητας ενός προγράμματος σε C, η οποία δηλώνεται πριν από τις αγκύλες με το όνομα main( ). Ένα πρόγραμμα σε C μπορεί να αποτελείται από πολλές τέτοιες ενότητες κάθε μία από τις οποίες έχει το δικό της όνομα και τη δική της ξεχωριστή λειτουργία. Έτσι αντί να γράφαμε όλες τις εντολές του προγράμματός μας μέσα σε μία κεντρική ενότητα μπορούμε να δημιουργήσουμε ξεχωριστές ενότητες, κάθε μία από τις οποίες περιέχει τις εντολές εκείνες που αντιστοιχούν στην συγκεκριμένη ενότητα. Οι ενότητες αυτές στη γλώσσα C ονομάζονται functions, και το πρόγραμμά μας τις εκτελεί με τη σειρά που καλούνται από την κεντρική function, δηλαδή την main( ). Παράδειγμα αντί να γράφαμε: main( ){ /* οι παρακάτω εντολές διαβάζουν κάποια δεδομένα*/ εντολή 1; εντολή 2; εντολή 3; /* οι παρακάτω εντολές υπολογίζουν μία αριθμητική τιμή*/ εντολή 4; εντολή 5; /*οι παρακάτω εντολή εμφανίζει το αποτέλεσμα στην οθόνη*/ εντολή 6; μπορούμε να γράψουμε: main( ){ input_data( ); calculate( ); output_results( ); 5

6 input_data( ){ εντολή 1; εντολή 2; εντολή 3; calculate( ){ εντολή 4; εντολή 5; output_results( ){ εντολή 6; Το πρόγραμμα τώρα εκτελεί με τη σειρά τις function input_data( ), calculate( ) και output_results( ), με τη σειρά δηλαδή που δηλώθηκαν για να κληθούν μέσα από την main( ). Αυτή η δομή προγραμματισμού είναι σαφώς πιο ευέλικτη και πιο οικονομική αφού δεν χρειάζεται να γράφουμε πολλές φορές την ίδια ομάδα εντολών. Αρκεί μόνο να τις γράψουμε μία φορά και να τις καλέσουμε όσες φορές χρειαστεί ξανά, καλώντας το όνομα της function. Η συγκεκριμένη μορφή προγραμματισμού ονομάζεται δομημένος προγραμματισμός. Το πρώτο πρόγραμμα - η εντολή εξόδου printf( ) main( ){ printf( Γεια και χαρά ); To πρόγραμμα αυτό αποτελείται από μία μόνο εντολή: την printf( ). H printf( ) είναι μία εντολή εξόδου, αφού εμφανίζει ό,τι περιέχεται μέσα στα διπλά εισαγωγικά, στη μονάδα εξόδου του υπολογιστή μας, δηλαδή στην οθόνη. Τα τρία Ε: Είσοδος, Επεξεργασία, Έξοδος Κάθε πρόγραμμα που θέλουμε να γράψουμε με την C -αλλά και σε οποιαδήποτε άλλη γλώσσα δομημένου προγραμματισμού- πρέπει πρώτα να αναλυθεί σε τρία βήματα: 1. Ποια είναι τα δεδομένα μου (Είσοδος) 2. Ποια η επεξεργασία που πρέπει να γίνει σε αυτά (Επεξεργασία) 3. Τι θα συμβεί με το αποτέλεσμα της επεξεργασίας τους (Έξοδος) 6

7 Έστω για παράδειγμα πως έχουμε ένα πρόβλημα υπολογισμού. Θέλουμε το πρόγραμμά μας κάθε φορά να μας υπολογίζει το μέγεθος ενός αρχείου εικόνας σε byte. O τύπος υπολογισμού είναι: μέγεθος αρχείου = οριζόντια ανάλυση x κάθετη ανάλυση (σε pixel) x bytes κωδικοποίησης Προσεγγίζοντας το πρόβλημα με βάση τα τρία αυτά βήματα έχουμε την παρακάτω ανάλυση: 1. Είσοδος: Σαν είσοδο έχουμε κάθε φορά τρία δεδομένα: α. την οριζόντια ανάλυση (σε pixel) β. την κάθετη ανάλυση (σε pixel) γ. τα bytes κωδικοποίησης Για κάθε ένα από τα δεδομένα αυτά αντιστοιχούμε μία μεταβλητή: α. hpix β. vpix γ. bytes 2. Επεξεργασία: Η επεξεργασία που γίνεται στα δεδομένα μας είναι η εξής: hpix x vpix x bytes 3. Έξοδος: Η έξοδος που λαμβάνουμε από την επεξεργασία είναι μία αριθμητική τιμή. Και σε αυτήν πρέπει να αντιστοιχίσουμε μία μεταβλητή. Ας την ονομάσουμε size. To πρόβλημά μας σχηματικά αναλύεται ως εξής: 7

8 Η έννοια της μεταβλητής Όπως είδαμε στο προηγούμενο παράδειγμα, τόσο για κάθε ένα από τα δεδομένα μας, όσο και για το αποτέλεσμα αντιστοιχήσαμε μία μεταβλητή. Αυτό γίνεται γιατί κάθε φορά που τρέχουμε ένα πρόγραμμα αλλάζουν οι τιμές των δεδομένων -άρα και του αποτελέσματος. Αυτό όμως που δεν αλλάζει είναι η όλη διαδικασία. Χρησιμοποιώντας λοιπόν μεταβλητές κρατάμε την ροή της διαδικασίας επίλυσης του προβλήματος, δίνοντας παράλληλα σε αυτές τις τιμές που εμείς κάθε φορά θέλουμε να υπολογίσουμε. Η μεταβλητή μπορεί λοιπόν να ειδωθεί σαν μία κενή θέση στη μνήμη του υπολογιστή, η οποία λαμβάνει και μία διαφορετική τιμή κάθε φορά που εκτελείται το πρόγραμμα μας. Δήλωση μεταβλητών Πριν λοιπόν ξεκινήσουμε οποιαδήποτε εντολή στo πρόγραμμά μας, πρέπει πρώτα να δηλώσουμε τις μεταβλητές που θα χρησιμοποιήσουμε, έτσι ώστε αφενός να κρατηθεί θέση γι αυτές στη μνήμη του υπολογιστή, αφετέρου να ξέρει ο υπολογιστής πού θα τις αναζητήσει όταν τις χρησιμοποιεί στην επεξεργασία. Στο συγκεκριμένο 8

9 παράδειγμα αυτό γίνεται ακριβώς μετά από την ανοικτή αγκύλη της function main( ), δηλαδή στην πρώτη γραμμή του προγράμματός μας: main( ){ int hpix, vpix, bytes, size; Eίδη μεταβλητών Πριν συνεχίσουμε πρέπει να πούμε ότι υπάρχουν διαφορετικά είδη μεταβλητών που χρησιμοποιούνται από την C. Πρέπει λοιπόν πρώτα απ όλα να δηλώσουμε τον σωστό τύπο. Ο τύπος δηλώνεται στην ίδια γραμμή μαζί με τα ονόματα των μεταβλητών που αντιστοιχούν σε αυτόν και ακριβώς πριν από αυτές. Στο παράδειγμα βλέπουμε ότι ο τύπος μεταβλητής που χρησιμοποιούμε είναι ο int (δηλαδή integer, ακέραιος). Οι μεταβλητές στην C είναι διαφόρων ειδών. Αυτές ποικίλουν ανάλογα το μέγεθος που καταλαμβάνουν στην μνήμη (σε bytes), και ανάλογα το περιεχόμενό τους (αριθμός ή χαρακτήρας). Μία μεταβλητή μπορεί να δέχεται τρεις διαφορετικούς τύπους δεδομένων: - χαρακτήρες (τύπου char) - ακέραιους αριθμούς (τύπου int) - πραγματικούς αριθμούς (τύπου float ή double) Το μέγεθος που καταλαμβάνουν στη μνήμη οι παραπάνω τύποι μεταβλητών, ποικίλει από υπολογιστή σε υπολογιστή. Σε γενικές όμως γραμμές έχουμε τα παρακάτω μεγέθη: τύπος μεταβλητής μέγεθος σε bytes περιεχόμενο char 1 ASCII χαρακτήρας int 2 προσημασμένος ακέραιος ( έως 32767) unsigned int 2 θετικός ακέραιος (0 έως 65535) long int 4 προσημασμένος μεγάλος ακέραιος ( έως ) unsigned long int 4 θετικός μεγάλος ακέραιος (0 έως ) float 4 δεκαδικός με προσέγγιση 6 δεκαδικών ψηφίων double 8 δεκαδικός με προσέγγιση 10 δεκαδικών ψηφίων long double 16 δεκαδικός με προσέγγιση 10 δεκαδικών ψηφίων Προσέχουμε το εύρος τιμών των παραπάνω τύπων να συμπίπτει με το μέγεθος των μεταβλητών που χρησιμοποιούμε. Με βάση λοιπόν τα παραπάνω στοιχεία οι μεταβλητές του προγράμματός μας μπορούν να δηλωθούν σωστότερα και ως εξής: main( ){ unsigned int hpix, vpix, bytes; 9

10 unsigned long int size; H μνήμη τώρα θα δείχνει ως εξής: Σε εποχές που οι μνήμες ήταν περιορισμένες σε μέγεθος η παραπάνω λογική οργάνωσης των μεταβλητών είχε κάποιο νόημα. Σήμερα, που δεν τίθενται τέτοιου είδους περιορισμοί, μπορούμε άνετα να δηλώνουμε τις αριθμητικές μεταβλητές ως int, float ή double. Πώς μία μεταβλητή λαμβάνει τιμές - η εντολή scanf( ) Aφού δηλώσαμε τις μεταβλητές που θα χρησιμοποιήσουμε, πριν προχωρήσουμε στην επεξεργασία τους πρέπει πρώτα να λάβουν κάποιες τιμές. Αυτό γίνεται με την εντολή scanf( ). Ας δούμε για παράδειγμα πώς η μεταβλητή η οποία αντιστοιχεί στη συχνότητα δειγματοληψίας (η sr), λαμβάνει μία τιμή: printf( \n Δώστε την συχνότητα δειγματοληψίας: ); 10

11 scanf( %lf, &sr); Ο τύπος δεδομένων που η εντολή scanf( ) θα διαβάσει δηλώνεται αμέσως μετά το σύμβολο % (εδώ lf, δηλαδή τύπου double). Έξω από τα διπλά εισαγωγικά και μετά το κόμα ακολουθεί η μεταβλητή η οποία θα λάβει την τιμή. Γενικά η scanf( ) δηλώνεται ως εξής: scanf( %Σ1 %Σ2 % ΣN, &μεταβλητή1, &μεταβλητή2,, &μεταβλητήn); όπου Σ1, Σ2,, ΣΝ οι τύποι των μεταβλητών μεταβλητή1, μεταβλητή2,, μεταβλητήn αντίστοιχα. Τα σύμβολα που διαβάζουν συγκεκριμένους τύπους μεταβλητών είναι τα εξής: %c διαβάζει έναν χαρακτήρα %d διαβάζει έναν ακέραιο αριθμό %f διαβάζει έναν float αριθμό %lf διαβάζει έναν double αριθμό Πριν από την scanf( ) προηγείται σχεδόν πάντα μία printf( ) η οποία μας προτρέπει να εισάγουμε την τιμή που η scanf( ) ακολούθως θα διαβάσει. Αυτό γίνεται για να γνωρίζουμε κατά την εκτέλεση του προγράμματος πότε θα εισάγουμε μία συγκεκριμένη τιμή. Πρέπει επίσης να γνωρίζουμε πως η scanf( ) είναι μία εντολή που παγώνει την εκτέλεση του προγράμματος ώσπου εμείς να εισάγουμε απ το πληκτρολόγιο την (ή τις) τιμή (τιμές), για τις οποίες είναι προγραμματισμένη να δεχθεί. Η συνέχεια στο πρόγραμμα δίνεται αφού πατήσουμε το πλήκτρο enter. Τελικά η εισαγωγή δεδομένων στο πρόγραμμά μας γράφεται ως εξής: printf( \n Δώστε την ανάλυση της εικόνας σε οριζόντια pixel: ); scanf( %ld, &hpix); printf( \n Δώστε την ανάλυση της εικόνας σε κάθετα pixel: ); scanf( %d, &vpix); printf( \n Δώστε τo πλήθος των byte κωδικοποίησης: ); scanf( %d, &bytes); To σύμβολο \n (new line) στην printf( ) δηλώνει αλλαγή γραμμής κατά την εμφάνιση του μηνύματος στην οθόνη. Συνοπτικά θα μπορούσαμε να γράφαμε τον ίδιο κώδικα με την χρήση μιας μόνο scanf( ): printf( \n Δώστε με τη εξής σειρά: ); printf( \n α) την ανάλυση της εικόνας σε οριζόντια pixel:, ); printf( \n β) την ανάλυση της εικόνας σε κάθετα pixel:, ); printf( \n γ) τo πλήθος των byte κωδικοποίησης: ); scanf( %ld %d %d, &hpix, &vpix, &bytes); Eπεξεργασία - Το σύμβολο = 1 1

12 Ακολουθεί η επεξεργασία των δεδομένων μας με την παρακάτω εντολή: size = hpix x vpix x bytes; Το σύμβολο ισότητας ( = ) στην γλώσσα C έχει διαφορετική έννοια από αυτή των μαθηματικών. Δηλώνει πως ό,τι βρίσκεται στην δεξιά πλευρά του, θα καταχωρηθεί στην μεταβλητή που βρίσκεται στην αριστερή. Παράδειγμα: i = i +1; H εντολή αυτή δηλώνει πως η μεταβλητή i θα λάβει την τιμή που είχε έως εκείνη την στιγμή αυξημένη κατά μία μονάδα. 12

13 Οι τελεστές πράξεων Η C χρησιμοποιεί συγκεκριμένα σύμβολα για τις αριθμητικές πράξεις. Αυτά είναι: - αφαίρεση + πρόσθεση * πολλαπλασιασμός / διαίρεση (μεταξύ ακέραιων :το ακέραιο μέρος) % διαίρεση (μεταξύ ακέραιων: το δεκαδικό μέρος) -- μείωση κατά μία μονάδα ++ αύξηση κατά μία μονάδα Προτεραιότητα πράξεων Οι παραπάνω τελεστές πράξεων έχουν συγκεκριμένη προτεραιότητα με την οποία εκτελούνται. Για παράδειγμα η έκφραση: * 3 θα δώσει αποτέλεσμα 7, αφού ο πολλαπλασιασμός προηγείται σαν πράξη της πρόσθεσης. Εάν θέλαμε να γίνει πρώτα η πρόσθεση, θα έπρεπε να χρησιμοποιούσαμε την παρένθεση. Έτσι η έκφραση: (1 + 2) * 3 θα δώσει αποτέλεσμα 9. Γενικά στην C ο πολλαπλασιασμός και η διαίρεση έχουν μεγαλύτερο βαθμό προτεραιότητας από την πρόσθεση και την αφαίρεση. Τι θα συμβεί στην περίπτωση που η C συναντήσει ίδιας προτεραιότητας πράξεις, π.χ. 12 / 6 * 2 θα δώσει αποτέλεσμα 4, ή 1; Το σωστό αποτέλεσμα είναι το 4 αφού για πράξεις ίσης προτεραιότητας, αυτές εκτελούνται με τη σειρά που συναντώνται από τα αριστερά προς τα δεξιά. Εάν θέλαμε το αντίθετο θα χρησιμοποιούσαμε παρενθέσεις: 12 / (6 * 2) 13

14 Έξοδος - Η εντολή printf( ) Όπως έχουμε δει η εντολή printf( ) εμφανίζει στην οθόνη ό,τι περιέχεται ανάμεσα στα διπλά εισαγωγικά. Μπορεί όμως πέρα από αυτό να μας εμφανίσει και το περιεχόμενο μιας μεταβλητής. Στο σημείο που θέλουμε να εμφανιστεί η τιμή της μεταβλητής χρησιμοποιούμε το σύμβολο % ακολουθούμενο από τον τύπο της μεταβλητής, ενώ μετά τα διπλά εισαγωγικά δηλώνουμε το όνομα της μεταβλητής. Για παράδειγμα στο πρόγραμμά μας για να εμφανίζαμε το αποτέλεσμα της επεξεργασίας θα δηλώναμε: printf( \nτο μέγεθος του αρχείου εικόνας είναι: %f, size); Πρόγραμμα: ο υπολογισμός μεγέθους ενός αρχείου εικόνας Το πρόγραμμά μας ολοκληρωμένο έχει ως εξής: main(){ /* δήλωση μεταβλητών */ int vpix, hpix, bytes, size; /* εισαγωγή τιμών */ printf( \n Δώστε με τη εξής σειρά: ); printf( \n α) την ανάλυση της εικόνας σε οριζόντια pixel:, ); printf( \n β) την ανάλυση της εικόνας σε κάθετα pixel:, ); printf( \n γ) τo πλήθος των byte κωδικοποίησης: ); scanf( %ld %d %d, &hpix, &vpix, &bytes); /* επεξεργασία */ size = hpix x vpix x bytes; /*έξοδος αποτελέσματος*/ printf( \nτο μέγεθος του αρχείου εικόνας είναι: %f, size); 14

15 Περισσότερα για το σύμβολο καταχώρησης ( = ) Στο προηγούμενο παράδειγμα είδαμε ένα πρόγραμμα που χρησιμοποιεί τρεις μεταβλητές για να υπολογίσει μία αριθμητική τιμή και να την αποθηκεύσει τελικά σε μία τέταρτη μεταβλητή. Τι συμβαίνει όμως στην περίπτωση που χρειάζεται να επεξεργαστούμε πολλά δεδομένα; Φανταστείτε για παράδειγμα την περίπτωση που μας ζητηθεί ο μέσος όρος κάποιων τιμών που αφορούν π.χ. την βαθμολογία ενός τμήματος. Ο τύπος υπολογισμού (ΕΠΕΞΕΡΓΑΣΙΑ) είναι ο ακόλουθος: Μ.Ο. = βαθμός1 + βαθμός2 + βαθμός3 + + βαθμόςν Ν,όπου Ν το πλήθος των βαθμών. Εάν υποτεθεί ότι έχουμε 100 διαφορετικούς βαθμούς, τότε θα χρειαζόμασταν 100 διαφορετικές μεταβλητές; Η απάντηση είναι προς το παρόν όχι, αρκεί να μην μας ζητηθεί κάτι παραπάνω πέρα από τον μέσο όρο (ή μία οποιαδήποτε άλλη γενικά ακολουθιακή διαδικασία). Την λύση μας την δίνει το σύμβολο καταχώρησης, δηλαδή το μαθηματικό σύμβολο της ισότητας ( = ). Όπως είδαμε και πριν το σύμβολο αυτό δεν σηματοδοτεί την ισότητα όπως αυτό είναι συνηθισμένο στα μαθηματικά, παρά δηλώνει πως όποια μεταβλητή βρίσκεται στα αριστερά του θα λάβει την τιμή που βρίσκεται δεξιά του, παράδειγμα εάν εκτελεστούν με τη σειρά που εμφανίζονται οι παρακάτω εντολές: y = 1; /* το y λαμβάνει την τιμή 1 */ x = 34; /* το x λαμβάνει την τιμή 34 */ x = x y; /* το x λαμβάνει την τιμή */ τότε η μεταβλητή x έχει τελικά καταχωρημένη την τιμή 36 Η λύση λοιπόν του προβλήματός μας βρίσκεται αρκεί να δηλώσουμε μία μεταβλητή στην οποία θα καταχωρούμε έναν - έναν όλους τους βαθμούς αθροιστικά και στο τέλος θα κάνουμε την διαίρεση με το πλήθος των αριθμών (το 100), παράδειγμα: float sum; /* δηλώνουμε την μεταβλητή αθροιστή */ float x; /* και την μεταβλητή - βοηθό της για να μαζεύει τους βαθμούς που θα /* πληκτρολογούμε εμείς κάθε φορά */ sum = 0; /* τις μηδενίζουμε προκειμένου να σιγουρευτούμε πως δεν προϋπάρχουν */ x = 0; /* ήδη κάποιες άλλες τιμές σε αυτές τις θέσεις της μνήμης */ printf( Δώσε τον πρώτο βαθμό\n ); /* ζητάμε τον πρώτο βαθμό */ scanf( %f, &x); /* η x λαμβάνει τον πρώτο βαθμό */ sum = sum + x; /* καταχώρισε την πρώτη τιμή στη μεταβλητή sum */ /*μαζί με ό,τι προϋπήρχε στην sum (το 0) */ printf( Δώσε τον δεύτερο βαθμό\n ); /* ζητάμε τον δεύτερο βαθμό */ scanf( %f, &x); /* η x τώρα λαμβάνει τον δεύτερο βαθμό */ sum = sum + x; /* καταχώρισε την δεύτερη τιμή στη μεταβλητή sum, */ /* μαζί με ό,τι προϋπήρχε (ο βαθμός1)*/ 15

16 printf( Δώσε τον τρίτο βαθμό\n ); /* ζητάμε τον τρίτο βαθμό */ scanf( %f, &x); /* η x τώρα λαμβάνει τον τρίτο βαθμό */ sum = sum + x; /* καταχώρισε την τρίτη τιμή στη μεταβλητή sum, */ /* μαζί με ό,τι προϋπήρχε (ο βαθμός1 + ο βαθμός2)*/ printf( Δώσε τον τέταρτο βαθμό\n ); /* ζητάμε τον τέταρτο βαθμό */ scanf( %f, &x); /* η x τώρα λαμβάνει τον τέταρτο βαθμό */ sum = sum + x; /* καταχώρισε την τέταρτη τιμή στη μεταβλητή sum, */ /* μαζί με ό,τι προϋπήρχε (ο βαθμός1 + ο βαθμός2 + ο βαθμός3)*/ κλπ. μάλιστα. Άλλες 96 τέτοιες τριάδες εντολών και τελειώσαμε Επαναληπτικές διαδικασίες - Η εντολή for Και όμως υπάρχει λύση στην ατελείωτη πληκτρολόγηση (και δεν εννοούμε βέβαια την κλασσική copy-paste). Όταν μία διαδικασία επαναλαμβάνεται στο πρόγραμμά μας, υπάρχει μία ειδική εντολή στην οποία αρκεί να δηλώσουμε πόσες φορές θα επαναληφθούν οι εντολές που αποτελούν την διαδικασία αυτή. Η εντολή αυτή είναι η for και συντάσσεται ως εξής: όπου : for(i = 0; i < loop_times; i ++){ /* η ανοικτή αγκύλη σηματοδοτεί την έναρξη*/ ακολουθούν οι εντολές που θέλουμε να επαναλαμβάνονται (πάντα μέσα στις δύο αγκύλες) /* και η κλειστή την λήξη μίας περιόδου επανάληψης*/ i, ο μετρητής της επανάληψης loop_times, o αριθμός επαναλήψεων και τα τρία πεδία εντός της παρένθεσης, τα οποία προσδιορίζουν τα εξής: i = 0 : το πρώτο πεδίο δηλώνει την αρχική τιμή με την οποία θα ξεκινήσει να μετράει ο αθροιστής. Η τιμή αυτή λαμβάνεται μία και μοναδική φορά απ τον μετρητή, όταν δηλαδή ξεκινήσει για πρώτη φορά η επανάληψη. Στη συνέχεια ο μετρητής θα μεταβάλει τις τιμές του ανάλογα με το τρίτο πεδίο ή κάποια άλλη εντολή -πιθανώς- η οποία βρίσκεται εντός των αγκύλων επανάληψης (μέσα δηλαδή στον βρόγχο ή loop). Το i μπορεί να λαμβάνει οποιαδήποτε αρχική τιμή (πχ. i = 1 ή i = -2 ή i = 1000), ανάλογα πως αυτό βολεύει στην χρήση του. i < loop _times : το δεύτερο πεδίο δηλώνει τη συνθήκη επανάληψης. Όταν αυτή παύσει να ισχύει σταματούν και οι επαναλήψεις. Εδώ δηλώνεται σαν συνθήκη ανισότητας, δηλαδή όσο η μεταβλητή i είναι μικρότερη από μία τιμή οι επαναλήψεις θα συνεχίζονται. Όταν το i λάβει την τιμή loop_times το πρόγραμμα σταματάει τις επαναλήψεις και συνεχίζει εκτελώντας τις εντολές που ακολουθούν 16

17 αμέσως μετά την κλειστή αγκύλη του βρόγχου. Η συνθήκη επανάληψης μπορεί να είναι οποιαδήποτε λογική σχέση, πχ. i = = 100 (το i να ισούται με 100) i >= - 45 (το i να είναι μεγαλύτερο ή ίσο με το - 45) i > 500 i < 1000 (το i να είναι μεγαλύτερο του 500 είτε μικρότερο του 1000) i < 1000 && k = = 0 (το i να είναι μικρότερο του 1000 και ταυτόχρονα το k ίσο με 0) x!= 0 (μία άλλη μεταβλητή x να είναι διάφορη του μηδενός) a/23*sin(z) <= b (η συγκεκριμένη παράσταση να είναι μικρότερη ή ίση με το b) (c = getchar( ) )!= \n (να μην πληκτρολογήσουμε enter) i ++ : το τρίτο πεδίο δηλώνει τι θα συμβαίνει στον μετρητή κάθε φορά που ο βρόγχος επαναλαμβάνεται (εδώ ο μετρητής i θα αυξάνει κάθε φορά κατά μία μονάδα). Και εδώ μπορούμε να δηλώσουμε οποιαδήποτε αριθμητική πράξη θέλουμε να υπολογίζεται κάθε φορά που επαναλαμβάνεται ο βρόγχος, πχ. i -- (το i να μειώνεται κάθε φορά κατά μία μονάδα) i += 3 (το i να αυξάνεται κάθε φορά κατά τρεις μονάδες) i -= 8, j ++ (το i να μειώνεται κάθε φορά κατά 8 μονάδες και το j να αυξάνεται κατά μία) Το πρόγραμμα υπολογισμού Μ.Ο. εκατό (ή οποιουδήποτε πλήθους) τιμών Το πρόγραμμα τώρα έχει ως εξής: /***** υπολογισμός Μ.Ο. 100 πραγματικών αριθμών *****/ main( ){ float sum = 0; float x = 0; int i = 0; for(i = 0 ; i < 100 ; i ++){ /* αρχή βρόγχου επανάληψης */ printf( \nδώσε τον %d ο βαθμό:, i +1); scanf( %f, &x); sum = sum + x; /* τέλος βρόγχου επανάληψης */ printf( \nο μέσος όρος των 100 βαθμών είναι: %f, sum/100); /* τέλος της main( ) */ Eάν θέλαμε να υπολογίζουμε τον Μ.Ο. ενός οποιουδήποτε πλήθους τιμών, το πρόγραμμά μας θα αλλάξει ελάχιστα: 1. Θα προσθέσουμε μία ακέραια μεταβλητή η οποία θα δέχεται το πλήθος για το οποίο θα υπολογίζουμε τον Μ.Ο. (πχ. η amount ) 17

18 2. Η σύγκριση επανάληψης στον βρόγχο της for, δεν θα συγκρίνει πλέον τον μετρητή i με την τιμή 100, αλλά με την μεταβλητή amount 3. Η διαίρεση τέλος, εντός την printf( ), δεν θα γίνεται με το 100 αλλά με την amount, δηλαδή: /***** υπολογισμός Μ.Ο. μεταβλητού πλήθους πραγματικών αριθμών *****/ main( ){ float sum = 0; float x = 0; int i = 0; int amount = 0; printf( \nποιο είναι το πλήθος των βαθμών για τον υπολογισμό του Μ.Ο.; ); scanf( %d, &amount); /* η amount παίρνει τιμή απ το πληκτρολόγιο */ for(i = 0 ; i < amount ; i ++){ /* αρχή βρόγχου επανάληψης */ printf( \nδώσε τον %d ο βαθμό:, i +1); scanf( %f, x); sum = sum + x; /* τέλος βρόγχου επανάληψης */ printf( \nο μέσος όρος των %d βαθμών είναι: %f, amount, sum/amount); /* τέλος της main( ) */ H εντολή if και οι παραλλαγές της H εντολή if κατευθύνει την ροή του προγράμματος σε συγκεκριμένες ενότητες εντολών, ανάλογα το αποτέλεσμα που λαμβάνει. Δηλαδή: if(x>y){ a = 1; /* η ενότητα εντολών η οποία εκτελείται μόνο εάν το x > y */ printf( \nτο x είναι όντως μεγαλύτερο από το y ); else{ /* δηλαδή εάν το x<= y */ a = 0; /* η ενότητα εντολών η οποία εκτελείται εάν το x <= y */ printf( \nτο y είναι όντως μεγαλύτερο (ή ίσο) από το x ); Εάν θέλουμε το πρόγραμμά μας να κάνει συγκεκριμένες ενέργειες μόνο όταν το x > y και στην περίπτωση που δεν ισχύει κάτι τέτοιο απλώς να συνεχίζει, τότε συντάσσουμε την if χωρίς την else: if(x>y){ /* η ενότητα εντολών η οποία εκτελείται μόνο εάν το x > y */ a = 1; printf( \nτο x είναι όντως μεγαλύτερο από το y ); 18

19 /* το πρόγραμμα συνεχίζει με άλλες εντολές */ Εάν τέλος θέλουμε να κάνουμε συγκεκριμένες ενέργειες και για την περίπτωση της ισότητας ξεχωριστά (x = y), τότε γράφουμε μία ακόμη if: if(x>y){ /* η ενότητα εντολών η οποία εκτελείται μόνο εάν το x > y */ a = 1; printf( \nτο x είναι όντως μεγαλύτερο από το y ); else if(x<y){ /* η ενότητα εντολών η οποία εκτελείται εάν το x < y */ a = 0; printf( \nτο y είναι όντως μεγαλύτερο από το x ); else{ /* η ενότητα εντολών η οποία εκτελείται εάν το x = y */ a = -1; printf( \nη ζωή δεν είναι πάντα άσπρο-μαύρο ); Ο πιο καλός ο μαθητής Με τη βοήθεια της if μπορούμε να επανέλθουμε στο προηγούμενο πρόγραμμα M.O. και να βρίσκουμε κάθε φορά και τον μεγαλύτερο βαθμό. Η λογική που θα ακολουθήσουμε είναι απλή: 1. Θα χρειαστούμε μία επιπλέον μεταβλητή (float), η οποία θα κρατάει τον μεγαλύτερο βαθμό, ας την ονομάσουμε best 2. H best θα πάρει μία πρώτη τιμή, τον πρώτο-πρώτο δηλαδή βαθμό που θα πληκτρολογήσουμε 3. Θα την συγκρίνουμε με τον επόμενο βαθμό. Εάν αυτός είναι μεγαλύτερος τότε η τιμή της θα αλλάξει και στη θέση της θα μπει ο βαθμός αυτός. Διαφορετικά δεν θα αλλάξει τίποτα και συνεχίζουμε με την επόμενη τιμή 4. Θα επαναλάβουμε τη διαδικασία 3 ώσπου να τελειώσουν όλοι οι βαθμοί. Η τελική τιμή που θα έχει η μεταβλητή best θα είναι ο μεγαλύτερος βαθμός. /***** υπολογισμός Μ.Ο. μεταβλητού πλήθους πραγματικών αριθμών *****/ /***** και εξαγωγή μέγιστης τιμής ****/ main( ){ float sum = 0; float x = 0; int i = 0; int amount = 0; float best = 0; printf( /nποιο είναι το πλήθος των βαθμών για τον υπολογισμό του Μ.Ο.; ); scanf( %d, &amount); /* η amount παίρνει τιμή απ το πληκτρολόγιο */ 19

20 printf( \nδώσε τον 1-ο βαθμό: ); scanf( %f, &best); /* η best παίρνει σαν πρώτη τιμή τον πρώτο βαθμό */ for(i = 0 ; i < amount-1 ; i ++){ /* η επανάληψη τώρα θα γίνει amount-1 φορές */ printf( \nδώσε τον %d-ο βαθμό:, i +2); scanf( %f, &x); sum = sum + x; if(x>best){ /* αρχή της if */ best = x; /* εάν η x > best τότε η best θα λάβει την τιμή του x */ /* τέλος της if */ /* τέλος βρόγχου επανάληψης */ printf( \nο μέσος όρος των %d βαθμών είναι: %f, amount, sum/amount); printf( \no μέγιστος βαθμός είναι ο %f, best); /* τέλος της main( ) */ H εντολή while( ) Έστω τώρα πως θέλουμε να υπολογίσουμε τα ίδια στοιχεία (Μ.Ο. και μέγιστη τιμή) αλλά για περισσότερες από μία ομάδες βαθμολογούμενων (πχ. τέσσερα διαφορετικά τμήματα). Η μία λύση είναι να γράψουμε τον παραπάνω κώδικα τέσσερις φορές. Η άλλη λύση είναι να συμπεριλάβουμε όλο τον παραπάνω κώδικα σε μία for με μετρητή έως τέσσερα. Υπάρχει όμως και απλούστερη λύση: η εντολή while( ) Η while συντάσσεται ως εξής: while(συνθήκη){ εντολές. Οι ενότητα εντολών που βρίσκονται εσωτερικά στις αγκύλες της while( ), θα εκτελείται σε διαρκείς επαναλήψεις έως ότου η συνθήκη παύσει να ισχύει. Τότε το πρόγραμμα συνεχίζει με τις εντολές που ακολουθούν μετά την δεύτερη (κλειστή) αγκύλη της while( ). Η παύση της συνθήκης προϋποθέτει ότι έχουμε φροντίσει εμείς για κάποιον μετρητή ο οποίος σε κάθε επανάληψή της θα αυξάνεται, πχ.: k = 0; while(k < 4){ /* η while θα εκτελεστεί τέσσερις φορές */ k++; /* ο μετρητής σε κάθε πέρασμα αυξάνεται */ 20

21 (προσοχή: Σε περίπτωση που δε φροντίσουμε για κάτι τέτοιο το πρόγραμμα πέφτει σε ατέρμονο βρόγχο και δεν τερματίζει ποτέ!) Εάν στη θέση του 4 βάλουμε κάποια μεταβλητή (πχ. η μεταβλητή με όνομα times, τύπου int) τότε ζητώντας την τιμή της times μπορούμε να έχουμε διαφορετικό αριθμό επαναλήψεων κάθε φορά που τρέχουμε το πρόγραμμά μας: printf( \nδώστε αριθμό επαναλήψεων ); scanf( %d, &times); k = 0; while(k<times){ /* η while θα εκτελεστεί times φορές */ k++; To πρόγραμμα Μ.Ο.- μέγιστης τιμής για μεταβλητό αριθμό επαναλήψεων /***** υπολογισμός Μ.Ο. μεταβλητού πλήθους πραγματικών αριθμών *****/ /***** και εξαγωγή μέγιστης τιμής ****/ /******* για πολλαπλά τμήματα ******/ main( ){ float sum = 0; float x = 0; int i = 0; int amount = 0; float best = 0; int times, k; printf( \nγια πόσα τμήματα θα βγει Μ.Ο. και μέγιστος βαθμός; ); scanf( %d, &times); k = 0; while(k < times){ /* αρχή της while */ printf( /nποιο είναι το πλήθος των βαθμών για τον υπολογισμό του Μ.Ο.; ); scanf( %d, &amount); printf( \nδώσε τον 1 ο βαθμό: ); scanf( %f, &best); for(i = 0 ; i < amount-1 ; i ++){ printf( \nδώσε τον %d ο βαθμό:, i +2); scanf( %f, &x); sum = sum + x; if(x>best){ 21

22 best = x; /* τέλος της if */ /* τέλος βρόγχου επανάληψης */ printf( \nγια το %d o τμήμα:, k+1); printf( \nο μέσος όρος των %d βαθμών είναι: %f, amount, sum/amount); printf( \no μέγιστος βαθμός είναι ο %f, best); k++; /* τέλος της while */ /* τέλος της main( ) */ 22

23 Ήχος και υπολογιστές Στα μέχρι τώρα προγράμματα οι τιμές που λαμβάνουν οι μεταβλητές τους είναι προσωρινές. Αρκεί η επόμενη καταχώριση σε μία μεταβλητή και η προηγούμενη τιμή της έχει χαθεί. Αυτό για ορισμένους υπολογισμούς δεν είναι πάντα ωφέλιμο. Ας φανταστούμε για παράδειγμα την περίπτωση ενός βρόγχου που θέλει να στέλνει πολλές φορές σε μία έξοδο (όχι απαραίτητα την οθόνη) μία συγκεκριμένη επαναλαμβανόμενη ακολουθία αριθμών. Ένα καλό παράδειγμα είναι ο ήχος στον υπολογιστή. Ο ήχος που παράγει ο υπολογιστής, όπως για παράδειγμα μία ημιτονοειδής κυματομορφή, είναι οι αριθμητικές τιμές μιας περιόδου της κυματομορφής οι οποίες επαναλαμβάνονται διαρκώς και στέλνονται στην έξοδο της κάρτας ήχου. Για να συμβεί κάτι τέτοιο οι τιμές αυτές πρέπει να βρίσκονται καθ όλη τη διάρκεια της αναπαραγωγής του ήχου κάπου αποθηκευμένες στη μνήμη. Το πλήθος αυτών των τιμών απαντάται συνήθως ως δύναμη του δύο, όπως για παράδειγμα 128 τιμές. Χρειαζόμαστε λοιπόν 128 διαφορετικές μεταβλητές προκειμένου να αποθηκεύονται οι τιμές μόνιμα στη μνήμη αλλά και να διαβάζονται κάθε φορά που αναπαράγεται η κυματομορφή. Το να χειριστούμε κάτι τέτοιο με απλές μεταβλητές, είναι προγραμματιστικά επίπονο. Για τον ευκολότερο λοιπόν χειρισμό πολλαπλών μεταβλητών του ίδιου τύπου (πραγματικών αριθμών ή double στη συγκεκριμένη περίπτωση), κάνουμε χρήση των πινάκων. Πίνακες (Arrays) Ο πίνακας είναι ένας χώρος στη μνήμη που καταλαμβάνεται από πολλές τιμές του ίδιου τύπου. Δηλώνεται ως εξής: τύπος _μεταβλητών_πίνακα Όνομα_Πίνακα[μέγεθος], πχ.: όπου: τύπος _μεταβλητών_πίνακα: ο τύπος δεδομένων των στοιχείων που περιλαμβάνει ο πίνακας (π.χ. int, float, char) Όνομα_Πίνακα: το όνομά του (ακριβώς όπως ονομάζουμε και μία οποιαδήποτε άλλη μεταβλητή, π.χ. Α, Χ, Array, b23 κλπ.) μέγεθος: το πλήθος των στοιχείων από το οποίο αποτελείται ο πίνακας int A[23]; ένας πίνακας με 23 θέσεις ακέραιων αριθμών και όνομα A char Names[1000]; ένας πίνακας με 1000 θέσεις χαρακτήρων και όνομα Names float WAV[128]; ένας πίνακας με 128 θέσεις πραγματικών και όνομα WAV Οι πίνακες κρατούν τα στοιχεία τους με συγκεκριμένη σειρά αρίθμησης ξεκινώντας από το 0 για το πρώτο στοιχείο, 1 για το δεύτερο, 2 για το τρίτο και καταλήγοντας μέγεθος - 1 για το τελευταίο. Έτσι όταν θέλουμε να προσπελάσουμε κάποιο στοιχείο ενός πίνακα δίνουμε τον αριθμό του στοιχείου που αντιστοιχεί σε αυτό πλάι στο όνομά του και μέσα στην παρένθεση. Παράδειγμα: A[17] = 0; το 18ο στοιχείο του πίνακα Α θα λάβει την τιμή 0 23

24 printf( %c, Names[8]); εμφανίζουμε στην οθόνη το 9ο στοιχείο του Νames WAV[0] = sin(0); το 1ο στοιχείο του WAV θα λάβει την τιμή του ημίτονου 0 ακτινίων Γέμισμα τιμών σε έναν πίνακα Έστω πως θέλουμε να γεμίσουμε τα στοιχεία ενός πίνακα με κάποιες τιμές. Η διαδικασία αυτή είναι επαναλαμβανόμενη και πραγματοποιείται με μία for: int i; int A[100]; /* ορισμός πίνακα */ /* γέμισμα πίνακα 100 θέσεων */ for(i = 0 ; i < 100 ; i++){ printf( \nδώσε τιμή για το %d στοιχείο του πίνακα, i+1); scanf( %d, A[i]); Γενικά πρέπει να έχουμε υπ όψη μας πως τα στοιχεία ενός πίνακα συμπεριφέρονται ακριβώς όπως μία άλλη μεταβλητή. Η μόνη διαφορά βρίσκεται στον τρόπο με τον οποίο ονοματίζονται: Α[i], όπου i o δείκτης του αντίστοιχου στοιχείου Οι παρακάτω λοιπόν γραμμές κώδικα είναι απολύτως σωστές: Α[i] = Α[i +1] (το στοιχείο Α[i] λαμβάνει την τιμή του επόμενου στοιχείου) Α[i] = Α[i] +1 (τα περιεχόμενα του στοιχείου Α[i] προσαυξάνονται κατά μία μονάδα) A[28] = A[0]/15 + b (καταχώρισε στο 29ο στοιχείο το αριθμητικό αποτέλεσμα της παράστασης δεξιά) Εκτύπωση τιμών ενός πίνακα Παρόμοια τα περιεχόμενα ενός πίνακα εμφανίζονται ως εξής: for(i = 0 ; i < 100 ; i++){ printf( \nτο %d στοιχείο του πίνακα είναι ίσο με: %d, i+1, A[i]); Παράδειγμα: ένας πίνακας ημιτονοειδούς κυματομορφής Ας δούμε ένα πρόγραμμα το οποίο γεμίζει έναν πίνακα 128 θέσεων με τις τιμές μίας περιόδου ημιτονοειδούς κυματομορφής και στη συνέχεια τις εμφανίζει στην οθόνη. Η συνάρτηση η οποία παράγει τιμές ημιτόνου είναι η: sin(x), όπου x τα ακτίνια του κύκλου (radians) 24

25 και η οποία βρίσκεται ενσωματωμένη στη βιβλιοθήκη μαθηματικών συναρτήσεων της C (math.h). Για να την χρησιμοποιήσουμε στο πρόγραμμά μας πρέπει λοιπόν πριν απ οτιδήποτε άλλο να την συμπεριλάβουμε στο πρόγραμμα. Αυτό γίνεται με την εντολή include, στην αρχή του κώδικά μας πριν την main( ): #include <math.h> Στη συνέχεια πρέπει να υπολογίσουμε τα 128 διαφορετικά ακτίνια απ τα οποία αποτελείται ένας κύκλος (μία δηλαδή πλήρης περίοδος της κυματομορφής). Γνωρίζουμε ότι: ένας κύκλος = 2π ακτίνια (όπου π = 3.14) άρα ο κύκλος πρέπει να διαιρεθεί σε 128 διαφορετικά τμήματα σε κάθε ένα από τα οποία θα υπολογίζεται η αντίστοιχη τιμή του ημίτονου.σε κάθε μία από τις 128 θέσεις του πίνακα θα αποθηκεύουμε και μία τέτοια τιμή: Στην πρώτη θέση του πίνακα W[0], θα καταχωρίσουμε την τιμή του sin(0). Στην δεύτερη θέση του πίνακα W[1], θα καταχωρίσουμε την τιμή του sin(2π/128). Στην τρίτη θέση του πίνακα W[2], θα καταχωρίσουμε την τιμή του sin(2π/128*2). Στην εκατοστή εικοστή όγδοη W[127], την τιμή sin(2π/128*127) Χρησιμοποιούμε λοιπόν μία επιπλέον μεταβλητή (double step), η οποία είναι το βήμα που κάθε φορά προσαυξάνεται η τρέχουσα τιμή έτσι ώστε να υπολογίζεται το επόμενο ημίτονο. Η step λοιπόν ορίζεται ως εξής: 25

26 step = two_pi/128; και για να έχουμε μία καλύτερη αριθμητική προσέγγιση της μεταβλητής two_pi δηλώνουμε: double two_pi = 8.*atan(1.); (όπου η μαθηματική συνάρτηση atan(x) υπολογίζει το τόξο εφαπτομένης του x) γιατί όντως 2π = 8 x (τόξο εφαπτομένης(1)) To πρόγραμμά μας ολοκληρωμένο έχει ως εξής: #include <math.h> main( ){ double two_pi = 8.*atan(1.); /* υπολογισμός της 2π */ double w[128]; /* δήλωση πίνακα 128 double θέσεων */ double step, x; int i; x = 0; step = two_pi / 128; /* υπολογισμός βήματος */ for(i=0; i<128; i++){ w[i] = sin(x); /* υπολόγισε το τρέχον ημίτονο */ x = x + step; /* και αύξησε την επόμενη τιμή κατά step */ for(i=0; i<128; i++){ printf( w[%d] = %f, i, w[i]);/* εκτύπωση τιμών πίνακα */ 26

Master Mind εφαρμογή στη γλώσσα προγραμματισμού C

Master Mind εφαρμογή στη γλώσσα προγραμματισμού C Master Mind εφαρμογή στη γλώσσα προγραμματισμού C Φεβρουάριος/Μάρτιος 2013 v. 0.1 Master-mind: κανόνες παιχνιδιού Στο master mind χρειάζεται να παράγονται κάθε φορά 4 τυχαία σύμβολα από ένα πλήθος 6 διαφορετικών

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

ΑΣΚΗΣΗ 2: ΔΟΜΗ ΠΡΟΓΡΑΜΜΑΤΟΣ C, ΧΕΙΡΙΣΜΟΣ ΜΕΤΑΒΛΗΤΩΝ ΚΑΙ ΣΥΝΑΡΤΗΣΕΙΣ ΕΙΣΟΔΟΥ ΚΑΙ ΕΞΟΔΟΥ

ΑΣΚΗΣΗ 2: ΔΟΜΗ ΠΡΟΓΡΑΜΜΑΤΟΣ C, ΧΕΙΡΙΣΜΟΣ ΜΕΤΑΒΛΗΤΩΝ ΚΑΙ ΣΥΝΑΡΤΗΣΕΙΣ ΕΙΣΟΔΟΥ ΚΑΙ ΕΞΟΔΟΥ ΑΣΚΗΣΗ 2: ΔΟΜΗ ΠΡΟΓΡΑΜΜΑΤΟΣ C, ΧΕΙΡΙΣΜΟΣ ΜΕΤΑΒΛΗΤΩΝ ΚΑΙ ΣΥΝΑΡΤΗΣΕΙΣ ΕΙΣΟΔΟΥ ΚΑΙ ΕΞΟΔΟΥ Σκοπός της Άσκησης Ο σκοπός αυτής της εργαστηριακής άσκησης είναι η ανάλυση των βασικών χαρακτηριστικών της Γλώσσας

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

Η-Υ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ. Εργαστήριο 1 Εισαγωγή στη C. Σοφία Μπαλτζή s.mpaltzi@di.uoa.gr

Η-Υ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ. Εργαστήριο 1 Εισαγωγή στη C. Σοφία Μπαλτζή s.mpaltzi@di.uoa.gr Η-Υ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ Εργαστήριο 1 Εισαγωγή στη C Σοφία Μπαλτζή s.mpaltzi@di.uoa.gr Διαδικαστικά Ιστοσελίδα μαθήματος: http://eclass.uoa.gr/courses/f30/ Υποχρεωτική παρακολούθηση: Παρασκευή 14:00 16:00 στην

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

Ψευδοκώδικας. November 7, 2011

Ψευδοκώδικας. November 7, 2011 Ψευδοκώδικας November 7, 2011 Οι γλώσσες τύπου ψευδοκώδικα είναι ένας τρόπος περιγραφής αλγορίθμων. Δεν υπάρχει κανένας τυπικός ορισμός της έννοιας του ψευδοκώδικα όμως είναι κοινός τόπος ότι οποιαδήποτε

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

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

Εισαγωγή στον Προγραμματισμό Εισαγωγή στον Προγραμματισμό Αριθμητική Δημήτρης Μιχαήλ Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο Ακ. Έτος 2012-2013 Δεύτερο Πρόγραμμα 1 / * Second Simple Program : add 2 numbers * / 2

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

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

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

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

ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΥΠΟΛΟΓΙΣΤΩΝ & ΥΠΟΛΟΓΙΣΤΙΚΗ ΦΥΣΙΚΗ

ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΥΠΟΛΟΓΙΣΤΩΝ & ΥΠΟΛΟΓΙΣΤΙΚΗ ΦΥΣΙΚΗ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΥΠΟΛΟΓΙΣΤΩΝ & ΥΠΟΛΟΓΙΣΤΙΚΗ ΦΥΣΙΚΗ Μέρος 3ο ΝΙΚΟΛΑΟΣ ΣΤΕΡΓΙΟΥΛΑΣ ΤΜΗΜΑ ΦΥΣΙΚΗΣ ΑΡΙΣΤΟΤΕΛΕΙΟ ΠΑΝΕΠΙΣΤΗΜΙΟ ΘΕΣΣΑΛΟΝΙΚΗΣ 1 ΕΚΤΥΠΩΣΗ ΚΕΙΜΕΝΟΥ Ένα κείμενο μπορεί να εκχωρηθεί ως τιμή μιας μεταβλητής

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

Οι εντολές ελέγχου της ροής ενός προγράμματος.

Οι εντολές ελέγχου της ροής ενός προγράμματος. Κεφάλαιο ΙΙI: Οι εντολές ελέγχου της ροής ενός προγράμματος 31 Εντολές ελέγχου της ροής Στο παρόν κεφάλαιο ασχολούμαστε με την σύνταξη των εντολών της C οι οποίες εισάγουν λογική και ελέγχουν την ροή εκτέλεσης

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

Λύσεις για τις ασκήσεις του lab5

Λύσεις για τις ασκήσεις του lab5 Εισαγωγή Λύσεις για τις ασκήσεις του lab5 Επειδή φάνηκε να υπάρχουν αρκετά προβλήματα σχετικά με τον τρόπο σκέψης για την επίλυση των προβλημάτων του lab5, θα συνοδεύσουμε τις λύσεις με αρκετές επεξηγήσεις,

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

ΓΛΩΣΣΑ ΑΛΦΑΒΗΤΟ ΤΥΠΟΙ ΔΕΔΟΜΕΝΩΝ ΣΤΑΘΕΡΕΣ ΜΕΤΑΒΛΗΤΕΣ

ΓΛΩΣΣΑ ΑΛΦΑΒΗΤΟ ΤΥΠΟΙ ΔΕΔΟΜΕΝΩΝ ΣΤΑΘΕΡΕΣ ΜΕΤΑΒΛΗΤΕΣ ΓΛΩΣΣΑ ΑΛΦΑΒΗΤΟ Κεφαλαία και μικρά γράμματα ελληνικού αλφαβήτου: Α Ω και α ω Κεφαλαία και μικρά γράμματα λατινικού αλφαβήτου: A Z και a z Αριθμητικά ψηφία: 0 9 Ειδικοί χαρακτήρες: + - * / =. ( ),! & κενός

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

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

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

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

Προγραμματισμός Ι. Χαρακτήρες. Πανεπιστήμιο Πελοποννήσου Τμήμα Πληροφορικής & Τηλεπικοινωνιών

Προγραμματισμός Ι. Χαρακτήρες. Πανεπιστήμιο Πελοποννήσου Τμήμα Πληροφορικής & Τηλεπικοινωνιών Χαρακτήρες Πανεπιστήμιο Πελοποννήσου Τμήμα Πληροφορικής & Τηλεπικοινωνιών Νικόλαος Προγραμματισμός Δ. Τσελίκας Ι Χαρακτήρες - Εισαγωγή Έως τώρα έχουμε κατά κύριο λόγο χρησιμοποιήσει τους αριθμητικούς τύπους

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

Ανάπτυξη και Σχεδίαση Λογισμικού

Ανάπτυξη και Σχεδίαση Λογισμικού Ανάπτυξη και Σχεδίαση Λογισμικού Η γλώσσα προγραμματισμού C Γεώργιος Δημητρίου Βασικά Στοιχεία Το αλφάβητο της C Οι βασικοί τύποι της C Δηλώσεις μεταβλητών Είσοδος/Έξοδος Βασικές εντολές της C Αλφάβητο

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

Η πρώτη παράμετρος είναι ένα αλφαριθμητικό μορφοποίησης

Η πρώτη παράμετρος είναι ένα αλφαριθμητικό μορφοποίησης Η συνάρτηση printf() Η συνάρτηση printf() χρησιμοποιείται για την εμφάνιση δεδομένων στο αρχείο εξόδου stdout (standard output stream), το οποίο εξ ορισμού συνδέεται με την οθόνη Η συνάρτηση printf() δέχεται

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

ΠΑΝΕΠΙΣΤΗΜΙΟ ΘΕΣΣΑΛΙΑΣ ΣΧΟΛΗ ΘΕΤΙΚΩΝ ΕΠΙΣΤΗΜΩΝ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ

ΠΑΝΕΠΙΣΤΗΜΙΟ ΘΕΣΣΑΛΙΑΣ ΣΧΟΛΗ ΘΕΤΙΚΩΝ ΕΠΙΣΤΗΜΩΝ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ ΠΑΝΕΠΙΣΤΗΜΙΟ ΘΕΣΣΑΛΙΑΣ ΣΧΟΛΗ ΘΕΤΙΚΩΝ ΕΠΙΣΤΗΜΩΝ ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ ΑΝΑΠΤΥΞΗ ΚΑΙ ΣΧΕΔΙΑΣΗ ΛΟΓΙΣΜΙΚΟΥ Η γλώσσα προγραμματισμού C ΕΡΓΑΣΤΗΡΙΟ 2: Εκφράσεις, πίνακες και βρόχοι 14 Απριλίου 2016 Το σημερινό εργαστήριο

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

Σκοπός. Αλγεβρικοί και Λογικοί Υπολογισμοί στη PASCAL

Σκοπός. Αλγεβρικοί και Λογικοί Υπολογισμοί στη PASCAL Αλγεβρικοί και Λογικοί Υπολογισμοί στη PASCAL Δυνατότητα ανάπτυξης, μεταγλώττισης και εκτέλεσης προγραμμάτων στη PASCAL. Κατανόηση της σύνταξης των προτάσεων της PASCAL. Κατανόηση της εντολής εξόδου για

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

2 ΟΥ και 7 ΟΥ ΚΕΦΑΛΑΙΟΥ

2 ΟΥ και 7 ΟΥ ΚΕΦΑΛΑΙΟΥ ΑΝΑΠΤΥΞΗ ΕΦΑΡΜΟΓΩΝ ΣΕ ΠΡΟΓΡΑΜΜΑΤΙΣΤΙΚΟ ΠΕΡΙΒΑΛΛΟΝ ΕΠΙΜΕΛΕΙΑ: ΜΑΡΙΑ Σ. ΖΙΩΓΑ ΚΑΘΗΓΗΤΡΙΑ ΠΛΗΡΟΦΟΡΙΚΗΣ ΘΕΩΡΙΑ 2 ΟΥ και 7 ΟΥ ΚΕΦΑΛΑΙΟΥ ΒΑΣΙΚΕΣ ΕΝΝΟΙΕΣ ΑΛΓΟΡΙΘΜΩΝ και ΔΟΜΗ ΑΚΟΛΟΥΘΙΑΣ 2.1 Να δοθεί ο ορισμός

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

Προγραμματισμός με FORTRAN Συνοπτικός Οδηγός Α. Σπυρόπουλος Α. Μπουντουβής

Προγραμματισμός με FORTRAN Συνοπτικός Οδηγός Α. Σπυρόπουλος Α. Μπουντουβής ΕΘΝΙΚΟ ΜΕΤΣΟΒΙΟ ΠΟΛΥΤΕΧΝΕΙΟ ΣΧΟΛΗ ΧΗΜΙΚΩΝ ΜΗΧΑΝΙΚΩΝ ΥΠΟΛΟΓΙΣΤΙΚΟ ΚΕΝΤΡΟ Προγραμματισμός με FORTRAN Συνοπτικός Οδηγός Α Σπυρόπουλος Α Μπουντουβής Αθήνα, 2015 v13_061015 Στον οδηγό αυτό θα χρησιμοποιηθούν

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

Σκοπός. Εργαστήριο 6 Εντολές Επανάληψης

Σκοπός. Εργαστήριο 6 Εντολές Επανάληψης Εργαστήριο 6 Εντολές Επανάληψης Η δομή Επιλογής στη PASCAL H δομή Επανάληψης στη PASCAL. Ρεύμα Εισόδου / Εξόδου.. Ρεύμα Εισόδου / Εξόδου. To πρόγραμμα γραφικών gnuplot. Γραφικά στη PASCAL. Σκοπός 6.1 ΕΠΙΔΙΩΞΗ

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

ΥΠΟΛΟΓΙΣΤΕΣ ΙΙ. Τύποι δεδομένων ΤΥΠΟΙ ΔΕΔΟΜΕΝΩΝ ΠΡΑΞΕΙΣ ΜΕΤΑΒΛΗΤΕΣ. Ακέραιοι αριθμοί (int) Πράξεις μεταξύ ακεραίων αριθμών

ΥΠΟΛΟΓΙΣΤΕΣ ΙΙ. Τύποι δεδομένων ΤΥΠΟΙ ΔΕΔΟΜΕΝΩΝ ΠΡΑΞΕΙΣ ΜΕΤΑΒΛΗΤΕΣ. Ακέραιοι αριθμοί (int) Πράξεις μεταξύ ακεραίων αριθμών ΥΠΟΛΟΓΙΣΤΕΣ ΙΙ ΤΥΠΟΙ ΔΕΔΟΜΕΝΩΝ ΠΡΑΞΕΙΣ ΜΕΤΑΒΛΗΤΕΣ 1 Τύποι δεδομένων Η γλώσσα προγραμματισμού C++ υποστηρίζει τους παρακάτω τύπους δεδομένων: 1) Ακέραιοι αριθμοί (int). 2) Πραγματικοί αριθμοί διπλής ακρίβειας

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

ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ Η/Υ Ακαδημαϊκό έτος 2001-2002 ΤΕΤΡΑΔΙΟ ΕΡΓΑΣΤΗΡΙΟΥ #4

ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ Η/Υ Ακαδημαϊκό έτος 2001-2002 ΤΕΤΡΑΔΙΟ ΕΡΓΑΣΤΗΡΙΟΥ #4 ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ Η/Υ Ακαδημαϊκό έτος 2001-2002 ΤΕΤΡΑΔΙΟ ΕΡΓΑΣΤΗΡΙΟΥ #4 «Προγραμματισμός Η/Υ» - Τετράδιο Εργαστηρίου #4 2 Γενικά Στο Τετράδιο #4 του Εργαστηρίου θα αναφερθούμε σε θέματα διαχείρισης πινάκων

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

Εισαγωγή στην C. Μορφή Προγράµµατος σε γλώσσα C

Εισαγωγή στην C. Μορφή Προγράµµατος σε γλώσσα C Εισαγωγή στην C Μορφή Προγράµµατος σε γλώσσα C Τµήµα Α Με την εντολή include συµπεριλαµβάνω στο πρόγραµµα τα πρότυπα των συναρτήσεων εισόδου/εξόδου της C.Το αρχείο κεφαλίδας stdio.h είναι ένας κατάλογος

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

ΥΠΟΛΟΓΙΣΤΕΣ ΙI. Άδειες Χρήσης. Τύποι δεδομένων, μεταβλητές, πράξεις. Διδάσκοντες: Αν. Καθ. Δ. Παπαγεωργίου, Αν. Καθ. Ε. Λοιδωρίκης

ΥΠΟΛΟΓΙΣΤΕΣ ΙI. Άδειες Χρήσης. Τύποι δεδομένων, μεταβλητές, πράξεις. Διδάσκοντες: Αν. Καθ. Δ. Παπαγεωργίου, Αν. Καθ. Ε. Λοιδωρίκης ΠΑΝΕΠΙΣΤΗΜΙΟ ΙΩΑΝΝΙΝΩΝ ΑΝΟΙΚΤΑ ΑΚΑΔΗΜΑΪΚΑ ΜΑΘΗΜΑΤΑ Άδειες Χρήσης ΥΠΟΛΟΓΙΣΤΕΣ ΙI Τύποι δεδομένων, μεταβλητές, πράξεις Διδάσκοντες: Αν. Καθ. Δ. Παπαγεωργίου, Αν. Καθ. Ε. Λοιδωρίκης Το παρόν εκπαιδευτικό

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

Ενότητα 2. Ζωγραφίζοντας με το ΒΥΟΒ

Ενότητα 2. Ζωγραφίζοντας με το ΒΥΟΒ Ενότητα 2 : Ζωγραφίζοντας με το ΒΥΟΒ -1- Ενότητα 2. Ζωγραφίζοντας με το ΒΥΟΒ Κεφάλαιο 1: Κίνηση και γεωμετρικά σχήματα α. Θέση και προσανατολισμός της μορφής Η θέση της κάθε μορφής στο σκηνικό προσδιορίζεται

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

ΕΙΣΑΓΩΓΗ ΣΤΟ ΔΟΜΗΜΕΝΟ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟ

ΕΙΣΑΓΩΓΗ ΣΤΟ ΔΟΜΗΜΕΝΟ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟ ΕΙΣΑΓΩΓΗ ΣΤΟ ΔΟΜΗΜΕΝΟ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟ Τρίτη Διάλεξη Εντολές Επιλογής και Επανάληψης Εντολές επιλογής Εντολή if Η πιο απλή μορφή της if συντάσσεται ως εξής: if ( συνθήκη ) Οι εντολές μέσα στα άγκιστρα αποτελούν

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

Παρακάτω δίνεται o σκελετός προγράμματος σε γλώσσα C. Σχολιάστε κάθε γραμμή του κώδικα.

Παρακάτω δίνεται o σκελετός προγράμματος σε γλώσσα C. Σχολιάστε κάθε γραμμή του κώδικα. Ερωτήσεις προόδου C Παρακάτω δίνεται o σκελετός προγράμματος σε γλώσσα C. Σχολιάστε κάθε γραμμή του κώδικα. #include // δίνει οδηγία στον compiler να // συμπεριλάβει την βιβλιοθήκη stdio int

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

ΔΟΜΗΜΕΝΟΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ

ΔΟΜΗΜΕΝΟΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ 23 ΔΟΜΗΜΕΝΟΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ Μάθημα 2ο Τμήμα Διοίκησης Επιχειρήσεων α εξάμηνο Β. Φερεντίνος I/O 24 Βασική βιβλιοθήκη συναρτήσεων εισόδου/εξόδου #include Η συνάρτηση εξόδου printf printf("συμβολοσειρά

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

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

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

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

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

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

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

2ο ΓΕΛ ΑΓ.ΔΗΜΗΤΡΙΟΥ ΑΕΠΠ ΘΕΟΔΟΣΙΟΥ ΔΙΟΝ ΠΡΟΣΟΧΗ ΣΤΑ ΠΑΡΑΚΑΤΩ

2ο ΓΕΛ ΑΓ.ΔΗΜΗΤΡΙΟΥ ΑΕΠΠ ΘΕΟΔΟΣΙΟΥ ΔΙΟΝ ΠΡΟΣΟΧΗ ΣΤΑ ΠΑΡΑΚΑΤΩ ΠΡΟΣΟΧΗ ΣΤΑ ΠΑΡΑΚΑΤΩ ΣΤΑΘΕΡΕΣ είναι τα μεγέθη που δεν μεταβάλλονται κατά την εκτέλεση ενός αλγόριθμου. Εκτός από τις αριθμητικές σταθερές (7, 4, 3.5, 100 κλπ), τις λογικές σταθερές (αληθής και ψευδής)

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

ΕΙΔΗ,ΤΕΧΝΙΚΕΣ ΚΑΙ ΠΕΡΙΒΑΛΛΟΝΤΑ ΠΡΟΓΡΑΜΜΑΤΙ- ΣΜΟΥ

ΕΙΔΗ,ΤΕΧΝΙΚΕΣ ΚΑΙ ΠΕΡΙΒΑΛΛΟΝΤΑ ΠΡΟΓΡΑΜΜΑΤΙ- ΣΜΟΥ Κεφάλαιο 7 ΕΙΔΗ,ΤΕΧΝΙΚΕΣ ΚΑΙ ΠΕΡΙΒΑΛΛΟΝΤΑ ΠΡΟΓΡΑΜΜΑΤΙ- ΣΜΟΥ Ερωτήσεις 1. Να αναφέρετε διαφορές μεταξύ γλωσσών μηχανής και γλωσσών χαμηλού επιπέδου. Οι γλώσσες μηχανής κωδικοποιούν τις εντολές τους με ομάδες

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

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

ΠΛΗΡΟΦΟΡΙΚΗ Ι JAVA Τμήμα θεωρίας με Α.Μ. σε 3, 7, 8 & 9 25/10/07 ΠΛΗΡΟΦΟΡΙΚΗ Ι JAVA Τμήμα θεωρίας με Α.Μ. σε 3, 7, 8 & 9 25/10/07 Αριθμητική στο δυαδικό σύστημα (γενικά) Συμπληρωματικά για δυαδικό σύστημα Η πρόσθεση στηρίζεται στους κανόνες: 0 + 0 = 0, 0 + 1 = 1, 1

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

Διάλεξη 3η: Τύποι Μεταβλητών, Τελεστές, Είσοδος/Έξοδος

Διάλεξη 3η: Τύποι Μεταβλητών, Τελεστές, Είσοδος/Έξοδος Διάλεξη 3η: Τύποι Μεταβλητών, Τελεστές, Είσοδος/Έξοδος Τμήμα Επιστήμης Υπολογιστών, Πανεπιστήμιο Κρήτης Εισαγωγή στην Επιστήμη Υπολογιστών Βασίζεται σε διαφάνειες του Κ Παναγιωτάκη Πρατικάκης (CSD) Μεταβλητές,

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

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

Εισαγωγή στον Προγραμματισμό Εισαγωγή στον Προγραμματισμό Συναρτήσεις Δημήτρης Μιχαήλ Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο Ακ. Έτος 2012-2013 Συναρτήσεις Ως τώρα γράφαμε όλα τα προγράμματα μας μέσα στην main..1

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

ΕΙΣΑΓΩΓΗ ΣΤΟ ΔΟΜΗΜΕΝΟ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟ

ΕΙΣΑΓΩΓΗ ΣΤΟ ΔΟΜΗΜΕΝΟ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟ ΕΙΣΑΓΩΓΗ ΣΤΟ ΔΟΜΗΜΕΝΟ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟ Δεύτερη Διάλεξη Βασικά στοιχεία της γλώσσας προγραμματισμού C Μία γλώσσα προγραμματισμού όπως και μια ανθρώπινη γλώσσα μπορεί να μελετηθεί ως προς το αλφάβητό της,

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

Εξοικείωση με το πρόγραμμα DEV C++ Επικοινωνία Χρήστη - Υπολογιστή

Εξοικείωση με το πρόγραμμα DEV C++ Επικοινωνία Χρήστη - Υπολογιστή Εξοικείωση με το πρόγραμμα DEV C++ Επικοινωνία Χρήστη - Υπολογιστή Δημιουργία Νέου αρχείου Από το μενού προγραμμάτων ανοίγετε το DEV C++ Επιλέγετε File-> New-> Source File (συντόμευση πληκτρολογίου Ctrl+N)

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

5 ΕΙΣΑΓΩΓΗ ΣΤΗ ΘΕΩΡΙΑ ΑΛΓΟΡΙΘΜΩΝ

5 ΕΙΣΑΓΩΓΗ ΣΤΗ ΘΕΩΡΙΑ ΑΛΓΟΡΙΘΜΩΝ 5 ΕΙΣΑΓΩΓΗ ΣΤΗ ΘΕΩΡΙΑ ΑΛΓΟΡΙΘΜΩΝ 5.1 Εισαγωγή στους αλγορίθμους 5.1.1 Εισαγωγή και ορισμοί Αλγόριθμος (algorithm) είναι ένα πεπερασμένο σύνολο εντολών οι οποίες εκτελούν κάποιο ιδιαίτερο έργο. Κάθε αλγόριθμος

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

ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΥΠΟΛΟΓΙΣΤΩΝ & ΥΠΟΛΟΓΙΣΤΙΚΗ ΦΥΣΙΚΗ

ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΥΠΟΛΟΓΙΣΤΩΝ & ΥΠΟΛΟΓΙΣΤΙΚΗ ΦΥΣΙΚΗ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΥΠΟΛΟΓΙΣΤΩΝ & ΥΠΟΛΟΓΙΣΤΙΚΗ ΦΥΣΙΚΗ Μέρος 2ο ΝΙΚΟΛΑΟΣ ΣΤΕΡΓΙΟΥΛΑΣ ΤΜΗΜΑ ΦΥΣΙΚΗΣ ΑΡΙΣΤΟΤΕΛΕΙΟ ΠΑΝΕΠΙΣΤΗΜΙΟ ΘΕΣΣΑΛΟΝΙΚΗΣ 1 ΣΦΑΛΜΑΤΑ ΜΕΤΑΓΛΩΤΤΙΣΗΣ Η γλώσσα C κάνει αυστηρή διάκριση μεταξύ πεζών

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

Χρησιμοποιείται για να αποφασίσει το πρόγραμμα αν θα κάνει κάτι σε ένα σημείο της εκτέλεσής του, εξετάζοντας αν ισχύει ή όχι μια συνθήκη.

Χρησιμοποιείται για να αποφασίσει το πρόγραμμα αν θα κάνει κάτι σε ένα σημείο της εκτέλεσής του, εξετάζοντας αν ισχύει ή όχι μια συνθήκη. Εργαστήριο 4: 4.1 Η Δομή Ελέγχου if Χρησιμοποιείται για να αποφασίσει το πρόγραμμα αν θα κάνει κάτι σε ένα σημείο της εκτέλεσής του, εξετάζοντας αν ισχύει ή όχι μια συνθήκη. Γενική Μορφή: Παρατηρήσεις:

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

Η γλώσσα προγραμματισμού C

Η γλώσσα προγραμματισμού C Η γλώσσα προγραμματισμού C Συναρτήσεις εισόδου/εξόδου, τελεστές Η συνάρτηση scanf() είσοδος δεδομένων Διαβάζει από το πληκτρολόγιο (stdin) μορφοποιημένες τιμές μεταβλητών. scanf (ΣΕΙΡΑ_ΕΛΕΓΧΟΥ, δείκτης_μεταβλητής-1,

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

Προγραμματισμός Ι. Δυναμική Διαχείριση Μνήμης. Δημήτρης Μιχαήλ. Ακ. Έτος 2011-2012. Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο

Προγραμματισμός Ι. Δυναμική Διαχείριση Μνήμης. Δημήτρης Μιχαήλ. Ακ. Έτος 2011-2012. Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο Προγραμματισμός Ι Δυναμική Διαχείριση Μνήμης Δημήτρης Μιχαήλ Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο Ακ. Έτος 2011-2012 Ανάγκη για Δυναμική Μνήμη Στατική Μνήμη Μέχρι τώρα χρησιμοποιούσαμε

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

H ΓΛΩΣΣΑ C. Μάθηµα 1: Το Πρώτο µας Πρόγραµµα σε C. ηµήτρης Ψούνης

H ΓΛΩΣΣΑ C. Μάθηµα 1: Το Πρώτο µας Πρόγραµµα σε C. ηµήτρης Ψούνης H ΓΛΩΣΣΑ C Μάθηµα 1: Το Πρώτο µας Πρόγραµµα σε C ηµήτρης Ψούνης 2 Περιεχόµενα Μαθήµατος Α. Θεωρία 1. Κύκλος Ανάπτυξης Προγράµµατος 1. Συγγραφή και Μεταγλώττιση ενός προγράµµατος 2. Εκτέλεση του προγράµµατος

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

ΚΕΦΑΛΑΙΟ 8 Η ΓΛΩΣΣΑ PASCAL

ΚΕΦΑΛΑΙΟ 8 Η ΓΛΩΣΣΑ PASCAL 8.1. Εισαγωγή ΚΕΦΑΛΑΙΟ 8 Η ΓΛΩΣΣΑ PACAL Πως προέκυψε η γλώσσα προγραμματισμού Pascal και ποια είναι τα γενικά της χαρακτηριστικά; Σχεδιάστηκε από τον Ελβετό επιστήμονα της Πληροφορικής Nicklaus Wirth to

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

Σκοπός. Εργαστήριο 6 Εντολές Επανάληψης Τα Εργαστηριακά Προγράμματα. Η δομή Επιλογής στη PASCAL. H δομή Επανάληψης στη PASCAL. Η εντολή επανάληψης for

Σκοπός. Εργαστήριο 6 Εντολές Επανάληψης Τα Εργαστηριακά Προγράμματα. Η δομή Επιλογής στη PASCAL. H δομή Επανάληψης στη PASCAL. Η εντολή επανάληψης for Εργαστήριο 6 Εντολές Επανάληψης Τα Εργαστηριακά Προγράμματα Η δομή Επιλογής στη PASCAL H δομή Επανάληψης στη PASCAL Η εντολή επανάληψης for Σκοπός Η εντολή επανάληψης while. 1 ΕΡΓΑΣΤΗΡΙΟ 6 Εισαγωγή στο

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

ΚΕΦΑΛΑΙΟ 10 ΥΠΟΠΡΟΓΡΑΜΜΑΤΑ

ΚΕΦΑΛΑΙΟ 10 ΥΠΟΠΡΟΓΡΑΜΜΑΤΑ ΚΕΦΑΛΑΙΟ 10 Όπως είδαμε και σε προηγούμενο κεφάλαιο μια από τις βασικότερες τεχνικές στον Δομημένο Προγραμματισμό είναι ο Τμηματικός Προγραμματισμός. Τμηματικός προγραμματισμός ονομάζεται η τεχνική σχεδίασης

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

Κεφάλαιο ΙV: Δείκτες και πίνακες. 4.1 Δείκτες.

Κεφάλαιο ΙV: Δείκτες και πίνακες. 4.1 Δείκτες. Κεφάλαιο ΙV: Δείκτες και πίνακες. 4.1 Δείκτες. Η C, όπως έχουμε αναφέρει, είναι μια γλώσσα προγραμματισμού υψηλού επιπέδου η οποία αναπτύχθηκε για πρώτη φορά το 1972 από τον Dennis Ritchie στα AT&T Bell

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

Εισαγωγή στον προγραμματισμό. Τμήμα Πληροφορικής & Επικοινωνιών ΤΕΙ Σερρών Εργαστήριο 2

Εισαγωγή στον προγραμματισμό. Τμήμα Πληροφορικής & Επικοινωνιών ΤΕΙ Σερρών Εργαστήριο 2 Εισαγωγή στον προγραμματισμό Τμήμα Πληροφορικής & Επικοινωνιών ΤΕΙ Σερρών Εργαστήριο 2 Δομή Προγράμματος Όλα τα προγράμματα που γράψαμε έχουν λίγο πολύ την ακόλουθη μορφή: Κάποιος κώδικας εδώ main( ) {

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

ΗΥ101: Εισαγωγή στην Πληροφορική

ΗΥ101: Εισαγωγή στην Πληροφορική Δρ. Χρήστος Ηλιούδης Τι είναι η ; Η διαδικασία του προγραμματισμού είναι μία πολύπλοκη διαδικασία που συχνά οδηγεί σε λάθη (πραγματοποιείται από ανθρώπους!!!). Τα προγραμματιστικά λάθη λέγονται bugs και

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

Βαθμός Σχόλια. lab5 PASS PASS PASS PASS PASS. Οριακά PASS - Καλή δουλειά

Βαθμός Σχόλια. lab5 PASS PASS PASS PASS PASS. Οριακά PASS - Καλή δουλειά Α. Μ. Βαθμός Σχόλια 1183 1194 1238 1239 1240 1241 - Καλή δουλειά 1242 1243 1244 1245 - Κακή χρήση συναρτήσεων. Κάνεις τον ίδιο έλεγχο και εντός και εκτός της συνάρτησης. Θα έπρεπε να έχεις βρεί ένα τρόπο

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

Προγραμματισμός Η/Υ 1 (Εργαστήριο)

Προγραμματισμός Η/Υ 1 (Εργαστήριο) Προγραμματισμός Η/Υ 1 (Εργαστήριο) Ενότητα 2: Δομή ενός προγράμματος C Καθηγήτρια Εφαρμογών: Τσαγκαλίδου Ροδή Τμήμα: Ηλεκτρολόγων Μηχανικών Τ.Ε. Άδειες Χρήσης Το παρόν εκπαιδευτικό υλικό υπόκειται σε άδειες

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

Οικονόμου Βαγγέλησ Διάλεξη Νο 2. Δομημένοσ Προγραμματιςμόσ - Διάλεξη 2

Οικονόμου Βαγγέλησ Διάλεξη Νο 2. Δομημένοσ Προγραμματιςμόσ - Διάλεξη 2 Οικονόμου Βαγγέλησ Διάλεξη Νο 2 Δομημένοσ Προγραμματιςμόσ - Διάλεξη 2 1 Η έννοια τησ μεταβλητήσ έδωςε λύςη ςτο πρόβλημα τησ αναφοράσ ςτην κύρια μνήμη του υπολογιςτή. Οι γλώςςεσ προγραμματιςμού υποςτηρίζουν

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

Δομή Προγράμματος C++, Χειρισμός Μεταβλητών και Συναρτήσεις Εισόδου - Εξόδου

Δομή Προγράμματος C++, Χειρισμός Μεταβλητών και Συναρτήσεις Εισόδου - Εξόδου Εργαστήριο 2: Δομή Προγράμματος C++, Χειρισμός Μεταβλητών και Συναρτήσεις Εισόδου - Εξόδου Ο σκοπός αυτής της εργαστηριακής άσκησης είναι η ανάλυση των βασικών χαρακτηριστικών της Γλώσσας Προγραμματισμού

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

Εισαγωγή στο περιβάλλον Code::Blocks

Εισαγωγή στο περιβάλλον Code::Blocks Εισαγωγή στο περιβάλλον Code::Blocks Στο παρόν εγχειρίδιο παρουσιάζεται η διαδικασία ανάπτυξης, μεταγλώττισης και εκτέλεσης ενός προγράμματος C στο περιβάλλον του Code::Blocks. Η διαδικασία αυτή παρουσιάζεται

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

Κεφάλαιο 7 ο Βασικές Έννοιες Προγραμματισμού (σελ )

Κεφάλαιο 7 ο Βασικές Έννοιες Προγραμματισμού (σελ ) Κεφάλαιο 7 ο Βασικές Έννοιες Προγραμματισμού (σελ. 147 159) Για τις γλώσσες προγραμματισμού πρέπει να έχουμε υπόψη ότι: Κάθε γλώσσα προγραμματισμού σχεδιάζεται για συγκεκριμένο σκοπό, δίνοντας ιδιαίτερη

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

Προγραμματισμός Υπολογιστών & Υπολογιστική Φυσική

Προγραμματισμός Υπολογιστών & Υπολογιστική Φυσική ΑΡΙΣΤΟΤΕΛΕΙΟ ΠΑΝΕΠΙΣΤΗΜΙΟ ΘΕΣΣΑΛΟΝΙΚΗΣ ΑΝΟΙΚΤΑ ΑΚΑΔΗΜΑΪΚΑ ΜΑΘΗΜΑΤΑ Προγραμματισμός Υπολογιστών & Υπολογιστική Φυσική Ενότητα 2: Μεταβλητές και Σταθερές Νικόλαος Στεργιούλας Τμήμα Φυσικής Άδειες Χρήσης

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

ΕΠΛ 003: ΕΙΣΑΓΩΓΗ ΣΤΗΝ ΕΠΙΣΤΗΜΗ ΤΗΣ ΠΛΗΡΟΦΟΡΙΚΗΣ

ΕΠΛ 003: ΕΙΣΑΓΩΓΗ ΣΤΗΝ ΕΠΙΣΤΗΜΗ ΤΗΣ ΠΛΗΡΟΦΟΡΙΚΗΣ ΕΠΛ 003: ΕΙΣΑΓΩΓΗ ΣΤΗΝ ΕΠΙΣΤΗΜΗ ΤΗΣ ΠΛΗΡΟΦΟΡΙΚΗΣ Δρ. Κόννης Γιώργος Πανεπιστήμιο Κύπρου - Τμήμα Πληροφορικής Προγραμματισμός Στόχοι 1 Να περιγράψουμε τις έννοιες του Υπολογιστικού Προβλήματος και του Προγράμματος/Αλγορίθμου

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

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

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

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

Η γλώσσα προγραμματισμού C

Η γλώσσα προγραμματισμού C Η γλώσσα προγραμματισμού C Εισαγωγή στη C Λίγα λόγια για την C Γλώσσα προγραμματισμού υψηλού επιπέδου. Σχεδιάστηκε και υλοποιήθηκε από τον Dennis Richie στις αρχές της δεκαετίας του 1970 (Bell Labs). Η

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

ΑΕΠΠ Ερωτήσεις θεωρίας

ΑΕΠΠ Ερωτήσεις θεωρίας ΑΕΠΠ Ερωτήσεις θεωρίας Κεφάλαιο 1 1. Τα δεδομένα μπορούν να παρέχουν πληροφορίες όταν υποβάλλονται σε 2. Το πρόβλημα μεγιστοποίησης των κερδών μιας επιχείρησης είναι πρόβλημα 3. Για την επίλυση ενός προβλήματος

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

Η βασική συνάρτηση προγράμματος main()

Η βασική συνάρτηση προγράμματος main() Η βασική συνάρτηση προγράμματος main() HEADER FILES main(){ ΔΗΛΩΣΕΙΣ ΜΕΤΑΒΛΗΤΩΝ ΕΝΤΟΛΕΣ (σειριακές, επιλογής ή επανάληψης) ΕΠΙΣΤΡΕΦΟΜΕΝΟΣ ΤΥΠΟΣ (return 0;) Συναρτήσεις Η συνάρτηση είναι ένα υποπρόγραμμα

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

Προγραμματισμός Ι. Δείκτες. Δημήτρης Μιχαήλ. Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο

Προγραμματισμός Ι. Δείκτες. Δημήτρης Μιχαήλ. Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο Προγραμματισμός Ι Δείκτες Δημήτρης Μιχαήλ Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο Τι είναι ο δείκτης Ένας δείκτης είναι μια μεταβλητή που περιέχει μια διεύθυνση μνήμης. Θυμηθείτε πως

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

Γλώσσα Προγραμματισμού C

Γλώσσα Προγραμματισμού C Προγραμματισμός HY: Γλώσσα Προγραμματισμού C Δρ. Ηλίας Κ. Σάββας, Αναπληρωτής Καθηγητής, Τμήμα Μηχανικών Πληροφορικής Τ.Ε., T.E.I. Θεσσαλίας Email: savvas@teilar.gr URL: http://teilar.academia.edu/iliassavvas

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

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

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

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

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

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

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

Μαλούτα Θεανώ Σελίδα 1

Μαλούτα Θεανώ Σελίδα 1 ΕΙΣΑΓΩΓΗ ΣΤΙΣ ΑΡΧΕΣ ΤΗΣ ΕΠΙΣΤΗΜΗΣ ΤΩΝ ΥΠΟΛΟΓΙΣΤΩΝ Α. ΕΡΩΤΗΣΕΙΣ ΘΕΩΡΙΑΣ ΦΥΛΛΑΔΙΟ 6 ο ( Ενότητες 2.3 ) 1.Τι είναι πρόγραμμα; 2. Ποια είναι τα πλεονεκτήματα των γλωσσών υψηλού επιπέδου σε σχέση με τις γλώσσες

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

1. Πότε χρησιμοποιούμε την δομή επανάληψης; Ποιες είναι οι διάφορες εντολές (μορφές) της;

1. Πότε χρησιμοποιούμε την δομή επανάληψης; Ποιες είναι οι διάφορες εντολές (μορφές) της; 1. Πότε χρησιμοποιούμε την δομή επανάληψης; Ποιες είναι οι διάφορες (μορφές) της; Η δομή επανάληψης χρησιμοποιείται όταν μια σειρά εντολών πρέπει να εκτελεστεί σε ένα σύνολο περιπτώσεων, που έχουν κάτι

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

Συμβολική γλώσσα Εκπαιδευτικού Υπολογιστή - Λογισμικό Υπολογιστών

Συμβολική γλώσσα Εκπαιδευτικού Υπολογιστή - Λογισμικό Υπολογιστών Συμβολική γλώσσα Εκπαιδευτικού Υπολογιστή - Λογισμικό Υπολογιστών Πρόγραμμα σε γλώσσα μηχανής του ΕΚΥ Θέση μνήμης Περιεχόμενα μνήμης Εντολή (assembly) 0 0001 000000000011 lda 3 1 0011 000000000100 ada

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

scanf() scanf() stdin scanf() printf() int float double %lf float

scanf() scanf() stdin scanf() printf() int float double %lf float Εισαγωγή Στον Προγραµµατισµό «C» Είσοδος Δεδοµένων Πανεπιστήµιο Πελοποννήσου Τµήµα Πληροφορικής & Τηλεπικοινωνιών Νικόλαος Δ. Τσελίκας Νικόλαος Προγραµµατισµός Δ. Τσελίκας Ι Η συνάρτηση scanf() Η συνάρτηση

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

Pascal, απλοί τύποι, τελεστές και εκφράσεις

Pascal, απλοί τύποι, τελεστές και εκφράσεις Pascal, απλοί τύποι, τελεστές και εκφράσεις 15 Νοεμβρίου 2011 1 Γενικά Στην standard Pascal ορίζονται τέσσερις βασικοί τύποι μεταβλητών: integer: Παριστάνει ακέραιους αριθμούς από το -32768 μέχρι και το

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

ΦΥΣ-151. Ηλεκτρονικοί Υπολογιστές Ι (FORTRAN 77) (Άνοιξη 2004)

ΦΥΣ-151. Ηλεκτρονικοί Υπολογιστές Ι (FORTRAN 77) (Άνοιξη 2004) 1 ΦΥΣ-151. Ηλεκτρονικοί Υπολογιστές Ι (FORTRAN 77) (Άνοιξη 2004) ιάλεξη 1 1.1 ΕΙΣΑΓΩΓΗ ΣΤΗ FORTRAN 77 Ένα πρόγραµµα σε οποιαδήποτε γλώσσα προγραµµατισµού δεν τίποτα άλλο από µια σειρά εντολών που πρέπει

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

Πίνακες: μια σύντομη εισαγωγή. Πίνακες χαρακτήρων: τα "Αλφαριθμητικά"

Πίνακες: μια σύντομη εισαγωγή. Πίνακες χαρακτήρων: τα Αλφαριθμητικά Πίνακες: μια σύντομη εισαγωγή Πίνακες χαρακτήρων: τα "Αλφαριθμητικά" Πίνακες(Arrays): έννοιες και ορισμοί Ορισμός: Πίνακας (array) = σύνολο μεταβλητών του ιδίου τύπου (int, float, char,...) με ένα κοινό

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

4. Επιλογή και Επανάληψη

4. Επιλογή και Επανάληψη Σελίδα 53 4. Επιλογή και Επανάληψη 4.1 Η Εντολή Επιλογής if.. then Η εντολή If.. Then.. χρησιμοποιείται για την λήψη λογικών αποφάσεων σε ένα πρόγραμμα. Η εντολή αυτή έχει διάφορες μορφές σύνταξης οι οποίες

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

Η γλώσσα προγραμματισμού C

Η γλώσσα προγραμματισμού C Η γλώσσα προγραμματισμού C Οι δείκτες στη C Η έννοια του δείκτη Την έννοια του δείκτη τη συναντήσαμε σε προηγούμενα μαθήματα. Η συνάρτηση scanf(), καταχωρίζει τιμές σε μεταβλητές χρησιμοποιώντας τον τελεστή

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

1. Τι ονομάζουμε αλγόριθμο; Δώστε παράδειγμα.

1. Τι ονομάζουμε αλγόριθμο; Δώστε παράδειγμα. 1. Τι ονομάζουμε αλγόριθμο; Δώστε παράδειγμα. ΑΠΑΝΤΗΣΗ Ορισμός: Αλγόριθμος είναι μια πεπερασμένη σειρά ενεργειών, αυστηρά καθορισμένων και εκτελέσιμων σε πεπερασμένο χρόνο, που στοχεύουν στην επίλυση ενός

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

Κεφάλαιο 1: Κίνηση και γεωμετρικά σχήματα

Κεφάλαιο 1: Κίνηση και γεωμετρικά σχήματα Ασκήσεις της Ενότητας 2 : Ζωγραφίζοντας με το ΒΥΟΒ -1- α. Η χρήση της πένας Κεφάλαιο 1: Κίνηση και γεωμετρικά σχήματα Υπάρχουν εντολές που μας επιτρέπουν να επιλέξουμε το χρώμα της πένας, καθώς και το

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

ΕΙΣΑΓΩΓΗ ΣΤΟΥΣ ΑΛΓΟΡΙΘΜΟΥΣ ΚΑΙ ΣΤΟΝ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟ

ΕΙΣΑΓΩΓΗ ΣΤΟΥΣ ΑΛΓΟΡΙΘΜΟΥΣ ΚΑΙ ΣΤΟΝ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟ ΕΙΣΑΓΩΓΗ ΣΤΟΥΣ ΑΛΓΟΡΙΘΜΟΥΣ ΚΑΙ ΣΤΟΝ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟ ΠΑΝΕΠΙΣΤΗΜΙΟ ΑΙΓΑΙΟΥ ΤΜΗΜΑ ΠΟΛΙΤΙΣΜΙΚΗΣ ΤΕΧΝΟΛΟΓΙΑΣ ΚΑΙ ΕΠΙΚΟΙΝΩΝΙΑΣ Διδάσκουσα Δρ Β. Καβακλή Χειμερινό Εξάμηνο 2001 1 Δοκιμή Έλεγχος Αλγορίθμου Για να

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

Σημαντικές δυνατότητες των σύγχρονων υπολογιστικών μηχανών: Αξιόπιστη καταγραφή πολύ μεγάλου όγκου δεδομένων

Σημαντικές δυνατότητες των σύγχρονων υπολογιστικών μηχανών: Αξιόπιστη καταγραφή πολύ μεγάλου όγκου δεδομένων Σημαντικές δυνατότητες των σύγχρονων υπολογιστικών μηχανών: Γρήγορες προσθέσεις αριθμών Γρήγορες συγκρίσεις αριθμών Αξιόπιστη καταγραφή πολύ μεγάλου όγκου δεδομένων Σχετικά γρήγορη μετάδοση και πρόσληψη

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

Γ ΓΥΜΝΑΣΙΟΥ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΜΕ ΤΗ ΓΛΩΣΣΑ MicroWorlds Pro

Γ ΓΥΜΝΑΣΙΟΥ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΜΕ ΤΗ ΓΛΩΣΣΑ MicroWorlds Pro Για να μπορέσουμε να εισάγουμε δεδομένα από το πληκτρολόγιο αλλά και για να εξάγουμε εμφανίσουμε αποτελέσματα στην οθόνη του υπολογιστή χρησιμοποιούμε τις εντολές Εισόδου και Εξόδου αντίστοιχα. Σύνταξη

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

ΚΕΦΑΛΑΙΟ 7 ο. Έτσι ο προγραµµατισµός µε τη ΓΛΩΣΣΑ εστιάζεται στην ανάπτυξη του αλγορίθµου και τη µετατροπή του σε σωστό πρόγραµµα.

ΚΕΦΑΛΑΙΟ 7 ο. Έτσι ο προγραµµατισµός µε τη ΓΛΩΣΣΑ εστιάζεται στην ανάπτυξη του αλγορίθµου και τη µετατροπή του σε σωστό πρόγραµµα. ΚΕΦΑΛΑΙΟ 7 ο 1. Επιλογή της κατάλληλης γλώσσας προγραµµατισµού Εκατοντάδες γλώσσες προγραµµατισµού χρησιµοποιούνται όπως αναφέρθηκε σήµερα για την επίλυση των προβληµάτων µε τον υπολογιστή, τη δηµιουργία

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

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

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

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

ΠΕΡΙΕΧΟΜΕΝΑ. Εντολές επιλογής Εντολές επανάληψης

ΠΕΡΙΕΧΟΜΕΝΑ. Εντολές επιλογής Εντολές επανάληψης ΠΕΡΙΕΧΟΜΕΝΑ Εντολές επιλογής Εντολές επανάληψης Εισαγωγή Στο προηγούμενο κεφάλαιο αναπτύξαμε προγράμματα, τα οποία ήταν πολύ απλά και οι εντολές των οποίων εκτελούνται η μία μετά την άλλη. Αυτή η σειριακή

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

Κεφάλαιο 2.3: Προγραμματισμός. Επιστήμη ΗΥ Κεφ. 2.3 Καραμαούνας Πολύκαρπος

Κεφάλαιο 2.3: Προγραμματισμός. Επιστήμη ΗΥ Κεφ. 2.3 Καραμαούνας Πολύκαρπος Κεφάλαιο 2.3: Προγραμματισμός 1 2.3.1 Αναφορά σε γλώσσες προγραμματισμού και «Προγραμματιστικά Υποδείγματα» 2.3.1.1 Πρόγραμμα και Γλώσσες Προγραμματισμού Πρόγραμμα: σύνολο εντολών που χρειάζεται να δοθούν

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

ΕΡΓΑΣΤΗΡΙΟ 3: Προγραμματιστικά Περιβάλλοντα και το Πρώτο Πρόγραμμα C

ΕΡΓΑΣΤΗΡΙΟ 3: Προγραμματιστικά Περιβάλλοντα και το Πρώτο Πρόγραμμα C ΕΡΓΑΣΤΗΡΙΟ 3: Προγραμματιστικά Περιβάλλοντα και το Πρώτο Πρόγραμμα C Στο εργαστήριο αυτό, θα ασχοληθούμε με δύο προγραμματιστικά περιβάλλοντα για τη γλώσσα C: τον gcc μεταγλωττιστή της C σε περιβάλλον

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

Ανάπτυξη Εφαρμογών σε Προγραμματιστικό Περιβάλλον. Διάρκεια 3 ώρες. Όνομα... Επώνυμο... Βαθμός...

Ανάπτυξη Εφαρμογών σε Προγραμματιστικό Περιβάλλον. Διάρκεια 3 ώρες. Όνομα... Επώνυμο... Βαθμός... 1 Ανάπτυξη Εφαρμογών σε Προγραμματιστικό Περιβάλλον Διάρκεια 3 ώρες Στοιχεία Μαθητή: Όνομα... Επώνυμο... Βαθμός... 2 Θεμα Α (30%) Α1 ΣΩΣΤΟ - ΛΑΘΟΣ 1. Ένα υποπρόγραμμα δεν μπορεί να κληθεί περισσότερες

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

9. Εντολές επανάληψηςκαι η εντολή

9. Εντολές επανάληψηςκαι η εντολή Προγραμματισμός Μεθόδων Επίλυσης Προβλημάτων 9. Εντολές επανάληψηςκαι η εντολή while Ιωάννης Κατάκης Σήμερα o Εισαγωγή στις δομές επανάληψης o Εντολή while o Τελεστές prefix και postfix Δομές ελέγχου προγράμματος

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

Η ΔΟΜΗ ΕΠΑΝΑΛΗΨΗΣ Εντολές Επανάληψης REPEAT UNTIL, FOR, WHILE

Η ΔΟΜΗ ΕΠΑΝΑΛΗΨΗΣ Εντολές Επανάληψης REPEAT UNTIL, FOR, WHILE ΕΡΓΑΣΤΗΡΙΟ 7 Ο Η ΔΟΜΗ ΕΠΑΝΑΛΗΨΗΣ Εντολές Επανάληψης REPEAT UNTIL, FOR, WHILE Βασικές Έννοιες: Δομή Επανάληψης, Εντολές Επανάληψης (For, While do, Repeat until), Αλγόριθμος, Αθροιστής, Μετρητής, Παράσταση

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

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

Εισαγωγή στον Προγραμματισμό Εισαγωγή στον Προγραμματισμό Εισαγωγή Δημήτρης Μιχαήλ Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο Ακ. Έτος 2012-2013 Βιβλιογραφία "C Προγραμματισμός", Deitel & Deitel, Πέμπτη Έκδοση, Εκδόσεις

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

ΔΟΜΗΜΕΝΟΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ

ΔΟΜΗΜΕΝΟΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ 1 ΔΟΜΗΜΕΝΟΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ Μάθημα 1ο Τμήμα Διοίκησης Επιχειρήσεων α εξάμηνο Β. Φερεντίνος Ορισμός Wikipedia.org 2 Δομημένος προγραμματισμός (structured programming) ή διαδικαστικός προγραμματισμός (procedural

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

Πληροφορική 2. Γλώσσες Προγραμματισμού

Πληροφορική 2. Γλώσσες Προγραμματισμού Πληροφορική 2 Γλώσσες Προγραμματισμού 1 2 Γλώσσες προγραμματσιμού Επιτρέπουν την κωδικοποίηση των αλγορίθμων Η εκτέλεση ενός προγράμματος θα πρέπει να δίνει τα ίδια αποτελέσματα με την νοητική εκτέλεση

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

Εισαγωγή στον Προγραµµατισµό. Διάλεξη 2 η : Βασικές Έννοιες της γλώσσας προγραµµατισµού C Χειµερινό Εξάµηνο 2011

Εισαγωγή στον Προγραµµατισµό. Διάλεξη 2 η : Βασικές Έννοιες της γλώσσας προγραµµατισµού C Χειµερινό Εξάµηνο 2011 Εισαγωγή στον Προγραµµατισµό Διάλεξη 2 η : Βασικές Έννοιες της γλώσσας προγραµµατισµού C Χειµερινό Εξάµηνο 2011 Hello World /* Αρχείο hello.c * Εµφανίζει στην οθόνη το * µήνυµα hello world */ #include

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

Εργαστήριο 2ο. Περίγραμμα Εργαστηριακής Άσκησης

Εργαστήριο 2ο. Περίγραμμα Εργαστηριακής Άσκησης Γλώσσες Προγραμματισμού Εργαστήριο 2ο Τύποι Δεδομένων - Είσοδος / Έξοδος Εργαστήριο 2ο Περίγραμμα Εργαστηριακής Άσκησης Εργαστήριο 2ο...1 Θεωρία εργαστηρίου...2 Τύποι δεδομένων...2 Η συνάρτηση printf()...3

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

Διάλεξη 2η: Αλγόριθμοι και Προγράμματα

Διάλεξη 2η: Αλγόριθμοι και Προγράμματα Διάλεξη 2η: Αλγόριθμοι και Προγράμματα Τμήμα Επιστήμης Υπολογιστών, Πανεπιστήμιο Κρήτης Εισαγωγή στην Επιστήμη Υπολογιστών Βασίζεται σε διαφάνειες του Κ Παναγιωτάκη Πρατικάκης (CSD) Αλγόριθμοι και Προγράμματα

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

ΑΝΑΠΤΥΞΗ ΕΦΑΡΜΟΓΩΝ ΣΕ ΠΡΟΓΡΑΜΜΑΤΙΣΤΙΚΟ ΠΕΡΙΒΑΛΛΟΝ ΜΑΡΙΑ Σ. ΖΙΩΓΑ ΚΑΘΗΓΗΤΡΙΑ ΠΛΗΡΟΦΟΡΙΚΗΣ ΕΙΣΑΓΩΓΗ ΣΤΟΝ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟ

ΑΝΑΠΤΥΞΗ ΕΦΑΡΜΟΓΩΝ ΣΕ ΠΡΟΓΡΑΜΜΑΤΙΣΤΙΚΟ ΠΕΡΙΒΑΛΛΟΝ ΜΑΡΙΑ Σ. ΖΙΩΓΑ ΚΑΘΗΓΗΤΡΙΑ ΠΛΗΡΟΦΟΡΙΚΗΣ ΕΙΣΑΓΩΓΗ ΣΤΟΝ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟ ΑΝΑΠΤΥΞΗ ΕΦΑΡΜΟΓΩΝ ΣΕ ΠΡΟΓΡΑΜΜΑΤΙΣΤΙΚΟ ΠΕΡΙΒΑΛΛΟΝ ΕΠΙΜΕΛΕΙΑ: ΜΑΡΙΑ Σ. ΖΙΩΓΑ ΚΑΘΗΓΗΤΡΙΑ ΠΛΗΡΟΦΟΡΙΚΗΣ ΘΕΩΡΙΑ 6 ΟΥ ΚΕΦΑΛΑΙΟΥ ΕΙΣΑΓΩΓΗ ΣΤΟΝ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟ 6.1 Τι ονοµάζουµε πρόγραµµα υπολογιστή; Ένα πρόγραµµα

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

ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΜΑΘΗΜΑ 3 Ο. Σταθερές-Παράμετροι-Μεταβλητές Αριθμητικοί & Λογικοί Τελεστές Δομή ελέγχου-επιλογής Σύνθετοι έλεγχοι

ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΜΑΘΗΜΑ 3 Ο. Σταθερές-Παράμετροι-Μεταβλητές Αριθμητικοί & Λογικοί Τελεστές Δομή ελέγχου-επιλογής Σύνθετοι έλεγχοι ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΜΑΘΗΜΑ 3 Ο Σταθερές-Παράμετροι-Μεταβλητές Αριθμητικοί & Λογικοί Τελεστές Δομή ελέγχου-επιλογής Σύνθετοι έλεγχοι ΣΙΝΑΤΚΑΣ Ι. ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ 2010-11 1 Μεταβλητές-Σταθερές-Παράμετροι Τα στοιχεία

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

Ενδεικτική περιγραφή μαθήματος

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

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

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

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

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

Προγραμματισμός Ι. Είσοδος/Έξοδος. Δημήτρης Μιχαήλ. Ακ. Έτος 2009-2010. Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο

Προγραμματισμός Ι. Είσοδος/Έξοδος. Δημήτρης Μιχαήλ. Ακ. Έτος 2009-2010. Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο Προγραμματισμός Ι Είσοδος/Έξοδος Δημήτρης Μιχαήλ Τμήμα Πληροφορικής και Τηλεματικής Χαροκόπειο Πανεπιστήμιο Ακ. Έτος 2009-2010 Είσοδος/Έξοδος Μέχρι τώρα όποτε θέλαμε να διαβάσουμε χρησιμοποιούσαμε πάντα

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

Δομημένος Προγραμματισμός

Δομημένος Προγραμματισμός Ανοικτά Ακαδημαϊκά Μαθήματα στο ΤΕΙ Ιονίων Νήσων Δομημένος Προγραμματισμός Ενότητα 2: Τύποι μεταβλητών Το περιεχόμενο του μαθήματος διατίθεται με άδεια Creative Commons εκτός και αν αναφέρεται διαφορετικά

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

Διαδικασία Ανάπτυξης Λογισμικού

Διαδικασία Ανάπτυξης Λογισμικού Διαδικασία Ανάπτυξης Λογισμικού Ανάλυση Απαιτήσεων (προϋποθέτει κατανόηση του προβλήματος και τη συλλογή πληροφοριών και των απαιτήσεων από το σύστημα) Σχεδιασμός (ορισμός διεργασιών για να ικανοποιηθούν

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

Εισαγωγή στην PHP. ΕΣΔ 516 Τεχνολογίες Διαδικτύου. Περιεχόμενα. Περιεχόμενα. ΕΣ 516: Τεχνολογίες ιαδικτύου. ΕΣ 516: Τεχνολογίες ιαδικτύου

Εισαγωγή στην PHP. ΕΣΔ 516 Τεχνολογίες Διαδικτύου. Περιεχόμενα. Περιεχόμενα. ΕΣ 516: Τεχνολογίες ιαδικτύου. ΕΣ 516: Τεχνολογίες ιαδικτύου ΕΣΔ 516 Τεχνολογίες Διαδικτύου Εισαγωγή στην PHP Περιεχόμενα Περιεχόμενα PHP και HTML Βασική σύνταξη Μεταβλητές Τελεστές Συναρτήσεις Παράδειγματα 1 Βιβλιογραφία Ενότητας Βιβλιογραφία [Lane 2004]: Chapter

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