C-ohjelmointi, kevät Merkkijonot Komentoriviparametrit. Luento
|
|
- Tapio Hämäläinen
- 7 vuotta sitten
- Katselukertoja:
Transkriptio
1 , kevät 2006 Merkkijonot Komentoriviparametrit Luento Kevät 2006 Liisa Marttinen 1 Merkkijonot (strings) (Müldnerin kirjan luku 9) C:ssä merkkijono ei ole ennaltamääritelty datatyyppi (kuten Javassa) Merkkijono on osoitin merkkeihin Osoitin mjono: Joukko merkkejä muistissa\0 Merkkijonojen käsittelyä varten standardikirjasto string.h Kevät 2006 Liisa Marttinen 2 1
2 Luennon sisältö Kirjastofunktiot merkkien käsittelyyn Merkkijonon määrittely ja alustaminen ja käyttö Merkkijonojen lukeminen ja kirjoittaminen formatoitu I/O merkkijonoille sscanf ja sprintf Riveittäin lukeminen ja tulostaminen fgets ja fputs; gets ja puts Kirjastofunktiot merkkijonojen käsittelyyn Komentoriviparametrit Kevät 2006 Liisa Marttinen 3 Merkeistä c on merkki ja c on merkkijono \0564, \xa6 datatyyppi int signed char, unsigned char L a long int esim. japanin tai kiinan merkkeihin Syöttö ja tulostus getchar, putchar scanf( format, &var), printf( format, exp) fgets, fputs, fscanf, fprintf Escape-merkit (samat kuin Javassa) '\n' = rivinvaihtomerkki '\t' = tabulaattori '\v' = pystysuora tabulointi '\b' = peruutusmerkki '\r' = rivinalkuunpalautusmerkki '\f' = sivunvaihtomerkki '\a' = hälytysmerkki, yleensä äänimerkki '\\' = kenoviiva '\'' = heittomerkki '\"' = lainausmerkki '\0' = merkkijonon lopetusmerkki if((c=getchar()) == EOF) if(scanf( %d%d, i,j)!=2) if((c=fgetc(tkahva)) == EOF).. while((c= getchar())!= \n ) while ((c=getchar())!=eof) while(getchar()!= \n ) ; Kevät 2006 Liisa Marttinen 4 2
3 #include<ctype.h> Kirjastofunktioita merkkien käsittelyyn Standardikirjaston ctype.h funktioita Merkkien luokitteluun islower(int c) isdigit(int c) palauttaa nollan, jos merkki ei ole kysyttyä tyyppiä, muuten nollasta eroavan arvon Merkkimuutoksiin tolower(int c) toupper(int c) jos muutos onnistuu, palauttaa muutetun arvon, muuten palauttaa EOF:n Kevät 2006 Liisa Marttinen 5 Merkkien luokittelufunktiot Alfanumeeriset int isalnum(int c) int isalpha(int c) int islower(int c) int isupper(int c) int isdigit(int c) int isxdigit(int c) int isodigit(int c) is c an alphanumeric is c an alphabetic letter is c a lower case letter is c an upper case letter is c a digit is c a hexadecimal digit is c an octal digit if (c>= a && c<= z ) Kirjastofunktioilla siirrettävämpää koodia! Muut merkit int isprint(int c) intisgraph(intc) int ispunct(int c) int isspace(int c) is c printable (not a control character) is c printable (not a space) is c printable (not space or alphanumeric) is c whitespace Kevät 2006 Liisa Marttinen 6 3
4 Merkkijonon määrittely ja muistinvaraaminen merkkijonolle Merkkijono määritellään osoittimena, joka osoittaa merkkeihin: char *s; Merkkijonolle pitää myös varata tilaa muistista. Myös \0-merkille on varattava tilaa Kirjastofunktiot osaavat käsitellä merkkijonona vain sellaista merkkien jonoa, joka päättyy \0-merkkiin! Esim. 10 merkin jonolle varattava 11 merkin kokoista muistialuetta: muistinvaraus -fraasi #define SIZE 10 if((s = malloc((size+1)*sizeof(char))) == NULL). Mitä tehdään varauksen epäonnistuessa? Kevät 2006 Liisa Marttinen 7 Merkkijonon alustaminen ja merkkijonon pituus s Vain muistialue, johon s osoittaa, mutta ei vielä merkkijono, koska \0 puuttuu! Alustettu, tyhjä merkkijono: s[0] = '\0'; \0 s Merkkijono, jonka pituus on 0! Merkkijonoon voidaan tallettaa lisää merkkejä: s H E L L O A L L \0 Nyt merkkijonon pituus on 9. Kevät 2006 Liisa Marttinen 8 4
5 Merkkijonon muistinvaraus ja i:nnen merkin osoittaminen Merkkijonon muistinvaraus aina calloc-funktiolla, koska calloc nullaa muistialueen => merkkijono on alustettu if((s = calloc(n+1, sizeof(char))) == NULL).. viittaus merkkijonon s i:nteen merkkiin s[i] :llä (0<= i < merkkijonon pituus) H E L L O A L L \0 s[0] s[1] s[2] s[3] s[4] s[5] s[6] s[7] s[8] S[3] = L ja s[6]= A Kevät 2006 Liisa Marttinen 9 Merkkijonon prefiksi (alkupää) ja suffiksi (loppupää) H E L L O A L L \0 s[0] s[1] s[2] s[3] s[4] s[5] s[6] s[7] s[8] s[9] s[10] Merkkijonon loppupäähän pääsee helposti käsiksi Esimerkiksi s+6 osoittaa merkkijonoa ALL, jonka pituus on 3 merkkiä s+8 osoittaa merkkijonoa L, jonka pituus on 1 merkki s+9 osoittaa tyhjää merkkijonoa, jonka pituus on 0 s+10 ei osoita mihinkään merkkijonoon! Alkupäähän esim. merkkijonoon HELL on taas vaikeampi päästä käsiksi, koska se ei pääty \0-merkkiin. Kevät 2006 Liisa Marttinen 10 5
6 Merkkijonovakio char *nimi Tarja Halonen Vakion sisältöä ei saa muuttaa On voitu tallettaa esim. read only alueelle Ei saa välittää parametrina sellaiselle funktiolle, joka muuttaa parametrinaan saamaa merkkijonoa Huomaa ero: T ja T T on merkki T nimi Tarja Halonen\0 T on merkkijono eli merkki T ja sitä seuraava null-merkki T\0 Kevät 2006 Liisa Marttinen 11 Merkkijono parametrina ja paluuarvona Koska merkkijono on itseasiassa osoitin, sitä voidaan käyttää samalla tavoin kuin osoittimia yleensä Merkkijonon tulee olla alustettu (muuten ei ole merkkijono!) Merkkijonovakioita ei saa muuttaa # funktio muuttaa # merkkijonon 1. merkin # isoksi kirjaimeksi void modify(char *s) { s[0] = toupper(s[0]); char *p; /* EI VIELÄ! modify(p); */ if((p = calloc(10, sizeof(char))) == NULL) errorf(); p[0] = 'h'; p[1] = 'i'; /* p[2] == '\0' */ modify(p); h i \0 H i \0 H I \0 modify(p+1); char *q = "hello"; /*merkkijonovakio*/ modify(q); /* EI, EI; EEII näin! */ Kevät 2006 Liisa Marttinen 12 6
7 Merkkijono parametrina ja paluuarvona (2) (vanha merkkijono ei muutu, nyt muutos tehdään sen kopioon) Muista vapauttaa muistilohko, char *modify(const char *s) { kun sitä ei enää tarvita: char *news; /* uusi merkkijono */ char *ps; /* selaa vanhaa */ free (news); char *pn; /* selaa uutta */ if ((news = calloc (length(s)+1), sizeof(char))) == NULL) return NULL; for (ps = s, pn = news; *ps; ps++, pn++) *pn = *ps; *pn = *ps; /* kopioi vielä \0-merkin /* p news[0] = toupper(news[0]); return news; tarja H.\0 char *p = tarja H. ; char *q = modify(p); tai char *q =modify( tarja H. ); Tarja H.\0 q = modify(p+3); p tarja H.\0 q Ja H.\0 q Kevät 2006 Liisa Marttinen 13 Erilaisia kopiointitapoja while((q[i]= p[i])!= \0 ) i++; while((*q=*p)!= \0 ) {q++; p++; while ((*q++=*p++)!= \0 ); while (*q++ = *p++); Tekevät saman asian: kopioivat merkit merkkijonosta p merkkijonoon q. Muista varata muistista tilaa merkkijonolle q ennen kopioimista. Älä hukkaa merkkijonojen alkuja! Kopioitava merkkijono\0 p?? q Kopioita Kevät 2006 Liisa Marttinen 14 7
8 Muutetun merkkijonon palautus parametrina void modify1(const char *s, char **news) { /* return through parameter a copy of s modified*/ char *ps; /* selaa vanhaa */ char *pn; /* selaa uutta */ if (s == NULL) return -1; if ((*news = calloc (length(s)+1), sizeof(char))) == NULL) return NULL; for (ps = s, pn = *news; *ps; ps++, pn++) *pn = *ps; *pn = *ps; /* kopioi vielä \0-merkin /* (*news)[0] = toupper((*news)[0]); s ps char *p; modify1("hello", &p); osoitin p: hello\0 news osoitin char osoitin, joka osoittaa osoittimeen, joka osoittaa char tyyppiseen muuttujaan Calloc-funktion varaama muistialue H e l l news = &p Kevät 2006 Liisa Marttinen 15 pn Esimerkki: funktio tarkistaa, onko annettu merkkijono kelvollinen kokonaisluku joko desimaalina tai heksadesimaalina esitettynä. int isnumber(const char *s) { if (s == NULL s[0] == \0 ) /* tyhjä merkkijono */ return 0; # onko heksaluku eli tyyppiä 0x2A68? if (s[0] == 0 ) { /*nolla ensimmäisenä*/ if (s[1] == \0 ) return 1; /*pelkkä nolla kelpaa*/ if(s[1] == x s[1] == X ) /*heksaluku?*/ if (s[2] == \0 ) return 0; /* 0x ei riitä*/ for (s +=2; *s; s++) if (!isxdigit (*s)) return 0; return 1; /* kelvollinen heksaluku */ # onko desimaaliluku for (;*s; s++) if (!isdigit (*s)) return 0; return 1; Fraasi merkkijonon läpikäyntiin: for (p = s; *p; p++) käytä *p:tä; Kevät 2006 Liisa Marttinen 16 8
9 Merkkijono ja formatoitu I/O %s sekä syötössä että tulostuksessa Syötössä merkkijonon alussa olevat tyhjät ohitetaan ja lukeminen aloitetaan ensimmäisestä ei-tyhjästä merkistä Luetaan yksi sana eli seuraavaan tyhjään merkkiin asti => scanf lukee vain yhden sanan const int SIZE = 7; char *s; if ((s = malloc((size + 1) * sizeof(char))) == NULL) virhetilanne(); scanf( %s, s); scanf ( %7s,s); Mitä luetaan, jos syöte on Java language? Entä, jos syöte on language Java? Entä scanf ( %SIZEs,s);? Ei käy, sillä lainausmerkkien sisällä ei käsitellä makroja! Kevät 2006 Liisa Marttinen 17 Merkkijonon lukeminen scanf ( %s, s) koska s on osoitin Ennen lukemista merkkijonolle on oltava muistia varattuna Muistia on oltava tarpeeksi! Varmista rajoittamalla pituus. if (scanf( %10s, s)!=1) error Lukee yhden korkeintaan 10 merkin mittaisen sanan. Varaa tilaa myös \0- merkille. Kevät 2006 Liisa Marttinen 18 9
10 Merkkijonon tulostus printf( %s, str) tulostaa osoittimen str osoittaman muistilohkon kaikki merkit \0-merkkiin saakka char *s = C ja Java ovat kieliä. printf ( %s\n, s); printf ( %s\n, s+5); C ja Java ovat kieliä.\0 s s+5 Tulostus: C ja Java ovat kieliä. Java ovat kieliä. Kevät 2006 Liisa Marttinen 19 Esimerkki int lower(char *s) { /* return number of l.c. letters */ int i; char *q; for(i = 0, q = s, *q, q++) if(islower(*q)) i++; return i; int main() { const int M = 10; char *p; if((p = calloc(m + 1, sizeof(char)) == NULL) return EXIT_FAILURE; if(scanf("%10s", p)!= 1) return EXIT_FAILURE; printf("%d lower case letters in %s\n", lower(p), p); return EXIT_SUCCESS; Ohjelma lukee yhden korkeintaan 10 merkin mittaisen sanan ja tulostaa siinä olleiden pienten kirjainten lukumäärän. #include <stdio.h> #include <stdlib.h> #include <ctype.h> for(i = 0, q = s, *q, q++) if(islower(*q)) i++; p = s; i=0; while (*p++) if (islower(*p)) i++; Kevät 2006 Liisa Marttinen 20 10
11 sscanf ja sprintf merkkijonosta lukeminen ja merkkijonoon kirjoittaminen int sscanf (s, format, arguments) merkkijonot luvuiksi if (sscanf (p,"%lf", &sd)!=1) if(sscanf(s+6, "%d%f", &i, &d)!= 2) Luvut \0 int sprintf (s, format, arguments) merkkijonon kokoamiseen osista sprintf(p, Syötetty luku oli %d, j); sprintf(s, "%s %d %f", "test", 1, 1.5); test 1 1.5\0 Tehokkaampiakin tapoja näihin toimintoihin on! p:n ja s:n oltava alustettuja merkkijonoja, joille on varattu riittävästi tilaa muistista calloc-funktiolla. Kevät 2006 Liisa Marttinen 21 fgets ja fputs tiedosto merkkijono (myös stdin ja stdout) Rivi kerrallaan lukeminen ja kirjoittaminen char* fgets(char *buf, int n, FILE *in); Lukee yhden rivin, mutta enintään n-1 merkkiä tiedostosta in ja tallettaa sen muistilohkoon buf. Tallettaa myös rivinlopetusmerkit. Vaikka fgets onnistuessaan aina kirjoittaa muistilohkoon viimeiseksi \0- merkin, niin merkkijonon kelvollisuus kannattaa varmistaa: buf[strlen(buf)] = \0 ; int fputs (const char *s, FILE *out); Kirjoittaa merkkijonon s (ilman \0-merkkiä) tiedostoon out. Kevät 2006 Liisa Marttinen 22 11
12 gets ja puts stdin-syöttö ja stdout-tulostus char * gets(char *buf); Lukee aina koko rivin (ei siis korkeintaan tiettyä määrää) eikä talleta rivin lopetusmerkkiä muistilohkoon. int puts(const char *buf); Kirjoittaa merkkijonon ja päättää sen aina rivinvaihdolla. Rivi kerrallaan lukemisen yleinen ongelma: aina oletettava jokin maksimipituus jolle varataan tilaa! Kevät 2006 Liisa Marttinen 23 Merkkijono-operaatiot: <string.h> Runsaasti merkkijonoja käsitteleviä funktioita Merkkijonon pituus size_t strlen (const char *string); Huom! merkkijonojen pituuksien vertailu if (strlen(x) >= strlen(y)) if ((int)strlen(x) SIZE >= 0) Merkkijonon kopiointi char *strcpy(char *dest, const char *src); char *strncpy(char *dest, const char *src, size_t n); Merkkijonon liittäminen toiseen char *strcat(char *dest, const char *src); char *strncat(char *dest, const char *src, size_t n) Varmista, että kopio on alustettu merkkijono kopiolle on varattu tarpeeksi muistitilaa kopioon tulee \0- merkki. Kevät 2006 Liisa Marttinen 24 12
13 Lisää merkkijono-operaatioita <string.h> Palauttaa Merkkijonojen vertailu (merkki merkiltä) int strcmp(const char *s1, const char *s2); int strcnmp(const char *s1, const char *s2, size_t n); Merkin tai merkkijonon etsiminen char *strchr(const char *str, int c); char *strchr(const char *str, int c); char *strstr(const char *str, const char *substr); etsii merkkijonoa <0 jos s1 < s2 0 jos s1 == s2 >0 jos s1 > s2 ensimmäinen c:n esiintymä viimeinen c:n esiintymä size_t strspn(const char *str, const char *set); 1. joukkoon kuuluva merkki size_t strcspn(const char *str, const char *set); 1. joukkoon kuulumaton merkki char *strpbrk(const char *str, const char *set); 1. joukkoon kuuluva merkki merkkijoukon merkkien esiintyminen merkkijonossa, palauttaa esiintymispaikan (ohitettujen merkkien lukumääränä tai osoittimena) Kevät 2006 Liisa Marttinen 25 Yhä merkkijono-operaatiota Merkkijonon jako sanoiksi (token) erotusmerkein char *strtok(char *str, const char *sep); ensimmäisellä kerralla annettava merkkijono; seuraavilla kerroilla voi antaa sen tilalla NULL:in Tällöin jatkaa seuraavan sanan etsimistä samasta merkkijonosta. Muuttaa merkkijonoa: \0 jokaisen havaitun sanan perään. Merkkijono numeroiksi <stdlib.h> p double strtod(const char *s, char **p); long strtol(const char *s, char **p, int base); unsigned long strtoul(const char *s, char **p, int base); <string.h> /home/avirta/kurssi/c/2006/testi.c\0 ANSI C versioita, jotka korvaavat vanhat: atof, atoi ja atol Kevät 2006 Liisa Marttinen 26 str char *sep \ ; strtok(null, sep); Tee kopio ja käytä sitä! s fail: s:n alkuun success: eka muuttamaton merkki 13
14 Esimerkki: Merkkijonon riisuminen turhista edesssä ja perässä olevista tyhjämerkeistä tai muista turhista merkeistä Heippa vaan \0 Heippa vaan\0 Müldnerin kirjan esimerkki 9-13 /* strip from s leading and trailing characters from * set. For example: * char *p = strip(",hi, how are you,", ","); */ char *strip(const char *s, const char *set) { int start = strspn(s, set); /* leading character*/ int end; /* trailing characters */ char *kopy; int length = strlen(s); /*merkkijonon pituus*/ if(length!= start) { /* there are characters not in s */ for(end = length; end > 1; end--) /* trailing */ if(strchr(set, s[end]) == NULL) /* onko poistettava merkki */ break; length = end - start + 1; /* left after strip */ Kevät 2006 Liisa Marttinen 27 Esimerkki jatkuu: /*char *strip() continued */ if((kopy = calloc(length + 1, sizeof(char)))==null) return NULL; memcpy(kopy, s + start, length); kopy[length] = '\0'; /* length!= start */ else { /* here, no characters in s */ if((kopy = calloc(length + 1, sizeof(char)))==null) return NULL; strcpy(kopy, s); return kopy; Kevät 2006 Liisa Marttinen 28 14
15 Komentoriviparametrit int main (int argc, char **argv); int main (int argc, char *argv[]); argc merkkijonojen lukumäärä argv osoitin osoitinlohkoon ohjelmannimi parametri1 parametri 2 echo Hello, world argc = 3 argv argv[0] argv[1] argv[2] echo\0 Hello,\0 world\0 -merkit echo Hello, world argv echo\0 toimivat argv[0] joissakin järjestelmissä! argv[1] Hello, world\0 argc = 2 Kevät 2006 Liisa Marttinen 29 Osoittaminen komentoriviargumentteihin etsi Virtanen Ville rektiedosto argc: 4 argv: argv[0] argv[1] argv[2] argv[3] etsi\0 Virtanen\0 Ville\0 rektiedosto\0 argv[0] tai argv osoittaa 1. parametriin eli ohjelman nimeen ( etsi ), argv[1] tai argv+1 osoittaa 2. parametriin ( Virtanen ) argv[2] tai argv+2 osoittaa 3. parametriin ( Ville ) argv[3] tai argv+3 osoittaa 4. parametriin ( rektiedosto ) argv[0][0] tai (*argv)[0] tai **argv osoittaa 1. parametrin 1. merkkiin argv[2][4] tai (*(argv+2))[4)] tai *(*(argv+2)+4) osoittaa 3. parametrin 5. merkkiin. 15
16 Komentoparametrien lukumäärän tarkistus /* Tarkista komentoriviparametrien lukumäärä! */ int main(int argc, char **argv) {. switch(argc) { case 4: /* kaikki tiedot annettu komentorivillä*/ case 3: /*OK! käytetään oletusarvoa*/ default: fprintf(stderr, Väärä käyttötapa: %s.. \n", argv[0]); /*Voisi myös kertoa oikean käytötavan!*/ return EXIT_FAILURE; Kevät 2006 Liisa Marttinen 31 Komentoriviparametrien käyttö: Tiedoston rivien tulostus näytölle #define DEFAULT 10 #define MAX 80 /*tulostaa näytölle tiedoston n ensimmäistä riviä */ int display(const char *fname, int n, int Max); int main(int argc, char **argv) { int lines = DEFAULT; switch(argc) { case 3: /* selvitä rivien lukumäärä argumentti */ ohjelman nimi rivien lkm show -n fname - = argumentti on optionaalinen; voi puuttua tiedoston nimi if(argv[1][0]!= '-' sscanf(argv[1] + 1, "%d", &lines)!=1 lines <= 0) return EXIT_FAILURE; argv++; /* no break: retrieve filename */ case 2: if(display(argv[1], lines, MAX) == 0) return EXIT_FAILURE; break; default: return EXIT_FAILURE; argv argv argv[0] show\0 argv[0] show\0 return EXIT_SUCCESS; argv[1] -n\0 argv[1] testi\0 argv[2] testi\0 Kevät 2006 Liisa Marttinen 32 16
17 Ohjelma laskee ja tulostaa parameteina annettujen lukujen summa #include <stdio.h> #include <stdlib.h> int main(int argc, char **argv) { int i; double luku, summa=0.0; char **p; char *s; if (argc==1) { printf ("Parametreja voi olla vaihteleva"); printf (" määrä ja ne voivat olla"); printf (" kokonaislukuja tai liukulukuja"); printf ("\nkäyttö: SUMMA arg1 arg2... argn\n"); exit(0); /* lopetetaan ohjelman toiminta */ if ((s = calloc(80, sizeof(char))) == NULL) return 1; p = &s; for (i=1; i<argc; i++) { luku = strtod(argv[i], p); summa=summa+luku; printf ("Lukujen summa on %.2lf\n",summa); return 0; Kevät 2006 Liisa Marttinen 33 Mitä opittiin? Merkkijonojen alustaminen ja käsittely Merkkijonojen syöttö ja tulostus Standardikirjaston funktioita merkkijonojen käsittelyyn Komentoriviparametrien käyttö Kevät 2006 Liisa Marttinen 34 17
18 Ensi kerralla Taulukoiden käsittelyä Yksiulotteiset taulukot Määrittely, kopiointi, vertailu Taulukko parametrina Alustus ja talletus Moniulotteiset taulukot Dynaamiset taulukot Kevät 2006 Liisa Marttinen 35 18
Merkkijonot Komentoriviparametrit
, kevät 2006 Merkkijonot Komentoriviparametrit Luento 7 14.3.2006 Kevät 2006 Liisa Marttinen 1 Merkkijonot (strings) (Müldnerin kirjan luku 9) C:ssä merkkijono ei ole ennaltamääritelty datatyyppi (kuten
LisätiedotC-ohjelmointi, syksy Merkkijonot Komentoriviparametrit. Luento C-ohjelmointi Syksy
, syksy 2008 Merkkijonot Komentoriviparametrit Luento 7 26.9.2008 Syksy 2008 1 Merkkijonot (strings) luku 9) (Müldnerin kirjan C:ssä merkkijono ei ole ennaltamääritelty datatyyppi (kuten Javassa) Merkkijono
LisätiedotMerkkijonot Komentoriviparametrit
C-ohjelmointi Merkkijonot Komentoriviparametrit Viikko 5 1 Merkkijonot (strings) luku 9) (Müldnerin kirjan C:ssä merkkijono ei ole ennaltamääritelty datatyyppi (kuten Javassa) Merkkijono on osoitin merkkeihin
LisätiedotTiedostot. Tiedostot. Tiedostot. Tiedostot. Tiedostot. Tiedostot
Tiedosto yhteenkuuluvien tietojen joukko, joka on tavallisesti talletettu pysyväismuistiin muodostuu tietueista, jotka voivat olla keskenään samanlaisia tai vaihdella tyypiltään tiedostot ovat joko tekstitiedostoja
LisätiedotMerkkijono määritellään kuten muutkin taulukot, mutta tilaa on varattava yksi ylimääräinen paikka lopetusmerkille:
Merkkijonot C-kielessä merkkijono on taulukko, jonka alkiot ovat char -tyyppiä. Taulukon viimeiseksi merkiksi tulee merkki '\0', joka ilmaisee merkkijonon loppumisen. Merkkijono määritellään kuten muutkin
LisätiedotMerkkijonot (strings) (Müldnerin kirjan luku 9) Luennon sisältö. Merkeistä. Merkkien luokittelufunktiot. Merkkijonot Komentoriviparametrit
, kevät 2006 Merkkijonot Komentoriviarametrit Luento 7 14.3.2006 Kevät 2006 Liia Marttinen 1 Merkkijonot (tring) (Müldnerin kirjan luku 9) C:ä merkkijono ei ole ennaltamääritelty datatyyi (kuten Javaa)
LisätiedotMerkkijonot (strings) luku 9)
, yky 2007 Merkkijonot (tring) luku 9) (Müldnerin kirjan Merkkijonot Komentoriviarametrit Luento 7 28.9.2007 Syky 2007 1 C:ä merkkijono ei ole ennaltamääritelty datatyyi (kuten Javaa) Merkkijono on ooitin
LisätiedotModuli 5: Kehittyneitä piirteitä
C! : Kehittyneitä piirteitä 19.4.2016 Aikataulusta 5. harjoituskierroksen määräaika: pe 22.4. Maari-C keskiviikkoisin ja torstaisin (12-14) Ti 26.4. Harjoitustentti (eli kertausluento) Normaalin luennon
LisätiedotOhjeet. AS C-ohjelmoinnin peruskurssi Aalto-yliopiston sahkotekniikan korkeakoulu Tentti , Raimo Nikkila
AS-0.1103 C-ohjelmoinnin peruskurssi Aalto-yliopiston sahkotekniikan korkeakoulu Tentti 15.05.2013, Raimo Nikkila Ohjeet Kaikki ohjelmointitehtavat tulee toteuttaa C-kielella hyvaa ohjelmointityylia noudattaen.
LisätiedotLyhyt kertaus osoittimista
, syksy 2007 Kertausta Luento 10 12.10.2007 Syksy 2007 1 Lyhyt kertaus osoittimista char *p; /* char, int, jne ilmoittavat, minkä tyyppisiä */ Keskusmuisti int *q; /* olioita sisältäviin muistilohkoihin
Lisätiedot1. Mitä seuraava ohjelma tulostaa? Vastaukseksi riittää yksi rivi joka esittää tulosteen. (6 p)
C- ohjelmoinnin peruskurssi, Tentti 28.5.2015 Lyhyt referenssi funktioista tehtäväpaperin lopussa. Paperilla on 5 tehtävää, joista useimmissa on muutama alikohta. Maksimipistemäärä on 30 pistettä. Kirjoita
LisätiedotLuennon sisältö. Taulukot (arrays) (Müldnerin kirjan luku 10) Yksiulotteiset taulukot. Mikä taulukko on? Taulukko-osoitin. tavallinen osoitin
, kevät 2006 Taulukot Yksiulotteiset taulukot Moniulotteiset taulukot Dynaamiset taulukot Binääritiedostot Luento 8 21.3.2006 Kevät 2006 Liisa Marttinen 1 Luennon sisältö Taulukoiden käsittelyä Yksiulotteiset
LisätiedotLuennon sisältö Tyypit int, char, float, double signed, unsigned short, long Vakiot const Rakenteet if, for, while, switch, do-while Syöttö ja tulostu
C-kurssi Viikko 1: tyypit, rakenteet, makrot Luennon sisältö Tyypit int, char, float, double signed, unsigned short, long Vakiot const Rakenteet if, for, while, switch, do-while Syöttö ja tulostus Makrot
LisätiedotC-ohjelmointi, syksy 2006
, syksy 2006 Taulukot Yksiulotteiset taulukot Moniulotteiset taulukot Dynaamiset taulukot Binääritiedostot Luento 8 3.10.2006 Syksy 2006 1 Luennon sisältö Taulukoiden käsittelyä Yksiulotteiset taulukot
LisätiedotC-ohjelmointi, syksy Yksiulotteiset taulukot Moniulotteiset taulukot Dynaamiset taulukot. Binääritiedostot. Luento
, syksy 2006 Taulukot Yksiulotteiset taulukot Moniulotteiset taulukot Dynaamiset taulukot Binääritiedostot Luento 8 3.10.2006 Syksy 2006 1 Luennon sisältö Taulukoiden käsittelyä Yksiulotteiset taulukot
LisätiedotOhjeet. Jaa vastauksesi konsepteille siten, etta:
/ AS-0.1103/4 C~ohjelmoinnin peruskurssi Aalto-yliopiston teknillinen korkeakoulu Tentti 12.05.2010, Raimo Nikkilii Ohjeet Kaikki ohjelmointitehtavat tulee toteuttaa C-kielella hyvaa ohjelmointityylia
LisätiedotBinäärioperaatiot Tiedostot ja I/O
C! Binäärioperaatiot Tiedostot ja I/O 8.3.2018 Tiedotteita Viimeinen luento to 29.3. Ohjelmointitehtävä, ohjelmointikoe ja niiden järjestelyt Ohjelmointikokeeseen ilmoittautuminen auki 2 .c tiedostot ja.h
LisätiedotOhjelmassa henkilön etunimi ja sukunimi luetaan kahteen muuttujaan seuraavasti:
1 (7) Tiedon lukeminen näppäimistöltä Scanner-luokan avulla Miten ohjelma saa käyttöönsä käyttäjän kirjoittamaa tekstiä? Järjestelmässä on olemassa ns. syöttöpuskuri näppäimistöä varten. Syöttöpuskuri
LisätiedotBinäärioperaatiot Tiedostot ja I/O
C! Binäärioperaatiot Tiedostot ja I/O 16.3.2017 Tiedotteita Määräaikoja pidennetty Myös 7. kierros uudestaan auki perjantaihin asti Seuraava ja viimeinen luento 30.3. Makrot, funktio-osoittimet Kokeen
LisätiedotRakenteiset tietotyypit Moniulotteiset taulukot
C! Rakenteiset tietotyypit Moniulotteiset taulukot 22.2.2018 Agenda Rakenteiset tietotyypit Vilkaisu 6. kierroksen tehtäviin Moniulotteiset taulukot Esimerkki Seuraava luento to 8.3. Ilmoittautuminen ohjelmointikokeeseen
LisätiedotOhjelmassa muuttujalla on nimi ja arvo. Kääntäjä ja linkkeri varaavat muistilohkon, jonne muuttujan arvo talletetaan.
Osoittimet Ohjelmassa muuttujalla on nimi ja arvo. Kääntäjä ja linkkeri varaavat muistilohkon, jonne muuttujan arvo talletetaan. Muistilohkon koko riippuu muuttujan tyypistä, eli kuinka suuria arvoja muuttujan
LisätiedotICS-C2000 Tietojenkäsittelyteoria Kevät 2016
ICS-C2000 Tietojenkäsittelyteoria Kevät 2016 Kierros 6, 22. 26. helmikuuta Huom: arviointiviikolla 15. 19.2. ei ole laskuharjoituksia! Demonstraatiotehtävien ratkaisut D1: (a) Osoita, että seuraava yhteydetön
LisätiedotLoppukurssin järjestelyt C:n edistyneet piirteet
C! Loppukurssin järjestelyt C:n edistyneet piirteet 30.3.2017 Ohjelmassa Ohjelmontitehtävän järjestelyt Tietokonetentin järjestelyt Esikääntäjä Parametrilistat Funktio-osoittimet Kunniamainintoja Kuura
Lisätiedot7. Näytölle tulostaminen 7.1
7. Näytölle tulostaminen 7.1 Sisällys System.out.println- ja System.out.print-operaatiot. Tulostus erikoismerkeillä. Edistyneempää tulosteiden muotoilua. 7.2 Tulostusoperaatiot System.out.println-operaatio
LisätiedotOhjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 15.2.2010 T-106.1208 Ohjelmoinnin perusteet Y 15.2.2010 1 / 46 Merkkijonot Merkkijonojen avulla ohjelmassa voi esittää tekstitietoa, esim. nimiä, osoitteita ja
Lisätiedot// // whiledemov1.c // #include <stdio.h> int main(void){ int luku1 = -1; int luku2 = -1;
// // whiledemov1.c // #include int main(void){ int luku1 = -1; int luku2 = -1; while( luku1
LisätiedotLoppukurssin järjestelyt
C! Loppukurssin järjestelyt 29.3.2018 Ohjelmassa Yhteenvetoa palautteesta Ohjelmontitehtävän järjestelyt Tietokonetentin järjestelyt Kysyttävää / kerrattavaa 10-kierroksen asioista? Aikatauluista 10. kierroksen
LisätiedotC-kurssi kevät Luennon sisältö
C-kurssi kevät 2006 Luento 2: tyypit, rakenteet, makrot 24.1.2006 Luennon sisältö Tyypit int, char, float, double signed, unsigned short, long Vakiot const Rakenteet if, for, while, switch, do-while Syöttö
LisätiedotJava-kielen perusteet
Java-kielen perusteet Tunnus, varattu sana, kommentti Muuttuja, alkeistietotyyppi, merkkijono, literaalivakio, nimetty vakio Tiedon merkkipohjainen tulostaminen 1 Tunnus Java tunnus Java-kirjain Java-numero
LisätiedotLuennon sisältö. C-kurssi kevät Tasokokeen kohta 1: Taulukon järjestäminen. Tasokokeen kohta 2. Tasokokeen kohta 2. Tasokokeen kohta 3
Luennon sisältö C-kurssi kevät 2006 Luento 2: tyypit, rakenteet, makrot 24.1.2006 Tyypit int, char, float, double signed, unsigned short, long Vakiot const Rakenteet if, for, while, switch, do-while Syöttö
LisätiedotC-kurssi syksy ltö. Luennon sisält. Luento 2: tyypit, rakenteet, makrot Tyypit. signed, unsigned short,, long Vakiot const Rakenteet
C-kurssi syksy 2007 Luento 2: tyypit, rakenteet, makrot 5.9.2008 Luennon sisält ltö Tyypit int, char, float, double signed, unsigned short,, long Vakiot const Rakenteet if,, for, while, switch, do-while
LisätiedotLuennon sisält. ltö. C-kurssi syksy ääreet: int ja char. Yksinkertaiset tyypit. Kokonaisluvut. Merkit
Luennon sisält ltö C-kurssi syksy 2007 Luento 2: tyypit, rakenteet, makrot 5.9.2008 Tyypit int, char, float, double signed, unsigned short,, long Vakiot const Rakenteet if,, for, while, switch, do-while
LisätiedotMuistin käyttö. Muistin käyttö. Muistin käyttö. Muistin käyttö. Muistin käyttö. Muistin käyttö. Muistin käyttö C-ohjelmassa
ssa ohjelman käytössä suoritusaikana oleva muisti jakautuu neljään osaan: koodisegmentti datasegmentti pinosegmentti (stack) kasa (heap) ssa ohjelman koodisegmentti sisältää käännetyn ohjelmakoodin sisältö
LisätiedotSisältö. C-ohjelmointi Luento 5: Osoittimet. Keko (heap) Pino (stack) Muistinhallinta Java vs C. Prosessin rakenne
Sisältö C-ohjelmointi Luento 5: Osoittimet 14.2.2006 Tiina Niklander Muistin rakenteesta Operaatiot ja void-tyyppi Muistinhallinta varaus, vapautus Osoitinaritmetiikka ja muistilohkon käsittely Osoittimet
LisätiedotC-kielessä taulukko on joukko peräkkäisiä muistipaikkoja, jotka kaikki pystyvät tallettamaan samaa tyyppiä olevaa tietoa.
Taulukot C-kielessä taulukko on joukko peräkkäisiä muistipaikkoja, jotka kaikki pystyvät tallettamaan samaa tyyppiä olevaa tietoa. Taulukon muuttujilla (muistipaikoilla) on yhteinen nimi. Jokaiseen yksittäiseen
LisätiedotOperaattoreiden ylikuormitus. Operaattoreiden kuormitus. Operaattoreiden kuormitus. Operaattoreista. Kuormituksesta
C++ - perusteet Java-osaajille luento 5/7: operaattoreiden ylikuormitus, oliotaulukko, parametrien oletusarvot, komentoriviparametrit, constant, inline, Operaattoreiden ylikuormitus Operaattoreiden kuormitus
LisätiedotHarjoitus 4 (viikko 47)
Kaikki tämän harjoituksen tehtävät liittyvät joko suoraan tai epäsuorasti kurssin toiseen harjoitustyöhön. Saa hyvän alun harjoitustyön tekoon, kun ratkaiset mahdollisimman monta tehtävää. Mikäli tehtävissä
LisätiedotOsoittimet ja taulukot
Osoittimet ja taulukot Hannu Laine Copyright Hannu Laine Osoittimet int main (void) { int a; int *p; //p on osoitinmuuttuja p = &a; *p = 10; printf( %d, *p); //tulostuu muuttujan a sisältö scanf( %d, p);
LisätiedotC-ohjelma. C-ohjelma. C-ohjelma. C-ohjelma. C-ohjelma. C-ohjelma. Operaatioiden suoritusjärjestys
Loogisia operaatioita - esimerkkejä Tänään on lämmin päivä ja perjantai Eilen satoi ja oli keskiviikko tai tänään on tiistai. On perjantai ja kello on yli 13 Ei ole tiistai tai ei sada. Ei pidä paikkaansa,
LisätiedotHarjoitus 5 (viikko 48)
Moni tämän harjoituksen tehtävistä liittyy joko suoraan tai epäsuorasti kurssin toiseen harjoitustyöhön. Harjoitustyö edistyy sitä paremmin, mitä enemmän tehtäviä ratkaiset. Mikäli tehtävissä on jotain
Lisätiedot815338A Ohjelmointikielten periaatteet Harjoitus 2 vastaukset
815338A Ohjelmointikielten periaatteet 2015-2016. Harjoitus 2 vastaukset Harjoituksen aiheena on BNF-merkinnän käyttö ja yhteys rekursiivisesti etenevään jäsentäjään. Tehtävä 1. Mitkä ilmaukset seuraava
LisätiedotOhjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 23.2.2009 T-106.1208 Ohjelmoinnin perusteet Y 23.2.2009 1 / 44 Debuggeri Tyypillinen tilanne: ohjelma on kirjoitettu, Python-tulkki ei valita virheistä, mutta
LisätiedotOhjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 14.2.2011 T-106.1208 Ohjelmoinnin perusteet Y 14.2.2011 1 / 55 Kännykkäpalautetteen antajia kaivataan edelleen! Ilmoittaudu mukaan lähettämällä ilmainen tekstiviesti
LisätiedotC-kurssi kevät t Luento 2: tyypit, rakenteet, makrot
C-kurssi kevät t 2006 Luento 2: tyypit, rakenteet, makrot 24.1.2006 Luennon sisält ltö Tyypit int, char, float, double signed, unsigned short,, long Vakiot const Rakenteet if,, for, while, switch, do-while
LisätiedotOhjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 1.4.2009 T-106.1208 Ohjelmoinnin perusteet Y 1.4.2009 1 / 56 Tentti Ensimmäinen tenttimahdollisuus on pe 8.5. klo 13:00 17:00 päärakennuksessa. Tämän jälkeen
LisätiedotC-kieli mahdollistaa hyvin tiiviin ja samalla sekavan tavan esittää asioita, kuitenkin hyvän ohjelman tulisi olla mahdollisimman helppolukuinen ja
1. C-kieli yleiskäyttöinen ohjelmointikieli, standardoitu 1990. siirrettävä laiteläheinen pieni ydin, monimutkaiset kokonaisuudet rakennetaan aliohjelmakirjastojen avulla. direktiivit ja esikääntäjien
LisätiedotJava-kielen perusteet
Java-kielen perusteet Tunnus, varattu sana, kommentti Muuttuja, alkeistietotyyppi, merkkijono, Vakio Tiedon merkkipohjainen tulostaminen Ohjelmointi (ict1tx006) Tunnus (5.3) Javan tunnus Java-kirjain Java-numero
LisätiedotOhjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 9.2.2009 T-106.1208 Ohjelmoinnin perusteet Y 9.2.2009 1 / 35 Listat Esimerkki: halutaan kirjoittaa ohjelma, joka lukee käyttäjältä 30 lämpötilaa. Kun lämpötilat
LisätiedotTietueet. Tietueiden määrittely
Tietueet Tietueiden määrittely Tietue on tietorakenne, joka kokoaa yhteen eri tyyppistä tietoa yhdeksi asiakokonaisuudeksi. Tähän kokonaisuuteen voidaan viitata yhteisellä nimellä. Auttaa ohjelmoijaa järjestelemään
LisätiedotTiedosto on yhteenkuuluvien tietojen joukko, joka tavallisimmin sijaitsee kiintolevyllä, muistitikulla tai jollakin muulla fyysisellä tietovälineellä.
Tiedostot Tiedosto on yhteenkuuluvien tietojen joukko, joka tavallisimmin sijaitsee kiintolevyllä, muistitikulla tai jollakin muulla fyysisellä tietovälineellä. C-kielessä syöttö ja tulostus kuvataan laiteriippumattomasti
LisätiedotPerusteet. Pasi Sarolahti Aalto University School of Electrical Engineering. C-ohjelmointi Kevät Pasi Sarolahti
C! Perusteet 19.1.2015 Työkaluista Perinteinen: komentorivi + tekstieditori Editori: esimerkiksi Kate, Notepad++, Aquamacs (Emacs) Ohjelman kääntäminen ja suorittaminen komentoriviterminaalissa TMC - komentorivityökalu
LisätiedotOsoitin ja viittaus C++:ssa
Osoitin ja viittaus C++:ssa Osoitin yksinkertaiseen tietotyyppiin Osoitin on muuttuja, joka sisältää jonkin toisen samantyyppisen muuttujan osoitteen. Ohessa on esimerkkiohjelma, jossa määritellään kokonaislukumuuttuja
LisätiedotPerusteet. Pasi Sarolahti Aalto University School of Electrical Engineering. C-ohjelmointi Kevät Pasi Sarolahti
C! Perusteet 19.1.2017 Palautteesta (1. kierros toistaiseksi) (Erittäin) helppoa Miksi vain puolet pisteistä? Vaikeinta oli ohjelmointiympäristön asennus ja käyttö Ei selvää että main funktion pitikin
LisätiedotJava-kielen perusteita
Java-kielen perusteita Käyttäjän kanssa keskusteleva ohjelma 1 Kirjoittaminen konsolinäkymään //Java ohjelma, joka tulostaa konsoli-ikkunaan public class HeiMaailma { public void aja() { // kirjoitus ja
LisätiedotC-ohjelmointi: Osoittimet
C-ohjelmointi: Osoittimet Liisa Marttinen & Tiina Niklander 22.2.2005 Muistinhallinta Java vs C Luokka on viittaustyypin määritelmä ja olio on viittaustyypin ilmentymä Muistinhallinta on implisiittistä.
LisätiedotJava-kielen perusteet
Java-kielen perusteet String-merkkijonoluokka 1 Ohjelmointikielten merkkijonot Merkkijonot ja niiden käsittely on välttämätöntä ohjelmoinnissa Valitettavasti ohjelmointikielten tekijät eivät tätä ole ottaneet
Lisätiedot815338A Ohjelmointikielten periaatteet 2015-2016. Harjoitus 5 Vastaukset
815338A Ohjelmointikielten periaatteet 2015-2016. Harjoitus 5 Vastaukset Harjoituksen aiheena ovat aliohjelmat ja abstraktit tietotyypit sekä olio-ohjelmointi. Tehtävät tehdään C-, C++- ja Java-kielillä.
Lisätiedot2. Lisää Java-ohjelmoinnin alkeita. Muuttuja ja viittausmuuttuja (1/4) Muuttuja ja viittausmuuttuja (2/4)
2. Lisää Java-ohjelmoinnin alkeita Muuttuja ja viittausmuuttuja Vakio ja literaalivakio Sijoituslause Syötteen lukeminen ja Scanner-luokka 1 Muuttuja ja viittausmuuttuja (1/4) Edellä mainittiin, että String-tietotyyppi
LisätiedotC-ohjelmointi Luento 5: Osoittimet Tiina Niklander
C-ohjelmointi Luento 5: Osoittimet 14.2.2006 Tiina Niklander Sisält ltö umuistin rakenteesta uoperaatiot ja void-tyyppi umuistinhallinta varaus, vapautus uosoitinaritmetiikka ja muistilohkon käsittely
LisätiedotPerusteet. Pasi Sarolahti Aalto University School of Electrical Engineering. C-ohjelmointi Kevät Pasi Sarolahti
C! Perusteet 19.1.2017 Palautteesta (1. kierros toistaiseksi) Toistaiseksi helppoa Miksi vain puolet pisteistä? Vaikeinta oli ohjelmointiympäristön asennus ja käyttö Vaikeaa eroavuudet Pythonin ja C:n
LisätiedotHarjoitus 6 (viikko 42)
Nämä ovat kurssin viimeiset harjoitukset. Hyväksytyistä ratkaisuista ja läsnäoloista kerättyjen pisteiden summan tulee olla vähintään 40 % ( pistettä) tehtävien ja läsnäolopisteiden kokonaislukumäärien
Lisätiedot// Tulostetaan double-tyyppiseen muuttujaan "hinta" tallennettu // kertalipun hinta ja vaihdetaan riviä. System.out.printf("%.1f euros.
Lue kukin tehtävänanto huolellisesti ja kokonaisuudessaan ennen kuin aloitat vastaamisen. Kustakin tehtävästä voi saada 0 6 pistettä. Tentin läpipääsyraja on 12 / 24 pistettä. Ratkaisut palautetaan WETO-järjestelmään
LisätiedotC-ohjelmointi Luento 5: Osoittimet
C-ohjelmointi Luento 5: Osoittimet 19.9.2006 Sisält ltö umuistin rakenteesta uoperaatiot ja void-tyyppi umuistinhallinta varaus, vapautus uosoitinaritmetiikka ja muistilohkon käsittely uosoittimet ja funktiot
LisätiedotOsoittimet ja taulukot
C! ja taulukot 1.2.2018 Tiedotteita Tämän jälkeen taas pari väliviikkoa (tenttiviikko) Seuraava luento 22.2. Laskareita ei tenttiviikolla 12.2. 16.2. 2 ja muisti Muisti Keskusyksikkö Suorittaa muistissa
LisätiedotHarjoitus 6. Käytä String-luokasta vain charat- ja length-operaatioita.
Nämä ovat kurssin viimeiset harjoitukset. Hyväksytyistä ratkaisuista ja läsnäoloista kerättyjen pisteiden summan tulee olla vähintään 40 % ( pistettä) tehtävien ja läsnäolopisteiden kokonaislukumäärien
LisätiedotTaulukot. Taulukon määrittely ja käyttö. Taulukko metodin parametrina. Taulukon sisällön kopiointi toiseen taulukkoon. Taulukon lajittelu
Taulukot Taulukon määrittely ja käyttö Taulukko metodin parametrina Taulukon sisällön kopiointi toiseen taulukkoon Taulukon lajittelu esimerkki 2-ulottoisesta taulukosta 1 Mikä on taulukko? Taulukko on
LisätiedotHarjoitustyö: virtuaalikone
Harjoitustyö: virtuaalikone Toteuta alla kuvattu virtuaalikone yksinkertaiselle olio-orientoituneelle skriptauskielelle. Paketissa on testaamista varten mukana kaksi lyhyttä ohjelmaa. Ohjeita Noudata ohjelman
LisätiedotKirjoita oma versio funktioista strcpy ja strcat, jotka saavat parametrinaan kaksi merkkiosoitinta.
Tehtävä 63. Kirjoita oma versio funktiosta strcmp(),joka saa parametrinaan kaksi merkkiosoitinta. Tee ohjelma, jossa luetaan kaksi merkkijonoa, joita sitten verrataan ko. funktiolla. Tehtävä 64. Kirjoita
Lisätiedot1.3Lohkorakenne muodostetaan käyttämällä a) puolipistettä b) aaltosulkeita c) BEGIN ja END lausekkeita d) sisennystä
OULUN YLIOPISTO Tietojenkäsittelytieteiden laitos Johdatus ohjelmointiin 81122P (4 ov.) 30.5.2005 Ohjelmointikieli on Java. Tentissä saa olla materiaali mukana. Tenttitulokset julkaistaan aikaisintaan
LisätiedotMetodien tekeminen Javalla
1 Metodien tekeminen Javalla Mikä metodi on? Metodin syntaksi Metodi ja sen kutsuminen Parametreista Merkkijonot ja metodi Taulukot ja metodi 1 Mikä metodi on? Metodilla toteutetaan luokkaan toiminnallisuutta.
LisätiedotOhjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 2.3.2009 T-106.1208 Ohjelmoinnin perusteet Y 2.3.2009 1 / 28 Puhelinluettelo, koodi def lue_puhelinnumerot(): print "Anna lisattavat nimet ja numerot." print
Lisätiedotint puts(char *buff) Kirjoittaa puskurissa buff \0 :lla päätetyn merkkijonon standarditulostukseen. Formatoitu konsoli-i/o Tiedostot
1. Standardikirjasto Ohjelmankehitysympäristössä on joukko kirjastoituja funktioita. on joukko otsikkotiedostoja, joissa on kirjastofunktioiden prototyypit (esittelyt) ja tarvittavien vakioiden, tietotyyppien
LisätiedotJavan perusteet. Ohjelman tehtävät: tietojen syöttö, lukeminen prosessointi, halutun informaation tulostaminen tulostus tiedon varastointi
1 Javan perusteet Ohjelmointi IPO-malli Java lähdekoodista suoritettavaksi ohjelmaksi Vakio Muuttuja Miten Javalla näytetään tietoa käyttäjälle, miten Javalla luetaan käyttäjän antama syöte Miten Javalla
LisätiedotSisältö. 2. Taulukot. Yleistä. Yleistä
Sisältö 2. Taulukot Yleistä. Esittely ja luominen. Alkioiden käsittely. Kaksiulotteinen taulukko. Taulukko operaation parametrina. Taulukko ja HelloWorld-ohjelma. Taulukko paluuarvona. 2.1 2.2 Yleistä
LisätiedotKoottu lause; { ja } -merkkien väliin kirjoitetut lauseet muodostavat lohkon, jonka sisällä lauseet suoritetaan peräkkäin.
2. Ohjausrakenteet Ohjausrakenteiden avulla ohjataan ohjelman suoritusta. peräkkäisyys valinta toisto Koottu lause; { ja } -merkkien väliin kirjoitetut lauseet muodostavat lohkon, jonka sisällä lauseet
Lisätiedot// Tulostetaan double-tyyppiseen muuttujaan "hinta" tallennettu // kertalipun hinta ja vaihdetaan riviä. System.out.printf("%.1f euros.
Lue kukin tehtävänanto huolellisesti ja kokonaisuudessaan ennen kuin aloitat vastaamisen. Kustakin tehtävästä voi saada 0 6 pistettä. Tentin läpipääsyraja on 12 / 24 pistettä. Ratkaisut palautetaan WETO-järjestelmään
Lisätiedot#include <stdio.h> // io-toiminnot. //#define KM_MAILISSA int main( ){
demo1.c 30/09/15 08:19 #include // io-toiminnot //#define KM_MAILISSA 1.609 int main( ){ double mailit = 0.0; double kilometrit; const double KM_MAILISSA = 1.609; printf("anna maililukema > ");
LisätiedotOhjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 25.2.2009 T-106.1208 Ohjelmoinnin perusteet Y 25.2.2009 1 / 34 Syötteessä useita lukuja samalla rivillä Seuraavassa esimerkissä käyttäjä antaa useita lukuja samalla
LisätiedotHarjoitus 3 (viikko 39)
Mikäli tehtävissä on jotain epäselvää, laita sähköpostia vastuuopettajalle (jorma.laurikkala@uta.fi). Muista nimetä muuttujat hyvin sekä kommentoida ja sisentää koodisi. Vältä liian pitkiä rivejä. Ohjelmointitehtävien
LisätiedotITKP102 Ohjelmointi 1 (6 op)
ITKP102 Ohjelmointi 1 (6 op) Tentaattori: Antti-Jussi Lakanen 22. huhtikuuta 2016 Vastaa kaikkiin tehtäviin. Tee jokainen tehtävä erilliselle konseptiarkille! Kirjoittamasi luokat, funktiot ja aliohjelmat
LisätiedotOhjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 20.1.2010 T-106.1208 Ohjelmoinnin perusteet Y 20.1.2010 1 / 40 Arvon pyytäminen käyttäjältä Käyttäjän antaman arvon voi lukea raw_input-käskyllä. Käskyn sulkujen
LisätiedotOhjausrakenteet. Valinta:
Ohjausrakenteet Luento antaa yleiskuvan siitä kuinka ohjelmassa suorittaan vaihtoehtoisia tehtäviä valintarakenteiden avulla ja kuinka samanlaisia ohjelma-askeleita toistetaan toistorakenteiden avulla
LisätiedotTietojen syöttäminen ohjelmalle. Tietojen syöttäminen ohjelmalle Scanner-luokan avulla
Tietojen syöttäminen ohjelmalle Tähän mennessä on käsitelty Javan tulostuslauseet System.out.print ja System.out.println sekä ohjelman perusrakenneosat (muuttujat, vakiot, lauseet). Jotta päästään tekemään
LisätiedotModuli 2: Osoittimet ja taulukot. Joel Huttunen
: Osoittimet ja taulukot 26.1.2016 Moduli 1 yhteenvetoa laskuharjoituksista (PS: palautteen saa jättää myös suomeksi jos haluaa) Ongelmia ympäristön asennuksessa Hoitakaa kuntoon ajoissa, niin loppukurssilla
LisätiedotListarakenne (ArrayList-luokka)
Listarakenne (ArrayList-luokka) Mikä on lista? Listan määrittely ArrayList-luokan metodeita Listan läpikäynti Listan läpikäynti indeksin avulla Listan läpikäynti iteraattorin avulla Listaan lisääminen
LisätiedotJohdatus ohjelmointiin / Lausekielinen ohjelmointi 1 & 2
Johdatus ohjelmointiin / Lausekielinen ohjelmointi 1 & 2 Syntaksilomake (22.4.2007) C-kielen standardikirjaston funktioita gets(merkkijono); scanf("formaatti", &muuttuja1,..., &muuttujan); sscanf(merkkijono,
Lisätiedot1.1 Pino (stack) Koodiluonnos. Graafinen esitys ...
1. Tietorakenteet Tietorakenteet organisoivat samankaltaisten olioiden muodostaman tietojoukon. Tämä järjestys voidaan saada aikaan monin tavoin, esim. Keräämällä oliot taulukkoon. Liittämällä olioihin
LisätiedotOhjelmointi 1 Taulukot ja merkkijonot
Ohjelmointi 1 Taulukot ja merkkijonot Jussi Pohjolainen TAMK Tieto- ja viestintäteknologia Johdanto taulukkoon Jos ohjelmassa käytössä ainoastaan perinteisiä (yksinkertaisia) muuttujia, ohjelmien teko
LisätiedotOhjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 7.2.2011 T-106.1208 Ohjelmoinnin perusteet Y 7.2.2011 1 / 39 Kännykkäpalautetteen antajia kaivataan edelleen! Ilmoittaudu mukaan lähettämällä ilmainen tekstiviesti
LisätiedotSisältö. 22. Taulukot. Yleistä. Yleistä
Sisältö 22. Taulukot Yleistä. Esittely ja luominen. Alkioiden käsittely. Kaksiulotteinen taulukko. Taulukko metodin parametrina. Taulukko ja HelloWorld-ohjelma. Taulukko paluuarvona. 22.1 22.2 Yleistä
LisätiedotYleistä. Nyt käsitellään vain taulukko (array), joka on saman tyyppisten muuttujien eli alkioiden (element) kokoelma.
2. Taulukot 2.1 Sisältö Yleistä. Esittely ja luominen. Alkioiden käsittely. Kaksiulotteinen taulukko. Taulukko operaation parametrina. Taulukko ja HelloWorld-ohjelma. Taulukko paluuarvona. 2.2 Yleistä
LisätiedotOhjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 16.2.2010 T-106.1208 Ohjelmoinnin perusteet Y 16.2.2010 1 / 41 Kännykkäpalautetteen antajia kaivataan edelleen! Ilmoittaudu mukaan lähettämällä ilmainen tekstiviesti
LisätiedotModuli 4: Moniulotteiset taulukot & Bittioperaatiot
C! : Moniulotteiset taulukot & Bittioperaatiot 15.3.2016 Agenda Pieni kertausharjoitus Moniulotteiset taulukot Esimerkki taulukoista Tauko (bittitehtävä) Binäärioperaatioista Esimerkki (vilkaistaan IP
LisätiedotHarjoitus 2 (viikko 45)
Mikäli tehtävissä on jotain epäselvää, laita sähköpostia vastuuopettajalle (jorma.laurikkala@uta.fi). Muista lisätä static-määre operaatioidesi otsikoihin, jotta ohjelmasi kääntyvät. Muista noudattaa hyvän
LisätiedotHarjoitus 1 (viikko 44)
Mikäli tehtävissä on jotain epäselvää, laita sähköpostia vastuuopettajalle (jorma.laurikkala@uta.fi). Muista lisätä static-määre operaatioidesi otsikoihin, jotta ohjelmasi kääntyvät. Muista noudattaa hyvän
Lisätiedot13 Operaattoreiden ylimäärittelyjä
248 13 C++-kielessä voidaan operaattoreita ylimäärittää. Ylimääriteltävää operaattoria voidaan pitää ikäänkuin metodina, joka esitellään luokan esittelyssä ja määritellään luokan ulkopuolella kuten metoditkin.
LisätiedotModulaarisessa ohjelmoinnissa jaetaan ohjelma osiin (moduuleihin), jotka ovat yksinkertaisia ja lyhyitä.
3. Funktiot Modulaarisessa ohjelmoinnissa jaetaan ohjelma osiin (moduuleihin), jotka ovat yksinkertaisia ja lyhyitä. Modulaarisuudella pyritään parantamaan ohjelman ymmärrettävyyttä, testattavuutta sekä
LisätiedotTaulukot. Jukka Harju, Jukka Juslin 2006 1
Taulukot Jukka Harju, Jukka Juslin 2006 1 Taulukot Taulukot ovat olioita, jotka auttavat organisoimaan suuria määriä tietoa. Käsittelylistalla on: Taulukon tekeminen ja käyttö Rajojen tarkastus ja kapasiteetti
LisätiedotOhjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 28.2.2011 T-106.1208 Ohjelmoinnin perusteet Y 28.2.2011 1 / 46 Ohjelmointiprojektin vaiheet 1. Määrittely 2. Ohjelman suunnittelu (ohjelman rakenne ja ohjelman
LisätiedotOhjelmoinnin peruskurssi Y1
Ohjelmoinnin peruskurssi Y1 CS-A1111 12.9.2018 CS-A1111 Ohjelmoinnin peruskurssi Y1 12.9.2018 1 / 19 Oppimistavoitteet: tämän luennon jälkeen osaat kirjoittaa Python-ohjelman, joka pyytää käyttäjältä lukuja,
Lisätiedot