Presentation laddar. Vänta.

Presentation laddar. Vänta.

William Sandqvist Är Du bra på for-loopar? Ge triangelns höjd: 12 1>............*............ 2>...........***........... 3>..........*****..........

Liknande presentationer


En presentation över ämnet: "William Sandqvist Är Du bra på for-loopar? Ge triangelns höjd: 12 1>............*............ 2>...........***........... 3>..........*****.........."— Presentationens avskrift:

1 William Sandqvist william@kth.se Är Du bra på for-loopar? Ge triangelns höjd: 12 1>............*............ 2>...........***........... 3>..........*****.......... 4>.........*******......... 5>........*********........ 6>.......***********....... 7>......*************...... 8>.....***************..... 9>....*****************.... 10>...*******************... 11>..*********************.. 12>.***********************. Utmaning vid laborationen: en stjärntriangel på prickad bakgrund.

2 William Sandqvist william@kth.se while() och for() x = 0; while ( x < 5 ) { sum += x*2; x ++; } x = 0; do { sum += x*2; x ++; } while ( x < 5 ); Avbrottsvilkoret x<5 Det är do while – slingan som passar PIC-processorns instruktionsuppsättning bäst. for ( x = 0 ; x < 5 ; x++ ) sum += x*2; Startvärde x =0 varje varv x++

3 William Sandqvist william@kth.se C:s for-loop Vi tar hjälp av Achilles (Brad Pitt)

4 William Sandqvist william@kth.se Zenons paradox och for-loopen Den snabbfotade Achilles ska tävla mot en sköldpadda. Zenon säger att Achilles aldrig kan hinna ifatt sköldpaddan om denna får en meters försprång …

5 William Sandqvist william@kth.se Varför skulle Achilles inte kunna hinna ikapp sköldpaddan? När Achilles hunnit ifatt försprånget på 1 m, har sköldpaddan redan hunnit ytterligare en bit, och när Achilles väl hunnit fram till den punkten så har ju sköldpaddan gått vidare … Resonemanget kan sedan fortsättas i det oändliga!

6 William Sandqvist william@kth.se Matematikerns svar Achilles, A hastighet 1 m/s Sköldpaddan, S hastighet ½ m/s försprång 1 m ikapp efter ett oändligt antal iterationer vid sträckan : = S ikapp!

7 William Sandqvist william@kth.se Vi tar hjälp av C:s for-loop for (s=0, x=1, count=1; count<=limit; count++, x*=2) { s += 1.0/x ; } C:s kommaoperator gör att vi direkt kan initiera sträcka och iterationsnummer. Vi kan även räkna fram 2-potensen och uppdatera iterationsnumret varje varv. I for-loopens ”kropp” räknas den aritmetiska serien fram.

8 William Sandqvist william@kth.se Programmet zeno.c /* zeno.c -- series sum */ #include #include int main(void) { int count; float s, x; int limit; printf("How many terms do you want?\n"); scanf("%d", &limit); for( s=0, x=1, count=0; count<=limit; count++, x*=2) { s += 1.0/x; printf(”S = %f at count = %d.\n", s, count); } system("PAUSE"); return 0; } Exemplet är från: C Primer Plus, Stephen Prata ISBN 1-57169-161-8

9 William Sandqvist william@kth.se Programkörning Programkörningen gör det troligt att Achilles hinner ikapp sköldpaddan inom 2 meter från startlinjen. Achilles har hastigheten 1 m/s, så detta kommer att ske efter två sekunder.

10 William Sandqvist william@kth.se C:s for-loop är flexibel En nedräkning … for( secs = 5 ; secs > 0 ; secs--) Öka i steg om 13 … for( n = 2 ; n < 60 ; n +=13) Räkna bokstäver i stället för siffror … for( ch = ’A’ ; ch <= ’Z’ ; ch++)

11 William Sandqvist william@kth.se C:s for-loop är flexibel Procentuell ökning … for(skuld=100.0;skuld<150.0;skuld*=1.1) Evighets-slinga … for( ; ; )

12 William Sandqvist william@kth.se Achilles springer … Fysik i Lund Achilles och Sköldpaddan


Ladda ner ppt "William Sandqvist Är Du bra på for-loopar? Ge triangelns höjd: 12 1>............*............ 2>...........***........... 3>..........*****.........."

Liknande presentationer


Google-annonser