IF
eta switch baldintzazko egiturak eta while eta do-while egitura errepikakorrak aurreko kapituluan aztertu eta gero, kapitulu honetan helburua ondoko azalpenetan datza:
Egitura errepikakor konplexu honetan, bigiztaren gorputza eta errepikatzeko baldintzaren gain hasieraketarako eta ziklo bakoitzeko eguneratzeko espresioak onartzen dira, kasu batzuetan oso egitura erosoa gertatuz.
Hona hemen sintaxia:
Dagokion funtzionamendua ondokoa da:
Beraz, parentesien arteko lehen espresioa (hasieraketa) behin exekutatzen da, bigarrena ziklo bakoitzaren hasieran eta hirugarrena (eguneratzea) ziklo bakoitzaren bukaeran. Dena den for egituraz egiten dena while eta asignazioaren bidez egin daiteke ondoan ikus daitekeenez.
1. programan aurreko kapituluan azaldutako faktorialaren kalkulua, for egitura erabiliz ikus daiteke.
Egituraren espresioak aukerazkoak badira, baldin-espresioak beti agertu behar du; bestela bigizta infinitua gertatuko bait litzateke. Lehen eta hirugarren espresioak agertzen ez direnean for eta while guztiz baliokideak dira.
Gorputza espresio bakarrak edo { eta }-en bidez bereiztutako espresio-multzoak osa dezakete, gorputz hutsa ere onartzen delarik (kasu honetan gorputza ; karaktereak osatzen du).
Egitura errepikakorretan, batzuetan, bigizta kontrolatzen duen espresioa (baldin-espresioa) bete arren, bigiztatik ateratzea komeni izaten da salbuespenen bat gertatu bada. Horretarako erabiltzen da break sententzia egitura errepikakorretan.
2. programan ikus daiteke honen adibide bat. Bertan, 80 karaktere irakurtzen dira eta zenbat maiuskula dagoen kontatzen da. Dena den ‘.’ karakterea irakurtzen bada, ez da karaktere gehiagorik irakurri behar.
Beste kasuetan egitura errepikakorraren gorputza konplexua denean, gerta daiteke egoera batean bigiztan jarraitu nahi arren gorputzaren zati bat exekutatu behar ez izatea, horretarako continue sententzia oso egokia gertatuz.
3. programan 20 zenbaki irakurtzen dira eta beren arteko biderkadura kalkulatu behar da, baina zenbakia Ø bada ez da kontutan hartzen.
1. enuntziatua: Irakurri hiru zenbaki oso eta handiena idatzi (4. programa).
Adibide honetan if baten adarretan if egiturak agertzen dira ( if kabiatuak) eta egitura bakoitza adierazpen sinpletzat jotzen denez ez da giltzarik behar.
2. enuntziatua: Irakurri karaktere bat eta kalkulatu zero egoeran zenbat bit dagoen. (5. programa).
Bit-maneiua oso zaila gertatzen da goi-mailako lengoaietan, baina Cz aldiz, izugarri erraza (and), | (or), ˆ (xor), (ezker-desplazamendua) eta (eskuin-desplazamendua) eragileei esker. Adibidean, and eragiketaren bidez bit bat aztertzen da, zeren and eragiketan bit bakar bat 1 egoeran duen maskara batekin datu bat parekatzen dugunean, 1-ri dagokion datuaren bita zeroa bada emaitza zero izango bait da, eta bata bada, emaitza desberdin zero. Eragiketa 8 aldiz errepikatzen den bigizta batean dago ( for egituraz) baina bit desberdinak aztertzeko, bigiztaren barruan maskarako bitak desplazatu behar dira (programan egin denaren legez), edo datu bera desplazatu.
3. enuntziatua: Irakurri 40 karaktere eta kontatu Ø egoeran zenbat bit duten.
Adibide honen aurrean 2 galdera sortzen dira:
Orain arte ikusitako oinarrizko datuak karaktereak (char) , zenbaki osoak (short, int, long) eta errealak (float, double) dira. Horien gain, datu-multzoak defini daitezke taulak edo bektoreak osatuz, ondoko adibidean ikus daitekeenez:
char string [8Ø];
/* 8Ø karaktereko katea */
int taula [2Ø], matrizea [M] [N];
Karaktere-katea (string ingelesez) karaktereez osatutako taula da, non azken karakterea ‘\Ø’ konstantea den. Katearen bukaerako karaktere honen bidez katearen amaiera detektatzen da, katea luzera aldakorrekoa denean.
Taulak dimentsio bakarrekoak izan daitezke ( string edo taula adibidean) edo anitzekoak ( matrizea bikoa da adibidean). Erabiltzean, izena eta indizea (makoen artean) aipatzen dira, indizea Ø eta osagai-kopurua ken bat artean egongo delarik. Definizioan izena eta osagai-kopurua (makoen artean) jarri behar da hasieraketa aukerazkoa izanik. 6. programan adibide bat ikus daiteke.