1 00:00:00,000 --> 00:00:00,340 2 00:00:00,340 --> 00:00:02,690 >> DAVID MALAN: Anta at vi ønsker å skrive et program som ber brukeren 3 00:00:02,690 --> 00:00:05,100 for en streng og deretter kapitaliserer strengen. 4 00:00:05,100 --> 00:00:09,000 Vel, la oss starte med noen kjente kode erklære en streng som heter s og 5 00:00:09,000 --> 00:00:11,380 tilordne den avkastningen Verdien av getstring. 6 00:00:11,380 --> 00:00:14,910 Og la oss nå fortsette å iterere over tegnene i denne strengen. 7 00:00:14,910 --> 00:00:16,000 Vel, hvordan du gjør det? 8 00:00:16,000 --> 00:00:19,350 Det viser seg at en streng er bare en sekvens av tegn, men mer 9 00:00:19,350 --> 00:00:23,320 på riktig måte, er en streng en rekke tegn, som betyr at vi kan bruke 10 00:00:23,320 --> 00:00:27,590 hakeparentes notasjon til indeksen inn en streng og få på individnivå 11 00:00:27,590 --> 00:00:28,680 tegn. 12 00:00:28,680 --> 00:00:30,980 >> Med andre ord, kan vi gjør følgende. 13 00:00:30,980 --> 00:00:36,730 For int, får jeg 0, og n blir, si, lengden av S, ved hjelp 14 00:00:36,730 --> 00:00:37,530 vår funksjon [? røre?] 15 00:00:37,530 --> 00:00:38,630 [? linje,?] 16 00:00:38,630 --> 00:00:40,450 i er mindre enn n i + +. 17 00:00:40,450 --> 00:00:45,290 Med andre ord, med denne sløyfen, vi vil iterere over alle n bokstaver 18 00:00:45,290 --> 00:00:46,670 i strengen s. 19 00:00:46,670 --> 00:00:51,680 Og i løpet av denne sløyfen, kommer jeg til å sjekk, hvis den i-ende tegn på s 20 00:00:51,680 --> 00:00:57,630 større enn eller lik til små bokstaver a, og den i-te tegn er mindre enn eller 21 00:00:57,630 --> 00:01:02,370 lik en små bokstaver c, så jeg ønsker å fortsette å kapitalisere på bokstaven. 22 00:01:02,370 --> 00:01:08,030 Med andre ord, jeg ønsker å skrive ut% c som plassholder og erstatning i for 23 00:01:08,030 --> 00:01:11,120 som plassholder s brakett jeg. 24 00:01:11,120 --> 00:01:14,390 >> Men da trenger jeg å konvertere s brakett jeg til store bokstaver. 25 00:01:14,390 --> 00:01:18,930 For å gjøre dette, kan jeg bare trekker uansett forskjellen er mellom 26 00:01:18,930 --> 00:01:24,120 små bokstaver a og kapital A. Vel, jeg faktisk husker at kapital A er 27 00:01:24,120 --> 00:01:27,160 65 i ASCII, og små bokstaver en er 97. 28 00:01:27,160 --> 00:01:29,210 Så forskjellen er teknisk 32.. 29 00:01:29,210 --> 00:01:31,620 Så jeg kunne bare hardt kode 32 her. 30 00:01:31,620 --> 00:01:33,870 Men jeg kan ikke nødvendigvis huske disse tallene. 31 00:01:33,870 --> 00:01:37,250 >> Og dessuten, hva om de variere fra datamaskinen? 32 00:01:37,250 --> 00:01:38,520 Mest sannsynlig er de ikke. 33 00:01:38,520 --> 00:01:42,460 Men poenget er fortsatt at jeg kan fortsatt generalisere at aritmetiske uttrykk 34 00:01:42,460 --> 00:01:46,550 som bare uansett forskjellen mellom inn en liten en og en stor A 35 00:01:46,550 --> 00:01:50,880 er hva jeg ønsker å trekke seg fra denne spesielle liten bokstav. 36 00:01:50,880 --> 00:01:54,500 >> Nå, dersom bestemt bokstav er ikke små bokstaver, jeg rett og slett 37 00:01:54,500 --> 00:01:56,620 ønsker å skrive den ut. 38 00:01:56,620 --> 00:02:01,110 printf,% c som min plassholder, s brakett jeg. 39 00:02:01,110 --> 00:02:05,150 På bunnen av dette programmet, la oss ganske enkelt skrive ut linjeskift slik at min 40 00:02:05,150 --> 00:02:07,520 meldingen vises på en ny linje for seg selv. 41 00:02:07,520 --> 00:02:11,540 >> La oss nå kompilere dette programmet med make capitalize0. 42 00:02:11,540 --> 00:02:13,900 La oss kjøre det med capitalize0. 43 00:02:13,900 --> 00:02:17,190 Og la oss skrive inn et ord som hallo i små bokstaver. 44 00:02:17,190 --> 00:02:19,960 Jeg får tilbake HELLO med store bokstaver som forventet. 45 00:02:19,960 --> 00:02:25,210 Men la oss prøve en mer test, denne gangen med mitt eget navn, D-A-V-I-D, men med 46 00:02:25,210 --> 00:02:28,170 den første D kapitalisert, bare i tilfelle jeg rotet noe opp 47 00:02:28,170 --> 00:02:29,430 med det første røye. 48 00:02:29,430 --> 00:02:34,250 Enter, og D-A-V-I-D med store bokstaver skrives også. 49 00:02:34,250 --> 00:02:36,873