Az előadás letöltése folymat van. Kérjük, várjon

Az előadás letöltése folymat van. Kérjük, várjon

Megszámlálás, kiválasztás alapalgoritmusok

Hasonló előadás


Az előadások a következő témára: "Megszámlálás, kiválasztás alapalgoritmusok"— Előadás másolata:

1 Megszámlálás, kiválasztás alapalgoritmusok
Alkalmazott Informatikai Tanszék SZÁMÍTÁSTECHNIKA I dr.Dudás László 18./0. Megszámlálás, kiválasztás alapalgoritmusok Vektoron értelmezett 2. alapalgoritmus:        a megszámlálás algoritmusa Vektoron értelmezett 3. alapalgoritmus:         a kiválasztás algoritmusa Példa egyszerű logikai feltételnek eleget tevő elem kiválasztására Elemkiválasztás összetett logikai feltétel alapján

2 Vektoron értelmezett 2. alapalgoritmus: a megszámlálás algoritmusa
Alkalmazott Informatikai Tanszék SZÁMÍTÁSTECHNIKA I dr.Dudás László 18./1. Vektoron értelmezett 2. alapalgoritmus:        a megszámlálás algoritmusa Megszámlálás Képernyőtörlés Kiíratás: ”Megszámlálás” ”A számok összes darabszáma=” n értékének bekérése *Beolvasás i=0,1,...,n-1 Kiíratás: ”Az ”,i+1, ”. szám=” vektor[ i ] értékének beolvasása 1 Feladat: meg kell számlálni, hogy egy sorozatban hány, megadott feltételnek eleget tevő elem van. Példa: Olvassunk be n darab pozitív egész számot egy vektorba, majd számláljuk meg, hogy hány kétjegyű és hány háromjegyű van közöttük ! Chapin diagram == struktogram

3 (10<=vektor[ i ] && vektor[ i ]<=99)
Alkalmazott Informatikai Tanszék SZÁMÍTÁSTECHNIKA I dr.Dudás László 18./2. A megszámlálás algoritmusa . . *Megszámlálás: ketjegyu= 0; haromjegyu= 0; i=0,1,...,n-1 (10<=vektor[ i ] && vektor[ i ]<=99) 1 (100<=vektor[ i ] && vektor[ i ]<=999)      ketjegyu++; haromjegyu++; ; igen nem 2

4 A megszámlálás algoritmusa . .
Alkalmazott Informatikai Tanszék SZÁMÍTÁSTECHNIKA I dr.Dudás László 18./3. A megszámlálás algoritmusa . . 2 *Eredmény kiíratása: Kiíratás: ketjegyu,” darab kétjegyü és”, haromjegyu, ” darab háromjegyü szám van” Várakozás Enter lenyomására A feladat struktogramja után lássuk a programját!

5 A megszámlálás algoritmusa . .
Alkalmazott Informatikai Tanszék SZÁMÍTÁSTECHNIKA I dr.Dudás László 18./4. A megszámlálás algoritmusa . . #include <conio.h> #include <stdio.h> unsigned int vektor [100]; void main(void) { unsigned int i, n, ketjegyu, haromjegyu ; clrscr(); puts(" Megszámlálás\n"); printf("A számok összes darabszáma= "); scanf("%u", &n); /* Beolvasás: */ for (i = 0; i < n ; i ++) printf("A %u. szám = ", i +1); scanf("%u", &vektor [ i ]); /* vagy scanf("%u",vektor+i); */ }

6 A megszámlálás algoritmusa . .
Alkalmazott Informatikai Tanszék SZÁMÍTÁSTECHNIKA I dr.Dudás László 18./5. A megszámlálás algoritmusa . . /* Megszámlálás: */ for (ketjegyu = 0, haromjegyu = 0, i = 0; i < n; i ++) if (10<=vektor [ i ] && vektor [ i ]<=99) ketjegyu++; else if (100<=vektor [ i ] && vektor [ i ]<=999) haromjegyu++; /* Eredmény kiíratása: */ printf("\n%u darab kétjegyű és %u darab háromjegyű \ szám van.\n", ketjegyu, haromjegyu); getch(); } 5, 7, 11 , 23 , 30 , 5 , 9 , 133 , 22 , 13 , 21 , 127 , 4 , 2 , 0 , 91 , 1 , 11 , 7 , ketjegyu == 8; haromjegyu == 3

