Megoldott programozási feladatok standard C-ben
|
|
- Alexandra Hajdu
- 9 évvel ezelőtt
- Látták:
Átírás
1 Megoldott programozási feladatok standard C-ben MÁRTON Gyöngyvér Sapientia Erdélyi Magyar Tudományegyetem, Matematika-Informatika Tanszék Marosvásárhely, Románia
2
3 Tartalomjegyzék 1. Bevezető feladatok 3 2. Feltételes utasítások Az if utasítás A switch utasítás Ciklus utasítások A while utasítas A for utasítas Bit műveletek Tömbök Egydimenziós tömbök Kétdimenziós tömbök Rekurzió 37 1
4 2 TARTALOMJEGYZÉK
5 1. fejezet Bevezető feladatok 1.1. Feladat. Egysoros szöveg kiírása, képernyőre. printf("helo vilag\n"); 1.2. Feladat. Képernyőre való kiíratás, táblázatos formában. printf("januar\tfebruar\tmarcius\n"); printf("2005\t2003\t2001\n"); printf("1999\t2001\t1989\n\n"); 1.3. Feladat. Egysoros szöveg kiírása, állományba. FILE *f; f = fopen("ki.txt","w"); fprintf(f,"helo vilag\n"); 3
6 4 FEJEZET 1. BEVEZETŐ FELADATOK fclose(f); 1.4. Feladat. Állományba való kiíratás, táblázatos formában. FILE *f; f = fopen("ki.txt","w"); fprintf(f,"januar\tfebruar\tmarcius\n"); fprintf(f,"2005\t2003\t2001\n"); fprintf(f,"1999\t2001\t1989\n"); fclose(f); 1.5. Feladat. Megjegyzések használata. printf("ez megjelenik a kepernyon\n"); //printf("ez nem jelenik meg a kepernyon\n"); printf("ez megint megjelenik a kepernyon\n"); /* ez egy tobb sorbol allo megjegzes nem fog megjelenni a kepernyon a programozo utolagos eligazodasara szolgall */ 1.6. Feladat. Szorzás. int x; //valtozo deklaralas x = 25; //valtozo ertekadasa
7 5 printf("%i\n",x*x); //kepernyore valo kiiratas 1.7. Feladat. Az osztási hányados meghatározása. int x; x = 10; printf("%i\n",x/3); //az eredmeny az osztas egesz resze 1.8. Feladat. Osztás, az eredmény egy valós szám int x; x = 10; printf("%.3f\n",(float)x/3); 1.9. Feladat. Az osztási maradék meghatározása. int x; x = 10; //maradekos osztas printf("%i\n",x%3); //az eredmeny ugyanaz, csak mas formazasi jelet hasznalunk printf("%i\n",x%3); Feladat. Aritmetikai műveletek.
8 6 FEJEZET 1. BEVEZETŐ FELADATOK int i; i = 2; printf("egesz tipusu valtozo: %i\n", i); // a valtozo erteket noveljuk 4-el i = i + 4; printf("az eredmeny: %i\n",i); // a valtozo erteket noveljuk 1-el i++; printf("az eredmeny: %i\n",i); // a valtozo erteket noveljuk 2-vel i += 2; printf("az eredmeny: %i\n",i); // a valtozo erteket szorozzuk 3-al i *= 3; printf("az eredmeny: %i\n",i); Feladat. Két változó értékének a felcserélése. int a,b,seged; a = 12; b = -12; printf("csere elott a szamok:\n\t%i %i\n",a,b); // elso modszer: seged = a; a = b; b = seged; printf("elso csere utan a szamok:\n\t%i %i\n",a,b); // masodik modszer a = a - b; b = a + b; a = b - a; printf("masodik csere utan a szamok:\n\t%i %i\n",a,b);
9 Feladat. Egész típus. int a, b, ered; printf("kerek egy egesz szamot:"); scanf("%i",&a); printf("kerek egy egesz szamot:"); scanf("%i",&b); printf("\n"); ered = a + b; printf("az osszeg:"); printf("%i", ered); printf("\n\n"); 1.1. Megjegyzés. Az int a; változó deklarálásakor az a azonosítóval a változó értékére tudunk hivatkozni, a &a azonosítóval a változó memória címére tudunk hivatkozni Megjegyzés. A scanf könyvtárfüggvény használatakor a változó memória címét használjuk, kivéve ha karakterlánc típusú változónak adunk értéket Feladat. Karakter típus. char a; printf("kerek egy karaktert:"); scanf("%c",&a); printf("a karakter es az ASCII kodja\n"); printf("%c\t%i",a,a); printf("\n");
10 8 FEJEZET 1. BEVEZETŐ FELADATOK Feladat. Karakterlánc típus. char szoveg[20]; printf("kerek egy szoveget"); scanf("%s",szoveg); printf("%s",szoveg); printf("\n"); Feladat. Valós típus, float. float a, b; ered1 = 0; printf("kerek egy valos szamot:"); scanf("%f",&a); printf("kerek egy valos szamot:"); scanf("%f",&b); printf("\n"); a = a * b; // a beolvasott erteket felulirjuk printf("%20s","a szorzat:"); printf("%8.2f\n", a); Feladat. Valós típus, double. double f1,f2,f3,f4; printf("\n\nkerek egy valos szamot:"); scanf("%lf",&f1); printf("kerek egy valos szamot:"); scanf("%lf",&f2);
11 9 printf("kerek egy valos szamot:"); scanf("%lf",&f3); printf("kerek egy valos szamot:"); scanf("%lf",&f4); printf("a szamok atlaga: "); printf("%6.3lf\n",(f1+f2+f3+f4)/4 ); Feladat. A sizeof operátor alkalmazása printf("karakter tipus -byte szama:: "); printf("%i\n",sizeof(char)); printf("egesz tipus -byte szama:: "); printf("%i\n",sizeof(int)); printf("valos tipus -byte szam:: "); printf("%i\n",sizeof(float)); printf("hosszu valos -tipus byte szama:: "); printf("%i\n",sizeof(double)); Feladat. Típuskonverzió int a,b; printf("kerek egy egesz szamot:"); scanf("%i",&a); printf("kerek egy egesz szamot:"); scanf("%i",&b); printf("\n"); printf("%20s%8d\n","az egesz osztas:", a / b); /* az a valtozot valos szamma alakitom, csak igy kapom meg a valós osztás eredményét */
12 10 FEJEZET 1. BEVEZETŐ FELADATOK printf("%20s%8.2f\n\n","a valos osztas:", (float)a / b); Feladat. Számrendszerek: tízes, nyolcas, tizenhatos. char c; int i; float f; printf("kerek egy karakter:"); scanf("%c",&c); printf("a karkter erteke:\t\t%c\n",c); printf("a karakter kodja:\t\t%i\n",c); printf("a karakter kodja oktalisan:\t%o\n",c); printf("a karakter kodja hexaban:\t%x\n",c); printf("\n\nkerek egy egesz szamot:"); scanf("%i",&i); printf("az egesz szam tizedeskent:\t%i\n",i); printf("az egesz szam tizedeskent:\t%i\n",i); printf("az egesz szam oktalisan:\t%o\n",i); printf("az egesz szam hexaban:\t\t%x\n",i); printf("\n\nkerek egy valos szamot:"); scanf("%f",&f); printf("a valos szam erteke:\t\t%7.3f\n",f);
13 2. fejezet Feltételes utasítások 2.1. Az if utasítás 2.1. Feladat. Páros vagy páratlan számot olvastunk be? int szam; printf("egesz szam:"); scanf("%i",&szam); if( szam%2 == 0) printf("a szam paros\n"); else printf("a szam paratlan\n"); 2.2. Feladat. Milyen karaktert olvastunk be? char c1; int mas = 1; printf("karakter:"); scanf("%c",&c1); if( c1 >= a && c1 <= z ) printf("kisbetut olvastal be\n"); 11
14 12 FEJEZET 2. FELTÉTELES UTASÍTÁSOK if( c1 >= A && c1 <= Z ) printf("nagy betut olvastal be\n"); if( c1 >= 0 && c1 <= 9 ) printf("szamjegyet olvastal be\n"); printf("nem angol ABC-beli betut es nem is szamjegyet olvastal be\n"); 2.3. Feladat. Másodfokú egyenlet megoldása. #include <math.h> int a, b, c; float ered1,ered2,delta; printf("a:"); scanf("%i",&a); printf("b:"); scanf("%i",&b); printf("c:"); scanf("%i",&c); if(a == 0) //a sajatos esetek meghatarozasa if(b!= 0 && c!= 0) ered1 = -(float)c/b; printf("az eredmeny:%5.2f\n",ered1); if(c == 0 && b == 0) printf("vegtelen sok megoldas\n"); if(c!= 0 && b == 0) printf("nincs megoldas\n");
15 2.2. A SWITCH UTASÍTÁS 13 if(c == 0 && b!= 0) printf("az eredmeny:0\n"); else /* a negyzetgyok meghatarozasara hasznaljuk az sqrt beepietett konyvtarfuggvenyt */ delta = sqrt(b * b - 4 * a * c); if(delta < 0) printf("nincs valos megoldas\n"); else ered1 = (-b + delta) / 2; ered2 = (-b - delta) / 2; //a kiiratast 2 tizedesnyi pontosaggal vegezzuk printf("az eredmeny:%5.2f\n",ered1); printf("az eredmeny:%5.2f\n",ered2); 2.2. A switch utasítás 2.4. Feladat. Milyen műveleteket végezzünk? int c; int szam1, szam2, szam3; int ered; printf("0 Kilpes\n"); printf("1 Osszeadas\n"); printf("2 Szorzas\n"); printf("milyen muveleteket vegzunk a szamokon?"); scanf("%i",&c); if (c == 0) printf("elso szam:"); scanf("%i",&szam1); printf("masodik szam:");
16 14 FEJEZET 2. FELTÉTELES UTASÍTÁSOK scanf("%i",&szam2); printf("harmadik szam:"); scanf("%i",&szam3); switch(c) case 1 : ered = 0; ered += szam1; ered += szam2; ered += szam3; printf("osszeadas\n"); printf("az eredmeny:%i\n\n\n",ered); break; case 2: ered = 1; ered *= szam1; ered *= szam2; ered *= szam3; printf("szorzas\n"); printf("az eredmeny:%i\n\n\n",ered); break;
17 3. fejezet Ciklus utasítások 3.1. A while utasítas 3.1. Feladat. Melyik ciklus gyorsabb? #include <stdlib.h> #include <time.h> #define N #define N int64 i; clock_t st; st = clock(); for(i=0; i<n1; i++); printf("%i64i\t", i); printf("time:%.3lf\n",(clock()-st)/(double)clocks_per_sec); st = clock(); for(i=0; i<n2; ++i); printf("%i64i\t", i); printf("time:%.3lf\n",(clock()-st)/(double)clocks_per_sec); 15
18 16 FEJEZET 3. CIKLUS UTASÍTÁSOK 3.2. Feladat. Páros számok kiíratása adott n értékig. int i, k, n; printf("meddig::"); scanf("%i",&n); i = 0; k = 0; while(i < n) printf("%i ",k); k = k + 2; i++; printf("\n"); 3.3. Feladat. Adott szám számjegyeinek fordított sorrendjének a meghatározása. unsigned int szam, szamj; //elojel nelkuli egesz tipus deklaralasa printf("kerek egy szamot::"); scanf("%i",&szam); printf("\na szam szamjegyei forditott sorrendben:"); while(szam!= 0) szamj = szam % 10; printf("%i ", szamj); szam = szam / 10; 3.4. Feladat. Két szám legnagyobb közös osztójának a meghatározása, Euklideszi algoritmussal.
19 3.1. A WHILE UTASÍTAS 17 unsigned int a, b, r; printf("kerek egy egesz szamot:"); scanf("%i",&a); printf("kerek meg egy egesz szamot"); scanf("%i",&b); while ( b!= 0 ) r = a % b; a = b; b = r; printf("az lnko:%i\n",a); 3.5. Feladat. Határozzuk meg egy adott állományban levő számokra a számok négyzetgyökét. double negyzetgy(int x); FILE *f; double y = 1; int x; f = fopen("szamok.txt", "r"); while(1) fscanf(f,"%i", &x); if(feof(f)) break; y = negyzetgy(1, x); printf("%10i%10.2lf\n", x, y); fclose(f); double negyzetgy(int x)
20 18 FEJEZET 3. CIKLUS UTASÍTÁSOK double y = 1; while (y*y - x > x-y*y > ) y = (y + x/y) /2; return y; 3.6. Feladat. Határozzuk meg egy adott állományban levő x és y számpárokra az x y értékét, felhasználva a pow könyvtárfüggvényt. #include <math.h> FILE *f; double e; int x, y; f = fopen("szamok.txt", "r"); while(1) fscanf(f,"%i%i", &x, &y); if(feof(f)) break; e = pow(x, y); printf("%10i%10i%10.0lf\n", x, y, e); fclose(f); 3.2. A for utasítas 3.7. Feladat. Páros számok kiíratása adott n értékig. int i, n; printf("n:"); scanf("%i",&n); for(i = 0; i < n; i++)
21 3.2. A FOR UTASÍTAS 19 printf("%i\n",2*i); 3.8. Feladat. Billentyűzetről beolvasott számok átlagértékének a meghatározása. int i, n, ossz, szam; printf("n="); scanf("%i",&n); ossz = 0; for(i = 0; i < n; i++) printf("kerek egy szamot:"); scanf("%i",&szam); ossz += szam; printf("a szamok atlaga::%.2f\n",(float)ossz/n); 3.9. Feladat. Határozzuk meg a billentyűzetről beolvasott számok közül a pozitív számok számát, n szám esetében int i, n, db, szam; printf("n="); scanf("%d",&n); db = 0; for(i = 0; i < n; i++) printf("kerek egy szamot:"); scanf("%d",&szam); if (szam>0) db++; printf("a pozitiv szamok szama: %i\n",db);
22 20 FEJEZET 3. CIKLUS UTASÍTÁSOK Feladat. Válasszuk ki a billentyűzetről beolvasott számok közül a legnagyobbat. int i, n, max, szam; printf("n="); scanf("%i",&n); max = szam; printf("kerek egy szamot:"); scanf("%i",&szam); max = szam; //inicializalas for(i = 1; i < n; i++) printf("kerek egy szamot:"); scanf("%i",&szam); if (max < szam) max = szam; printf("a legnagyobb szam::%i\n",max); Feladat. Határozzuk meg a billentyűzetről beolvasott számok átlagértékét, n szám esetében int i, n, ossz, szam; printf("n="); scanf("%d",&n); ossz = 0; for(i = 0; i < n; i++) printf("kerek egy szamot:"); scanf("%d",&szam); ossz += szam;
23 3.2. A FOR UTASÍTAS 21 printf("a szamok atlaga::%.2f\n",(float)ossz/n); Feladat. Határozzuk meg a billentyűzetről beolvasott számok szorzatát, n szám esetében int i, n, szorzat, szam; printf("n="); scanf("%d",&n); szorzat = 0; for(i = 0; i < n; i++) printf("kerek egy szamot:"); scanf("%d",&szam); szorzat *= szam; printf("a szamok szorzata: %i\n",szorzat); Feladat. Írjuk ki az ASCII kódtáblát. int i; for(i = 0; i < 256; i++) printf("%c: %i\t", i, i); printf("\n\n"); Feladat. Vizsgáljuk meg egy számról, hogy prím szám-e, vagy sem.
24 22 FEJEZET 3. CIKLUS UTASÍTÁSOK int szam, ok, i; printf("kerek egy szamot:"); scanf("%i",&szam); ok = 1; if( szam ==2 ) printf("a szam prim\n"); else if( szam % 2 == 0) printf("a szam nem prim\n"); else for(i=3; i*i<=szam && ok ; i+=2) //eleg a paratlan osztokat vizsgalni if(szam % i == 0) printf("a szam nem prim\n"); ok = 0; if (ok) printf("a szam prim\n"); Feladat. Írjunk egy függvényt mely megvizsgálja hogy egy szám teljes négyzet-e vagy sem. int negyzetszam(int szam); main() int p, sz = 141; p = negyzetszam(sz); if(p == 1) printf("teljes negyzet\n"); else printf("nem teljes negyzet\n"); int negyzetszam(int szam) int i; for (i=1; i*i<=szam; i++) if (i*i == szam) return 1;
25 3.2. A FOR UTASÍTAS 23
26 24 FEJEZET 3. CIKLUS UTASÍTÁSOK
27 4. fejezet Bit műveletek 4.1. Feladat. A 0-ik bit 1-re állítása. unsigned int a=28; // 0x1c; printf("az OR muvelet bitteken:\n%x\n",a); a = a 0x1; printf("%x\n",a); 4.2. Feladat. Az 5-ik bitet 0-ra állítása. unsigned int a = 58; printf("\naz END muvelet bitteken:\n%x\n",a); a = a & 0x1f; printf("%x\n",a); 4.3. Feladat. Adott számérték titkosítása. 25
28 26 FEJEZET 4. BIT MŰVELETEK unsigned int a = 1994; printf("\ntitkositas kovetkezik, a XOR muvelettel:\n"); printf("a unsigned int:\t\t%x\n",a); a = a ^ 0xaaaa; printf("kodolva:\t%x\n",a); a = a ^ 0xaaaa; printf("dekodolva:\t%x\n",a); 4.4. Feladat. Két változó értékének a felcserélése unsigned int a, b; printf("\nszam1:"); scanf("%d",&a); printf("szam2:"); scanf("%d",&b); b = a ^ b; a = a ^ b; b = a ^ b; printf("\nszam1:%d",a); printf("\nszam2:%d",b); 4.5. Feladat. Egy szám kettes számrendszerbeli alakja. unsigned int a, b, i = 7; printf("kerem a szamot:"); scanf("%d",&a); while(i >= 0) b = (a >> i) & 1; printf("%i",b);
29 27 i--; 4.6. Feladat. Az unsigned int típus belső ábrázolásához szükséges bitek száma. unsigned int a = 1, sz = 0; //a szám belso abrazolasanak a negaltja a = ~a; while(a!= 0) a = a >> 1; sz++; printf("a gepszo hosszusaga:%d", sz);
30 28 FEJEZET 4. BIT MŰVELETEK
31 5. fejezet Tömbök 5.1. Egydimenziós tömbök 5.1. Feladat. Egy egydimenziós tömb elemeit inicializáljuk véletlenszerűen generált elemekkel, majd határozzuk meg az elemek összegét. #include <stdlib.h> #include <time.h> int n, tomb[50]; int i, ossz; srand(time(null)); printf("n:"); scanf("%d",&n); for(i = 0; i < n; i ++) tomb[i] = ( rand() % 100 ) - 50; printf("%d\t",tomb[i]); printf("\n"); ossz = 0; for(i = 0; i < n; i++) ossz += tomb[i]; printf("az osszeg: %d\n",ossz); 29
32 30 FEJEZET 5. TÖMBÖK 5.2. Feladat. Egy egydimenziós tömb elemeit inicializáljuk véletlenszerűen generált elemekkel, majd határozzuk meg a páros elemek indexét. #include <stdlib.h> #include <time.h> int n, tomb[50]; int i; srand(time(null)); printf("n:"); scanf("%d",&n); for(i = 0; i < n; i++) printf("%3d\t",i); printf("\n"); for(i = 0; i < n; i++) tomb[i] = ( rand() % 100 ) - 50; printf("%3d\t",tomb[i]); printf("\n\n"); printf("a paros elemek pozicioi:"); for( i = 0; i < n; i++) if(tomb[i]%2 == 0) printf("%d\t", i); printf("\n\n"); 5.3. Feladat. Határozzuk meg egy tömb elemeinek a szorzatát, ahol a tömb elemeit konstansként inicializáljuk. int n, tomb[] = 10, 8, 7, 6, 3; int i, szorzat; n = sizeof(tomb)/sizeof(tomb[0]); szorzat = 1; for(i=1; i<n; i++) szorzat *= tomb[i];
33 5.1. EGYDIMENZIÓS TÖMBÖK 31 printf("a szorzat: %i", szorzat); 5.4. Feladat. Határozzuk meg egy tömb elemeinek az átlagértékét, ahol a tömb elemeit konstansként inicializáljuk. int n, tomb[] = 10, 8, 7, 6, 3; int i, osszeg; n = sizeof(tomb)/sizeof(tomb[0]); osszeg = 0; for(i=0; i<n; i++) osszeg += tomb[i]; printf("az atlag: %.2f\n",(float)osszeg/n); 5.5. Feladat. Határozzuk meg egy tömb elemei közül a maximum elemet. int n, tomb[] = 10, 8, 7, 6, 3; int i, max; n = sizeof(tomb)/sizeof(tomb[0]); max = tomb[0]; for(i=0; i<n; i++) if(tomb[i]>max) max =tomb[i]; printf("maximum: %d\n",max); 5.6. Feladat. Vizsgáljuk meg, hogy egy tömb csak páros számokat tartalmaze vag sem. int csak_paros(int t [], int i);
34 32 FEJEZET 5. TÖMBÖK main() int t[]= 10,21,0,32,4,52; int n, v; n = sizeof(t)/sizeof(t[0]); v = csak_paros(t, n-1); if (v==1) printf("csak paros elemeket tartalmaz\n"); else printf("nem csak paros elemeket tartalmaz\n"); int csak_paros(int t[], int n) int i; for(i=0; i<n; i++) if (t[i]%2 == 1) return 1; 5.7. Feladat. Határozzuk meg egy szám kettes számrendszerbeli alakját, egy tömbbe. main() int i, k, tomb[100]; int szam = 18; k = 0; while(szam>0) tomb[k++] = szam%2; szam /=2; for(i=k-1; i>=0; i--) printf("%3i", tomb[i]); printf("\n"); 5.8. Feladat. Határozzuk meg egy szám valódi osztóit, előállítva őket egy tömbbe.
35 5.1. EGYDIMENZIÓS TÖMBÖK 33 main() int szam, k, i, tomb[100]; printf("szam:"); scanf("%i", &szam); k = 0; for(i = 2; i<=szam/2; i++) if(szam%i == 0) tomb[k++] = i; for(i=0; i<k; i++) printf("%4i", tomb[i]); printf("\n"); 5.9. Feladat. Hozzunk létre egy n elemű tömböt, mely tartalmazza az első n prím számot. #include <math.h> int n, tomb[10000]; int i, szam, prim, j; printf("n:"); scanf("%d",&n); tomb[0] = 2; i = 1; szam = 3; while( i<n ) prim = 1; for( j = 3; j <= sqrt(szam) && prim; j += 2) if ( szam % j == 0 ) prim = 0; if ( prim ) tomb[i] = szam; i++; szam += 2; for(i = 0; i < n; i++)
36 34 FEJEZET 5. TÖMBÖK printf("%d\t",tomb[i]); printf("\n\n"); Feladat. Adott egy egész szám. Töltsünk fel egy tömböt a szám számjegyeivel. //64 bitten tarolt szam int64 szam; int i, n, tomb[100]; printf("szam:"); scanf("%i64i", &szam); n = 0; while (szam!= 0 ) tomb[n] = szam % 10 ; n++; szam = szam / 10; //a tomb elemeit forditott sorrendbe irjuk ki for ( i = n-1; i >= 0; i--) printf("%d ", tomb[i]); printf("\n\n"); Feladat. Olvassunk be egy karakterláncot a billentyűzetről és készítsünk karakter előfordulási statisztikát. char tomb[20]; int i, stat[256]; printf("karakterlanc:"); scanf("%s", tomb); for(i = 0; i < 256; i++) stat[i] = 0;
37 5.2. KÉTDIMENZIÓS TÖMBÖK 35 for(i = 0; tomb[i]!= \0 ; i++) stat[ tomb[i] ]++; for(i = 0; i < 256; i++) if( stat[i]!= 0) printf("%c:: %d\n", i, stat[i]); printf("\n\n"); 5.2. Kétdimenziós tömbök Feladat. Adott egy n*n-es mátrix, melynek elemeit véletlenszerű egész számokkal töltsük fel. Írjuk ki a mátrixot táblázatos formában majd határozzuk meg a mátrix legkisebb elemét és ezen elem sor és oszlop értékét #include <stdlib.h> #include <time.h> int n, mat[10][10]; int i, j, max, m, mi, mj; printf("n: "); scanf("%d", &n); printf("m: "); scanf("%d", &m); if (n >= 10 m >= 10 ) //hibakezeles printf("error:: beolvasott ertek >= 10 \n"); exit(1); srand(time(null)); for(i = 0; i < n; i++) for(j = 0; j < m; j++) //vegig megyunk az osszes oszlopbeli elemen mat[i][j] = rand() % 100; //ertekadas printf("%3d", mat[i][j]); //kiiratas printf("\n"); //ujsorba megyunk ha kiirtuk a matrix egy adott sorat
38 36 FEJEZET 5. TÖMBÖK max = mat[0][0]; mi = 0; mj = 0; for(i = 0; i < n; i++) for(j = 0; j < m; j++) if( mat[i][j] > max ) max = mat[i][j]; mi = i; mj = j; printf("\na maximum elem: %d", max); printf("\na maximum elem pozicioi: %d, %d", mi + 1, mj + 1); printf("\n\n");
39 6. fejezet Rekurzió 6.1. Feladat. Határozzuk meg egy adott n szám faktoriálisát. int fakt(int szam); main() int szam = 5; int m; m = fakt(szam); printf("faktorialis: %i\n", m); int fakt(int n) int t; if (n == 0) return 1; t = fakt(n-1); return n * t; 6.2. Feladat. Határozzuk meg egy adott szám számjegyeinek az összegét. int szamj(int szam); 37
40 38 FEJEZET 6. REKURZIÓ main() int szam = 12345; int m; m = szamj(szam); printf("osszeg: %i\n", m); int szamj(int szam) int t; if (szam <= 0) t = szamj1(szam/10); return (szam%10) + t; 6.3. Feladat. Határozzuk meg egy tömb elemének a maximum elemét. int mmax(int t[], int n); main() int t [] = 1034, 6, 912, 356, 11, 8, 99; int n = sizeof(t)/sizeof(t[0]); int m; m = mmax (t,n-1); printf("maximum: %i\n", m); int mmax(int t[], int n) int m; if (n == 0) return t[0]; m = mmax(t, n-1); if (m < t[n]) return t[n]; else return m; 6.4. Feladat. Vizsgáljuk meg, hogy egy tömb elemei csak párosak-e vagy sem.
41 39 int csak_paros(int t [], int i); main() int t[]= 10,2,0,32,4,52; int n, v; n = sizeof(t)/sizeof(t[0]); v = csak_paros(t, n-1); if (v == 1) printf("csak paros elemeket tartalmaz\n"); else printf("nem csak paros elemeket tartalmaz\n"); int csak_paros (int t[], int n) if (n < 0) return 1; if (t[n]%2 == 1) csak_paros(t, n-1); 6.5. Feladat. Határozzuk meg két szám legnagyobb közös osztóját, Euklideszi algoritmussal, rekurzívan. int lnko(int a, int b) if (b == 0) return a; return lnko(b, a%b); main() printf("%i", lnko(48,102)); 6.6. Feladat. Írjuk ki 2 hatványait egy megadott n számig. int rec(int sz, int n); int n = 10;
42 40 FEJEZET 6. REKURZIÓ rec(1, n); int rec(int sz, int n) if(n<0) printf("%i\n", sz); rec(sz*2, n-1); 6.7. Feladat. Határozzuk meg egy szám kettes számrendszerbeli alakját, rekurzívan. int kettes(int szam); int sz = 18; kettes(sz); printf("\n"); int kettes(int szam) if(szam<=0) kettes(szam/2); printf("%3i",szam%2); 6.8. Feladat. Határozzuk meg egy szám négyzetgyökét. double negyzetgy(double y, int x); double y; int x = 16; y = negyzetgy(y, x); printf("%10i%10.2lf\n", x, y);
43 41 double negyzetgy(double y, int x) y = (y+ x/y)/2; if(y*y-x < && x-y*y < ) return y; return negyzetgy(y,x);
44 Tárgymutató átlag érték, 19 a sizeof operátor, 9 AND, 25 aritmetikai műveletek, 5 ASCII kód tábla, 21 char, 7 ciklus, 15 comment, 4 double, 8 egész részes osztás, 5 egész számok, 7 egydimenziós tömbök, 29 Euklideszi algoritmus, 16 float, 8 for, 18 if, 11 int, 7 negáció, 27 OR, 25 osztás, 5 páros számok, 16, 18 prím szám, 21 rand, 29 switch, 13 szám számjegyei, 16 szorzás, 4 tömbök, 29 tipus konverzió, 9 válotozó csere, 6 valós típus, 8 while, 15 XOR, 25 két dimenziós tömbök, 35 karakter típus, 42 kettes számrendszerbeli alak, 26 másodfokú egyenlet, 12 maradékos osztás, 5 maximum, 20 megjegyzés, 4 memória cím, 7 42
Megoldott programozási feladatok standard C-ben
Megoldott programozási feladatok standard C-ben Márton Gyöngyvér Műszaki és Humántudományok Kar EMTE-Sapientia, Marosvásárhely 2008. december 14. 1. fejezet Megoldott feladatok 1.1. Alap algoritmusok 1.1.
C programozás. { Márton Gyöngyvér, 2009 } { Sapientia, Erdélyi Magyar Tudományegyetem }
C programozás Márton Gyöngyvér, 2009 Sapientia, Erdélyi Magyar Tudományegyetem http://www.ms.sapientia.ro/~mgyongyi 1 Ciklusok for (ismétlés) while do while 2 for utasítás szöveg 10-szeri kiíratása: int
C programozás. { Márton Gyöngyvér, 2009 } { Sapientia, Erdélyi Magyar Tudományegyetem } http://www.ms.sapientia.ro/~mgyongyi
C programozás Márton Gyöngyvér, 2009 Sapientia, Erdélyi Magyar Tudományegyetem http://www.ms.sapientia.ro/~mgyongyi 1 Könyvészet Kátai Z.: Programozás C nyelven Brian W. Kernighan, D.M. Ritchie: A C programozási
C változók. Feladat: Deklaralj egy valos, egy karakter es ket egesz tipusu valtozot! int main() {
C változók Feladat: Deklaralj egy valos, egy karakter es ket egesz tipusu valtozot! float valos; char karakter; int egesz1, egesz2; /* Tobb valtozo ugyan olyan tipusu lehet, ezek deklaraciojat csoportosthatjuk.
6. gyakorlat Egydimenziós numerikus tömbök kezelése, tömbi algoritmusok
6. gyakorlat Egydimenziós numerikus tömbök kezelése, tömbi algoritmusok 1. feladat: Az EURO árfolyamát egy negyedéven keresztül hetente nyilvántartjuk (HUF / EUR). Írjon C programokat az alábbi kérdések
10. gyakorlat Tömb, mint függvény argumentum
10. gyakorlat Tömb, mint függvény argumentum 1. feladat: A 6. gyakorlat 1. feladatát oldja meg a strukturált programtervezési alapelv betartásával, azaz minden végrehajtandó funkciót külön függvényben
Programozás alapjai C nyelv 4. gyakorlat. Mit tudunk már? Feltételes operátor (?:) Típus fogalma char, int, float, double
Programozás alapjai C nyelv 4. gyakorlat Szeberényi Imre BME IIT Programozás alapjai I. (C nyelv, gyakorlat) BME-IIT Sz.I. 2005.10.10.. -1- Mit tudunk már? Típus fogalma char, int, float,
Programozás alapjai 9.Gy: Struktúra 2.
Programozás alapjai 9.Gy: Struktúra 2. Ördögi részletek P R O A L A G 35/1 B ITv: MAN 2018.11.10 Euró árfolyam statisztika Az EURO árfolyamát egy negyedéven keresztül hetente nyilvántartjuk (HUF / EUR).
Mit tudunk már? Programozás alapjai C nyelv 4. gyakorlat. Legnagyobb elem keresése. Feltételes operátor (?:) Legnagyobb elem keresése (3)
Programozás alapjai C nyelv 4. gyakorlat Szeberényi Imre BME IIT Mit tudunk már? Típus fogalma char, int, float, double változók deklarációja operátorok (aritmetikai, relációs, logikai,
int tokeletes(int szam) { int i,oszto=0; for(i=1; i<szam; i++) { if(szam %i == 0) { oszto+=i; }
1. /* Készítsen egy olyan szabványos ANSI C függvényt, amely egy egész számról eldönti, hogy tökéletes szám-e! Az a tökéletes szám, amely egyenlő a nála kisebb osztói összegével. Pl. 6 = 1+2+3 28 = 1+2+4+7+14*/
Algoritmusok pszeudókód... 1
Tartalomjegyzék Algoritmusok pszeudókód... 1 Abszolút érték... 1 Hányados ismételt kivonással... 1 Legnagyobb közös osztó... 1 Páros számok szűrése... 2 Palindrom számok... 2 Orosz szorzás... 2 Minimum
/* Az iter függvény meghívása és a visszatérő érték átadása a gyok változóba */ gyok = iter( n, a, e ) ;
1. Írjunk programot, amely függvény alkalmazásával meghatározza n a értékét, (a az n-edik gyök alatt), az általunk megadott pontossággal, iterációval. Az iteráció képlete a következő: ahol : n-1 x uj =
11. gyakorlat Sturktúrák használata. 1. Definiáljon dátum típust. Olvasson be két dátumot, és határozza meg melyik a régebbi.
11. gyakorlat Sturktúrák használata I. Új típus új műveletekkel 1. Definiáljon dátum típust. Olvasson be két dátumot, és határozza meg melyik a régebbi. typedef struct datum { int ev; int ho; int nap;
Programozás I. gyakorlat
Programozás I. gyakorlat 2. gyakorlat Kifejezések, vezérlési szerkezetek, struktúrák Kifejezések Mit ír ki az alábbi program? #include int main() { int a = 20, b = 40; printf("%d\n", a > b);
Algoritmusok pszeudókód... 1
Tartalomjegyzék Algoritmusok pszeudókód... 1 Abszolút érték... 1 Hányados ismételt kivonással... 1 Legnagyobb közös osztó... 2 Páros számok szűrése... 2 Palindrom számok... 2 Orosz szorzás... 3 Minimum
1. Feladat: beolvas két számot úgy, hogy a-ba kerüljön a nagyobb
1. Feladat: beolvas két számot úgy, hogy a-ba kerüljön a nagyobb #include main() { int a, b; printf( "a=" ); scanf( "%d", &a ); printf( "b=" ); scanf( "%d", &b ); if( a< b ) { inttmp = a; a =
INFORMATIKA tétel 2019
INFORMATIKA tétel 2019 ELIGAZÍTÁS: 1 pont hivatalból; Az 1-4 feladatokban (a pszeudokód programrészletekben): (1) a kiír \n utasítás újsorba ugratja a képernyőn a kurzort; (2) a / operátor osztási hányadost
Programozás alapjai 8.Gy: Program struktúra
Programozás alapjai 8.Gy: Program struktúra Elvarázsolt matekóra P R O A L A G 32/1 B ITv: MAN 2018.11.02 Programozás történelem Kezdetben egy program egyetlen kódsorozat volt (ún. monolitikus program)
INFORMATIKA javítókulcs 2016
INFORMATIKA javítókulcs 2016 ELMÉLETI TÉTEL: Járd körbe a tömb fogalmát (Pascal vagy C/C++): definíció, egy-, két-, több-dimenziós tömbök, kezdőértékadás definíciókor, tömb típusú paraméterek átadása alprogramoknak.
Felvételi tematika INFORMATIKA
Felvételi tematika INFORMATIKA 2016 FEJEZETEK 1. Természetes számok feldolgozása számjegyenként. 2. Számsorozatok feldolgozása elemenként. Egydimenziós tömbök. 3. Mátrixok feldolgozása elemenként/soronként/oszloponként.
7/8. gyakorlat Karaktertömbök és sztringkezelés
7/8. gyakorlat Karaktertömbök és sztringkezelés 1. feladat: Karaktertömb kezelése Egy beolvasott karaktert lineáris kereső eljárással keressen meg az angol ábécében (az ábécé betűit tárolja inicializált
Tartalomjegyzék Algoritmusok - pszeudókód... 1 42
Tartalomjegyzék Algoritmusok - pszeudókód... 1 42 Abszolút érték...1 Hányados ismételt kivonással...1 Legnagyobb közös osztó... 1 2 Páros számok szűrése...2 Palindrom számok... 2 3 Orosz szorzás...3 Minimum
Programozás alapjai 5. gyakorlat Vezérlési szerkezetek egymásba ágyazása
Programozás alapjai 5. gyakorlat Vezérlési szerkezetek egymásba ágyazása 1. feladat: Eldönteni egy számról, hogy pozitív, negatív vagy 0. Próbálja megoldani a feladatot switch szerkezettel is. Mikor használható
A C programozási nyelv I. Bevezetés
A C programozási nyelv I. Bevezetés Miskolci Egyetem Általános Informatikai Tanszék A C programozási nyelv I. (bevezetés) CBEV1 / 1 A C nyelv története Dennis M. Ritchie AT&T Lab., 1972 rendszerprogramozás,
A C programozási nyelv I. Bevezetés
A C programozási nyelv I. Bevezetés Miskolci Egyetem Általános Informatikai Tanszék A C programozási nyelv I. (bevezetés) CBEV1 / 1 A C nyelv története Dennis M. Ritchie AT&T Lab., 1972 rendszerprogramozás,
Programozás alapjai 2.Gy: A C nyelv alapjai P R O
Programozás alapjai 2.Gy: A C nyelv alapjai. P R O A L A G 1/32 B ITv: MAN 2018.10.02 Code::Blocks Indítsa el mindenki! 2/32 1 Code::Blocks Új projekt 2 3 4 5 3/32 Code::Blocks Forráskód Kód fordítása:
Programozás alapjai 3.Gy: C elágazások, ciklusok P R O
Programozás alapjai 3.Gy: C elágazások, ciklusok. P R O A L A G 1/39 B ITv: MAN 2018.10.08 Kövessük a kódot 1. 2. 3. 4. 5. 6. 7. 8. 9. void main() { int a, b, seged; printf("\nkerek ket egesz szamot: ");
Vezérlési szerkezetek. Szelekció Ciklusok
Vezérlési szerkezetek Szelekció Ciklusok Szelekciós vezérlés A program egy feltétel teljesülése alapján választja ki, hogy mely műveleteket hajtsa végre. Alakja: if ( feltétel ) { műveletek, ha feltétel
Járműfedélzeti rendszerek II. 1. előadás Dr. Bécsi Tamás
Járműfedélzeti rendszerek II. 1. előadás Dr. Bécsi Tamás A tárgy órái Előadás hetente (St101) csüt. 8:15 Bécsi Tamás C elmélet Ajánlott irodalom Dennis Ritchie: A C programozási nyelv Gyakorlat hetente
INFORMATIKA tétel 2018
INFORMATIKA tétel 2018 ELIGAZÍTÁS: 1 pont hivatalból; Az 1-4 feladatokban (a pszeudokód programrészletekben): (1) a kiír \n utasítás újsorba ugratja a képernyőn a kurzort; (2) a minden i = n,1,-1 végezd
1. Írjunk programot mely beolvas két számot és ellenőrzi hogy mindkét szám zérus-e:
1. Írjunk programot mely beolvas két számot és ellenőrzi hogy mindkét szám zérus-e: main() int number1, number2; printf("adjon meg két számot: "); scanf("%d %d", &number1, &number2); if ((number1 == 0)
3 A C programozási nyelv szintaktikai egységei
3 A C programozási nyelv szintaktikai egységei 3.1 Azonosítók Betűk és számjegyek sorozata, betűvel vagy _ (aláhúzás) karakterrel kell kezdődnie. A nagy- és kisbetűk különbözőek. Az azonosítók tetszőleges
Programozás alapjai gyakorlat. 4. gyakorlat Konstansok, tömbök, stringek
Programozás alapjai gyakorlat 4. gyakorlat Konstansok, tömbök, stringek Házi ellenőrzés (f0069) Valósítsd meg a linuxos seq parancs egy egyszerűbb változatát, ami beolvas két egész számot, majd a kettő
Programozás alapjai gyakorlat. 2. gyakorlat C alapok
Programozás alapjai gyakorlat 2. gyakorlat C alapok 2016-2017 Bordé Sándor 2 Forráskód, fordító, futtatható állomány Először megírjuk a programunk kódját (forráskód) Egyszerű szövegszerkesztőben vagy fejlesztőkörnyezettel
Funkcionális és logikai programozás. { Márton Gyöngyvér, 2012} { Sapientia, Erdélyi Magyar Tudományegyetem }
Funkcionális és logikai programozás { Márton Gyöngyvér, 2012} { Sapientia, Erdélyi Magyar Tudományegyetem } http://www.ms.sapientia.ro/~mgyongyi ` 1 Jelenlét: Követelmények, osztályozás Az első 4 előadáson
Programozás I gyakorlat. 10. Stringek, mutatók
Programozás I gyakorlat 10. Stringek, mutatók Karakter típus A char típusú változókat karakerként is kiírhatjuk: #include char c = 'A'; printf("%c\n", c); c = 80; printf("%c\n", c); printf("%c\n",
Programozás alapjai. (GKxB_INTM023) Dr. Hatwágner F. Miklós augusztus 29. Széchenyi István Egyetem, Gy r
Programozás alapjai (GKxB_INTM023) Széchenyi István Egyetem, Gy r 2019. augusztus 29. Feladat: írjuk ki az els 10 természetes szám négyzetét! #i n c l u d e i n t main ( v o i d ) { p r
Programozás C nyelven (13. ELŐADÁS) Sapientia EMTE
Programozás C nyelven (13. ELŐADÁS) Sapientia EMTE 2015-16 1 Olvasás/írás (ANSI C) ille tyűzetről/képer yőre (scanf/printf) scanf: olvasás a standard inputról (stdin) A sta dard i put i pli ite a ille
2018, Diszkrét matematika
Diszkrét matematika 3. előadás mgyongyi@ms.sapientia.ro Sapientia Egyetem, Matematika-Informatika Tanszék Marosvásárhely, Románia 2018, őszi félév Miről volt szó az elmúlt előadáson? számtartományok: természetes
Függvény pointer. Feladat: Egy tömbben soroljunk fel függvényeket, és hívjuk meg valahányszor.
Függvény pointer Több feladat közül futási időben döntöm el, hogy melyiket hajtom végre. A függvényre mutató pointer a függvény kódjának a címére mutat, azon keresztül meghívhatom a függvényt. A pointernek
I. ALAPALGORITMUSOK. I. Pszeudokódban beolvas n prim igaz minden i 2,gyök(n) végezd el ha n % i = 0 akkor prim hamis
I. ALAPALGORITMUSOK 1. Prímszámvizsgálat Adott egy n természetes szám. Írjunk algoritmust, amely eldönti, hogy prímszám-e vagy sem! Egy számról úgy fogjuk eldönteni, hogy prímszám-e, hogy megvizsgáljuk,
Programozás 3. Dr. Iványi Péter
Programozás 3. Dr. Iványi Péter 1 Egy operandus művelet operandus operandus művelet Operátorok Két operandus operandus1 művelet operandus2 2 Aritmetikai műveletek + : összeadás -: kivonás * : szorzás /
Programozás alapjai C nyelv 5. gyakorlat. Írjunk ki fordítva! Írjunk ki fordítva! (3)
Programozás alapjai C nyelv 5. gyakorlat Szeberényi Imre BME IIT Programozás alapjai I. (C nyelv, gyakorlat) BME-IIT Sz.I. 2005.10.17. -1- Tömbök Azonos típusú adatok tárolására. Index
INFORMATIKA tétel 2017
INFORMATIKA tétel 2017 ELMÉLETI TÉTEL: Sorold fel a rekurzív függvények/eljárások jellemzőit! Szemléltesd a fogalmakat egy konkrét példán! [1 pont] GYAKORLATI TÉTEL: 1. Legyen az alábbi pszeudokód programrészlet
Programozás I. 3. gyakorlat. Szegedi Tudományegyetem Természettudományi és Informatikai Kar
Programozás I. 3. gyakorlat Szegedi Tudományegyetem Természettudományi és Informatikai Kar Antal Gábor 1 Primitív típusok Típus neve Érték Alap érték Foglalt tár Intervallum byte Előjeles egész 0 8 bit
Programozás I gyakorlat
Programozás I. - 2. gyakorlat Változók, kiiratás, bekérés Tar Péter 1 Pannon Egyetem M szaki Informatikai Kar Számítástudomány Alkalmazása Tanszék Utolsó frissítés: September 24, 2007 1 tar@dcs.vein.hu
Objektumorientált Programozás III.
Objektumorientált Programozás III. Vezérlési szerkezetek ismétlés Matematikai lehetőségek Feladatok 1 Hallgatói Tájékoztató A jelen bemutatóban található adatok, tudnivalók és információk a számonkérendő
Programozás I gyakorlat
Programozás I. - 2. gyakorlat Változók, típusok, bekérés Tar Péter 1 Pannon Egyetem M szaki Informatikai Kar Rendszer - És Számítástudományi Tanszék Utolsó frissítés: September 21, 2009 1 tar@dcs.vein.hu
2018, Funkcionális programozás
Funkcionális programozás 6. előadás Sapientia Egyetem, Matematika-Informatika Tanszék Marosvásárhely, Románia mgyongyi@ms.sapientia.ro 2018, tavaszi félév Miről volt szó? Haskell modulok, kompilálás a
Programozás alapjai. 6. gyakorlat Futásidő, rekurzió, feladatmegoldás
Programozás alapjai 6. gyakorlat Futásidő, rekurzió, feladatmegoldás Háziellenőrzés Egészítsd ki úgy a simplemaths.c programot, hogy megfelelően működjön. A program feladata az inputon soronként megadott
Programozás I. Matematikai lehetőségek Műveletek tömbökkel Egyszerű programozási tételek & gyakorlás V 1.0 OE-NIK,
Programozás I. Matematikai lehetőségek Műveletek tömbökkel Egyszerű programozási tételek & gyakorlás OE-NIK, 2013 1 Hallgatói Tájékoztató A jelen bemutatóban található adatok, tudnivalók és információk
Operációs rendszerek. 11. gyakorlat. AWK - szintaxis, vezérlési szerkezetek UNIVERSITAS SCIENTIARUM SZEGEDIENSIS UNIVERSITY OF SZEGED
UNIVERSITAS SCIENTIARUM SZEGEDIENSIS UNIVERSITY OF SZEGED AWK - szintaxis, vezérlési szerkezetek Operációs rendszerek 11. gyakorlat Szegedi Tudományegyetem Természettudományi és Informatikai Kar Csuvik
Vezérlési szerkezetek
Vezérlési szerkezetek Szelekciós ok: if, else, switch If Segítségével valamely ok végrehajtását valamely feltétel teljesülése esetén végezzük el. Az if segítségével valamely tevékenység () végrehajtását
Programozás 6. Dr. Iványi Péter
Programozás 6. Dr. Iványi Péter 1 Előfeldolgozás része Makrók A forrás kódban elvégzi a helyettesítéseket a fordító Csak egyszer végez helyettesítést Nem olyan makrók, mint a LISP vagy Scheme esetén Csak
Struktúrák (struct) A struktúra szerkezetét meghatározó deklaráció általános formája:
Struktúrák (struct) A struktúra egy olyan összetett adatszerkezet, amely nemcsak azonos típusú elemeket rendelhet össze. A struktúra definíciójában leírjuk, hogy a struktúra hogyan épül fel. A struktúra
OOP I. Egyszerő algoritmusok és leírásuk. Készítette: Dr. Kotsis Domokos
OOP I. Egyszerő algoritmusok és leírásuk Készítette: Dr. Kotsis Domokos Hallgatói tájékoztató A jelen bemutatóban található adatok, tudnivalók és információk a számonkérendı anyag vázlatát képezik. Ismeretük
// keressük meg a legnagyobb faktoriális értéket, ami kisebb, // mint százmillió
BME MOGI Gépészeti informatika 3. 1. feladat Végezze el a következő feladatokat! Kérjen be számokat 0 végjelig, és határozza meg az átlagukat! A feladat megoldásához írja meg a következő metódusokat! a.
1.1. A forrásprogramok felépítése Nevek és kulcsszavak Alapvető típusok. C programozás 3
Darvay Zsolt Típusok és nevek a forráskódban Állandók és változók Hatókörök és az előfeldolgozó Bevitel és kivitel Kifejezések Utasítások Mutatók Függvények Struktúrák és típusok Állománykezelés C programozás
Programozás alapjai. (GKxB_INTM023) Dr. Hatwágner F. Miklós szeptember 27. Széchenyi István Egyetem, Gy r
Programozás alapjai (GKxB_INTM023) Széchenyi István Egyetem, Gy r 2018. szeptember 27. Háromszög szerkeszthet ségének ellen rzése ANSI C (C89) megvalósítás #i n c l u d e i n t main ( v
Programozás alapjai. (GKxB_INTM023) Dr. Hatwágner F. Miklós október 11. Széchenyi István Egyetem, Gy r
Programozás alapjai (GKxB_INTM023) Széchenyi István Egyetem, Gy r 2018. október 11. Függvények Mi az a függvény (function)? Programkód egy konkrét, azonosítható, paraméterezhet, újrahasznosítható blokkja
2019, Funkcionális programozás. 2. el adás. MÁRTON Gyöngyvér
Funkcionális programozás 2. el adás Sapientia Egyetem, Matematika-Informatika Tanszék Marosvásárhely, Románia mgyongyi@ms.sapientia.ro 2019, tavaszi félév Mir l volt szó? Követelmények, osztályozás Programozási
Mintavételes szabályozás mikrovezérlő segítségével
Automatizálási Tanszék Mintavételes szabályozás mikrovezérlő segítségével Budai Tamás budai.tamas@sze.hu http://maxwell.sze.hu/~budait Tartalom Mikrovezérlőkről röviden Programozási alapismeretek ismétlés
Algoritmusok - pszeudókód... 1
Tartalomjegyzék Algoritmusok - pszeudókód... 1 Abszolút érték... 1 Hányados ismételt kivonással... 1 Legnagyobb közös osztó... 1 Páros számok szűrése... 2 Palindrom számok... 2 Orosz szorzás... 2 Minimum
2016, Diszkrét matematika
Diszkrét matematika 2. előadás Sapientia Egyetem, Műszaki és Humántudományok Tanszék Marosvásárhely, Románia mgyongyi@ms.sapientia.ro 2016, őszi félév Miről volt szó az elmúlt előadáson? Követelmények,
értékel függvény: rátermettségi függvény (tness function)
Genetikus algoritmusok globális optimalizálás sok lehetséges megoldás közül keressük a legjobbat értékel függvény: rátermettségi függvény (tness function) populáció kiválasztjuk a legrátermettebb egyedeket
Tömbök kezelése. Példa: Vonalkód ellenőrzőjegyének kiszámítása
Tömbök kezelése Példa: Vonalkód ellenőrzőjegyének kiszámítása A számokkal jellemzett adatok, pl. személyi szám, adószám, taj-szám, vonalkód, bankszámlaszám esetében az elírásból származó hibát ún. ellenőrző
main int main(int argc, char* argv[]) { return 0; } main return 0; (int argc, char* argv[]) main int int int main main main
main int main(int argc, char* argv[]) { return 0; main main int int main int return 0; main (int argc, char* argv[]) main #include #include int main(int argc, char* argv[]) { double
Programozás I. 5. Előadás: Függvények
Programozás I 5. Előadás: Függvények Függvény Egy alprogram Egy C program általában több kisméretű, könnyen értelmezhető függvényből áll Egy függvény megtalálható minden C programban: ez a main függvény
Brósch Zoltán (Debreceni Egyetem Kossuth Lajos Gyakorló Gimnáziuma) Számelmélet I.
Számelmélet I. DEFINÍCIÓ: (Osztó, többszörös) Ha egy a szám felírható egy b szám és egy másik egész szám szorzataként, akkor a b számot az a osztójának, az a számot a b többszörösének nevezzük. Megjegyzés:
Programozás C nyelven 5. ELŐADÁS. Sapientia EMTE
Programozás C nyelven. ELŐADÁS Sapientia EMTE 201-16 1 while vs. for int szam, s; cin >> szam; s = 0; while ( szam > 0 ){ s += szam%10; szam /= 10; cout szam;
Assembly programozás: 2. gyakorlat
Assembly programozás: 2. gyakorlat Számrendszerek: Kettes (bináris) számrendszer: {0, 1} Nyolcas (oktális) számrendszer: {0,..., 7} Tízes (decimális) számrendszer: {0, 1, 2,..., 9} 16-os (hexadecimális
7. gyakorlat. Fájlkezelés IO haladó Függvények haladó
7. gyakorlat Fájlkezelés IO haladó Függvények haladó Fájlkezelés A C-ben a fájlkezelés ún. fájlstream-eken keresztül történik, melyek puffereltek ha valamit a streamre küldünk, nem biztos, hogy rögtön
tétel: különböző típusú adatokat csoportosít, ezeket egyetlen adatként kezeli, de hozzáférhetünk az elemeihez is
A tétel (record) tétel: különböző típusú adatokat csoportosít, ezeket egyetlen adatként kezeli, de hozzáférhetünk az elemeihez is A tétel elemei mezők. Például tétel: személy elemei: név, lakcím, születési
Bevezetés az informatikába
Figyelem! A jegyzet fejlesztés alatt áll, ezért fokozott figyelmet kérek a használatánál. Bevezetés az informatikába Gyakorlati segédlet gazdasági informatikusok részére Készítette: Szeghalmy Szilvia Módosítva:
2018, Diszkrét matematika
Diszkrét matematika 5. előadás mgyongyi@ms.sapientia.ro Sapientia Egyetem, Matematika-Informatika Tanszék Marosvásárhely, Románia 2018, őszi félév Miről volt szó az elmúlt előadáson? Python alapfogalmak:
C programozási nyelv Pointerek, tömbök, pointer aritmetika
C programozási nyelv Pointerek, tömbök, pointer aritmetika Dr. Schuster György 2011. június 16. C programozási nyelv Pointerek, tömbök, pointer aritmetika 2011. június 16. 1 / 15 Pointerek (mutatók) Pointerek
Sapientia Egyetem, Műszaki és Humántudományok Tanszék. mgyongyi@ms.sapientia.ro
Kriptográfia és Információbiztonság 4. előadás Sapientia Egyetem, Műszaki és Humántudományok Tanszék Marosvásárhely, Románia mgyongyi@ms.sapientia.ro 2015 Miről volt szó az elmúlt előadáson? blokk-titkosító
Programozás alapjai. 5. előadás
5. előadás Wagner György Általános Informatikai Tanszék Cserélve kiválasztásos rendezés (1) A minimum-maximum keresés elvére épül. Ismétlés: minimum keresés A halmazból egy tetszőleges elemet kinevezünk
Egyszerű programok készítése... 56 Kifejezések... 57 Bitszintű műveletek... 57 Relációs műveletek... 58
Tartalomjegyzék Algoritmusok - pszeudókód... 1 Abszolút érték... 1 Hányados ismételt kivonással... 1 Legnagyobb közös osztó... 1 Páros számok szűrése... 2 Palindrom számok... 2 Orosz szorzás... 3 Minimum
Programozas 1. Strukturak, mutatok
Programozas 1 Strukturak, mutatok Strukturak Tömb: több egyforma típusú változó együttese Struktúra: több különböző típusú de logikailag egybetartozó változó együttese, amelyet az egyszerű kezelhetőség
Programozás. (GKxB_INTM021) Dr. Hatwágner F. Miklós március 3. Széchenyi István Egyetem, Gy r
Programozás (GKxB_INTM021) Széchenyi István Egyetem, Gy r 2018. március 3. Függvények Mi az a függvény (function)? Programkód egy konkrét, azonosítható, paraméterezhet, újrahasznosítható blokkja Miért
Programozási segédlet
Programozási segédlet Programozási tételek Az alábbiakban leírtam néhány alap algoritmust, amit ismernie kell annak, aki programozásra adja a fejét. A lista korántsem teljes, ám ennyi elég kell legyen
Programozás C- és Matlab nyelven C programozás kurzus BMEKOKAM603 Előfeldolgozó rendszer Tömbök. Dr. Bécsi Tamás 4. Előadás
Programozás C- és Matlab nyelven C programozás kurzus BMEKOKAM603 Előfeldolgozó rendszer Tömbök Dr. Bécsi Tamás 4. Előadás A?: operátor Nézzük meg a következő kifejezést: if (a>b) z=a; else z=b; Ez felírható
Programozás I gyakorlat
Programozás I. - 3. gyakorlat Operátorok, típuskonverziók, matematikai függvények Tar Péter 1 Pannon Egyetem M szaki Informatikai Kar Számítástudomány Alkalmazása Tanszék Utolsó frissítés: September 24,
Programozás alapjai C nyelv 7. gyakorlat. Függvények. Függvények(2)
Programozás alapjai C nyelv 7. gyakorlat Szeberényi Imre BME IIT Programozás alapjai I. (C nyelv, gyakorlat) BME-IIT Sz.I. 2005.11.05. -1- Függvények C program egymás mellé rendelt függvényekből
Függvények. Programozás alapjai C nyelv 7. gyakorlat. LNKO függvény. Függvények(2) LNKO függvény (2) LNKO függvény (3)
Programozás alapjai C nyelv 7. gyakorlat Szeberényi Imre BME IIT Függvények C program egymás mellé rendelt függvényekből áll. A függvény (alprogram) jó absztrakciós eszköz a programok
Tartalomjegyzék Algoritmusok - pszeudókód... 1 42
Tartalomjegyzék Algoritmusok - pszeudókód... 1 42 Abszolút érték...1 Hányados ismételt kivonással...1 Legnagyobb közös osztó... 1 2 Páros számok szűrése...2 Palindrom számok...2 Orosz szorzás...3 Minimum
Programozás 1. Dr. Iványi Péter
Programozás 1. Dr. Iványi Péter 1 C nyelv B.W. Kernighan és D.M. Ritchie, 1978 The C Programming language 2 C nyelv Amerikai Szabványügy Hivatal (ANSI), 1983 X3J11 bizottság a C nyelv szabványosítására
Adatbázis rendszerek Gy: Algoritmusok C-ben
Adatbázis rendszerek 1. 1. Gy: Algoritmusok C-ben 53/1 B ITv: MAN 2015.09.08 Alapalgoritmusok Összegzés Megszámlálás Kiválasztás Kiválasztásos rendezés Összefésülés Szétválogatás Gyorsrendezés 53/2 Összegzés
Programozás BMEKOKAA146. Dr. Bécsi Tamás 2. előadás
Programozás BMEKOKAA146 Dr. Bécsi Tamás 2. előadás Szintaktikai alapok Alapvető típusok, ismétlés C# típus.net típus Méret (byte) Leírás byte System.Byte 1Előjel nélküli 8 bites egész szám (0..255) char
Bevezetés a programozásba I.
Bevezetés a programozásba I. 6. gyakorlat C++ alapok, szövegkezelés Surányi Márton PPKE-ITK 2010.10.12. Forrásfájlok: *.cpp fájlok Fordítás: a folyamat, amikor a forrásfájlból futtatható állományt állítunk
Programozási nyelvek I. 5. előadás (Gregorics Tibor anyagának felhasználásával)
Programozási nyelvek I. 5. előadás (Gregorics Tibor anyagának felhasználásával) I. A nyelv története C++ C (ős: B???) 1972 Ritchie AT&T Bell laboratórium UNIX 1978 Kernighan & Ritchie az első tankönyv,
7. fejezet: Mutatók és tömbök
7. fejezet: Mutatók és tömbök Minden komolyabb programozási nyelvben vannak tömbök, amelyek gondos kezekben komoly fegyvert jelenthetnek. Először is tanuljunk meg tömböt deklarálni! //Tömbök használata
B I T M A N B I v: T M A N
Műszaki informatika Tesztek+Megoldások B I v: T 2015.04.19 M A N 1/42 Tesztek + Megoldások Alapfogalmi kitérő kérdéssor IPA kérdéssor CPA kérdéssor 2/42 Ellenőrző kérdések 1. 1. Melyik Neumann elv következménye
6. A Pascal nyelv utasításai
6. A Pascal nyelv utasításai Írjunk programot, amely beolvas két valós számot és a két szám közül a kisebbikkel osztja a nagyobbikat! (felt0) program felt0; szam1, szam2, eredmeny : real; writeln('kérek
SZÁMRENDSZEREK KÉSZÍTETTE: JURÁNYINÉ BESENYEI GABRIELLA
SZÁMRENDSZEREK KÉSZÍTETTE: JURÁNYINÉ BESENYEI GABRIELLA BINÁRIS (kettes) ÉS HEXADECIMÁLIS (tizenhatos) SZÁMRENDSZEREK (HELYIÉRTÉK, ÁTVÁLTÁSOK, MŰVELETEK) A KETTES SZÁMRENDSZER A computerek világában a
Matematikai alapok. Dr. Iványi Péter
Matematikai alapok Dr. Iványi Péter Számok A leggyakrabban használt adat típus Egész számok Valós számok Bináris számábrázolás Kettes számrendszer Bitek: és Byte: 8 bit 28 64 32 6 8 4 2 bináris decimális
5. gyakorlat. Konstansok Tömbök Stringek
5. gyakorlat Konstansok Tömbök Stringek Konstansok A C nyelvben a konstansok preprocesszor makrókkal vannak megvalósítva. Konstansdefiniálás alakja: #define NÉV érték Az érték bármi lehet, később a fordítás
Java II. I A Java programozási nyelv alapelemei
Java II. I A Java programozási nyelv alapelemei Miskolci Egyetem Általános Informatikai Tanszék Utolsó módosítás: 2008. 02. 19. Java II.: Alapelemek JAVA2 / 1 A Java formalizmusa A C, illetve az annak
Stack Vezérlés szerkezet Adat 2.
Stack Vezérlés szerkezet Adat 2. Kód visszafejtés. Izsó Tamás 2013. november 14. Izsó Tamás Stack Vezérlés szerkezet Adat 2./ 1 Változó típusú paraméterekátadása 1. #include < s t d i o. h> int64 myfunc