7 Vektoron értelmezett 3. alapalgoritmus: a kiválasztás algoritmusa
Alkalmazott Informatikai Tanszék SZÁMÍTÁSTECHNIKA I dr.Dudás László 18./6. Vektoron értelmezett 3. alapalgoritmus:         a kiválasztás algoritmusa Kiválasztás n értékének bekérése i= 0,1,...,n-1 minertek= vektor[ 0 ]; index= 0; i= 1,2,...,n-1 vektor[ i ]<minertek igen nem minertek= vektor[ i ]; index= i; index és minertek kiíratása vektor[ i ] értékének bekérése ; Feladat: egy n elemű sorozatban megadott tulajdonsággal bíró elem sorszámának (indexének) meghatá- rozása. Példa egyszerű logikai feltételnek eleget tevő elem kiválasztására: a minimális elem kiválasztása.

8 A minimális elem kiválasztás programja
Alkalmazott Informatikai Tanszék SZÁMÍTÁSTECHNIKA I dr.Dudás László 18./7. A minimális elem kiválasztás programja #include <conio.h> #include <stdio.h> float vektor [100]; void main(void) { unsigned int n, i, index ; float minertek ; clrscr(); puts(" Kiválasztás\n"); printf("Elemek száma= "); scanf("%u", &n); /* Beolvasás a vektorba: */ for (i = 0; i < n; i++) printf("Vektor[%u]= ", i +1); scanf("%f", &vektor [ i ]); /* vagy scanf(%f",vektor+ i ); */ }

9 A minimális elem kiválasztás programja . .
Alkalmazott Informatikai Tanszék SZÁMÍTÁSTECHNIKA I dr.Dudás László 18./8. A minimális elem kiválasztás programja . . /* A minimális elem meghatározása: */ for (minertek = vektor [0], index =0, i =1; i < n; i++) if (vektor[ i ]<minertek) { minertek = vektor [ i ]; index= i ; } /* Az eredmény kiíratása: */ printf("\nIndex= %u, minimális érték =%10.3f", index, minertek); getch(); }

10 Elemkiválasztás összetett logikai feltétel alapján
Alkalmazott Informatikai Tanszék SZÁMÍTÁSTECHNIKA I dr.Dudás László 18./9. Elemkiválasztás összetett logikai feltétel alapján Kezdoszam és darab bekérése Primtényezők_száma i = 0,1,...,darab-1 szamsorozat[ i ]= kezdoszam + i ; legtobb = 0; osztok_szama= 0; oszto=2; hanyados =szamsorozat[ i ]; hanyados % oszto == 0 hanyados = hanyados / oszto; osztok_szama++; oszto++; hanyados != 1 osztok_szama > legtobb igen legtobb = osztok_szama; index = i; index, szamsorozat[ index ], és legtobb kiíratása nem ; Példa: Adott egy egyesé- vel növekvő számsorozat a kezdőszámmal és az elemek számával. Meghatározandó annak a számnak a sorszáma, amely a legtöbb prímtényezőre bontható fel.

11 Elemkiválasztás összetett logikai feltétel alapján . .
Alkalmazott Informatikai Tanszék SZÁMÍTÁSTECHNIKA I dr.Dudás László 18./10. Elemkiválasztás összetett logikai feltétel alapján . . A primtényezők számát megadó program: #include <conio.h> #include <stdio.h> unsigned int szamsorozat [100]; void main(void) { unsigned int kezdoszam, darab, oszto, i, index, osztok_szama, legtobb, hanyados; clrscr(); puts("Legtöbb prímtényező \n"); printf("Kezdő szám="); scanf("%u",&kezdoszam); printf("\nSzámok darabszáma="); scanf("%u", &darab); for (i = 0; i < darab; i++) szamsorozat [ i ]= kezdoszam+i ; legtobb= 0; kezdoszam= 11; darab= 2; szamsorozat { 11, 12 }

12 Elemkiválasztás összetett logikai feltétel alapján . .
Alkalmazott Informatikai Tanszék SZÁMÍTÁSTECHNIKA I dr.Dudás László 18./11. Elemkiválasztás összetett logikai feltétel alapján . . for (i = 0; i < darab; i++) { osztok_szama = 0; oszto = 2; hanyados = szamsorozat [ i ]; do { while (hanyados % oszto == 0) { hanyados /= oszto; /* egészosztás! */ osztok_szama++; } oszto++; } while (hanyados != 1); if (osztok_szama>legtobb) {legtobb= osztok_szama; index= i ; printf("\nIndex= %u, a szám= %u, tényezők száma= %u\n", index, szamsorozat[index], legtobb); getch();


Letölteni ppt "Megszámlálás, kiválasztás alapalgoritmusok"

Hasonló előadás


Google Hirdetések