1 00:00:00,000 --> 00:00:13,290 2 00:00:13,290 --> 00:00:14,570 >> ROB BOWDEN: Hi, Im 'Rob. 3 00:00:14,570 --> 00:00:17,610 Ac yr wyf yn gobeithio y byddwch yn eich cyhuddo ar gyfer credyd. 4 00:00:17,610 --> 00:00:20,710 Beth felly yn gyntaf mae angen i ni ei wneud yn gofyn am y cerdyn credyd 5 00:00:20,710 --> 00:00:22,710 nifer o'r defnyddwyr. 6 00:00:22,710 --> 00:00:25,060 Yma, rydym yn defnyddio getLongLong. 7 00:00:25,060 --> 00:00:29,070 Gallech hefyd wedi defnyddio getString, ond yn yr achos hwnnw, byddai angen i chi i wirio 8 00:00:29,070 --> 00:00:32,340 nad oedd unrhyw anrhifol gymeriadau yn y llinyn. 9 00:00:32,340 --> 00:00:34,560 Felly, byddwn yn defnyddio getLongLong. 10 00:00:34,560 --> 00:00:38,070 >> Cofiwch na allwch ddefnyddio rhywbeth fel getInt, gan fod y nifer a fydd yn 11 00:00:38,070 --> 00:00:40,650 rhy fawr i ffitio mewn gyfanrif. 12 00:00:40,650 --> 00:00:44,480 Unwaith y byddwn wedi y rhif hwnnw, yr ydym yn gweld fan hon y dolen amser. 13 00:00:44,480 --> 00:00:48,210 Felly, mae hyn dolen tra yn gweithredu Algorithm Luhn bod chi 14 00:00:48,210 --> 00:00:50,980 weld yn y fanyleb pset. 15 00:00:50,980 --> 00:00:53,830 >> Ac mae'n mynd mewn gwirionedd i fod ychydig yn glyfar. 16 00:00:53,830 --> 00:01:00,800 Felly, yn y fanyleb pset, yn sylwi bod Camau Un a Dau ar wahân. 17 00:01:00,800 --> 00:01:05,160 Rydym yn gyntaf yn mynd dros y cerdyn credyd cyfan nifer, yn chwilio am bob eraill 18 00:01:05,160 --> 00:01:09,775 cymeriad gan ddechrau o'r ail cymeriad diwethaf, a'u lluosi 19 00:01:09,775 --> 00:01:11,750 ac ychwanegu holl digid. 20 00:01:11,750 --> 00:01:16,150 Yna, ar ôl hynny, rydym yn ychwanegu mewn pob un o'r digidau eraill. 21 00:01:16,150 --> 00:01:20,660 >> Felly, yn hytrach na gwneud hynny mewn dau camau ar wahân, rydym yn mynd i gyfuno 22 00:01:20,660 --> 00:01:24,430 i mewn i un iteriad dros y rhif cerdyn credyd cyfan. 23 00:01:24,430 --> 00:01:29,710 Yma, rydym yn gweld hafal digid cyf int rhif cerdyn credyd, mod 10. 24 00:01:29,710 --> 00:01:32,050 Beth yw rhif cerdyn credyd mod 10 yn ei wneud? 25 00:01:32,050 --> 00:01:35,750 Mae'n rhoi digid olaf ni yn nifer cyfan. 26 00:01:35,750 --> 00:01:39,340 Felly cofiwch, os ydym yn rhannu'r rhifo i fyny o 10, yna bydd y gweddill 27 00:01:39,340 --> 00:01:42,180 fyddai beth bynnag bod digid olaf yn. 28 00:01:42,180 --> 00:01:46,560 23 wedi'i rannu â 10, mae'r Bydd gweddill fod yn 3. 29 00:01:46,560 --> 00:01:53,760 >> Felly, y digid olaf, yn awr yn y fan hon, rydym yn gweld rydym yn canghennog ar amryfal â 2. 30 00:01:53,760 --> 00:01:57,630 Felly, yr hyn yr ydym yn mynd i gael ei ddefnyddio amryfal 2 amdano yn gwahaniaethu rhwng 31 00:01:57,630 --> 00:02:02,110 un o'r "pob rifau eraill o yr ail digid rhifau ". 32 00:02:02,110 --> 00:02:08,310 Amryfal 2 yn mynd i ddechrau fel ffug, gan fod y digid olaf ni ddylid 33 00:02:08,310 --> 00:02:11,750 yn cael eu hystyried gan y ail digid diwethaf. 34 00:02:11,750 --> 00:02:16,760 >> Felly, yna ar ddiwedd hyn ar gyfer dolen, rydym yn weld ein bod yn mynd i newid hyn 35 00:02:16,760 --> 00:02:18,870 o ffug wir. 36 00:02:18,870 --> 00:02:22,520 Ar y ailadroddiad nesaf y i ddolen, mae'n mynd i ystyried yn wir hyd nes 37 00:02:22,520 --> 00:02:25,090 y diwedd, pan fyddwn yn newid rhag wir er mwyn ffug. 38 00:02:25,090 --> 00:02:28,290 Oherwydd wedyn byddwn yn ar y trydydd i digid olaf, nad yw'n un o'r 39 00:02:28,290 --> 00:02:32,210 digid y dylem luosi â 2. 40 00:02:32,210 --> 00:02:37,410 >> Felly, os ydym yn digwydd bod yn un o'r rhai a digid yr ydym am eu lluosi â 2, 41 00:02:37,410 --> 00:02:40,610 rydym yn gweld ein bod yn ychwanegu at ein prawfswm. 42 00:02:40,610 --> 00:02:43,640 Ac yma, rydym yn defnyddio'r gweithredwr deiran unwaith 43 00:02:43,640 --> 00:02:45,470 unwaith eto fod ychydig yn glyfar. 44 00:02:45,470 --> 00:02:50,170 Felly, os cyf digid yn llai na 5, yna gallwn dim ond gwneud amseroedd digid cyf 2. 45 00:02:50,170 --> 00:02:50,690 Mae hynny'n syml. 46 00:02:50,690 --> 00:02:52,770 Os yw'n 1, yna rydym am ychwanegu 2. 47 00:02:52,770 --> 00:02:54,090 Os yw'n 2, rydym am ychwanegu 4. 48 00:02:54,090 --> 00:02:55,530 Os yw'n 4, rydym am ychwanegu 8. 49 00:02:55,530 --> 00:02:57,400 >> Felly beth sy'n arbennig am 5? 50 00:02:57,400 --> 00:03:00,290 Wel, 5 gwaith 2 yw 10. 51 00:03:00,290 --> 00:03:05,920 A chofiwch o'r fanyleb pset y rydym eisiau ychwanegu'r digidau y 52 00:03:05,920 --> 00:03:09,300 amseroedd rhif 2, ac nid y amseroedd rhif 2 ei hun. 53 00:03:09,300 --> 00:03:13,920 Felly, os yw'r rhif gwreiddiol yn 7, 7 gwaith 2 14. 54 00:03:13,920 --> 00:03:18,930 Rydym yn awyddus i ychwanegu 1 ynghyd â 4 i nifer, nid yw 14. 55 00:03:18,930 --> 00:03:24,050 >> Felly dyma, os yw'r rhif yn 5 neu fwy, yr hyn rydym yn ei wneud yn digid cyf 56 00:03:24,050 --> 00:03:26,470 amseroedd 2 llai blwch 9. 57 00:03:26,470 --> 00:03:29,940 Ac os ydych yn meddwl am hynny, 5 gwaith 2 yw 10. 58 00:03:29,940 --> 00:03:33,130 Ac felly rydym yn ychwanegu 1, sydd 10 llai blwch 9. 59 00:03:33,130 --> 00:03:35,490 A 6 gwaith 2 12. 60 00:03:35,490 --> 00:03:38,380 Felly, rydym yn ychwanegu 3, sy'n yw 12 minws 9. 61 00:03:38,380 --> 00:03:40,250 Ac mae hynny'n gweithio ar gyfer pob rhif. 62 00:03:40,250 --> 00:03:43,330 >> Felly, dyna beth rydym yn ychwanegu i'n checksum. 63 00:03:43,330 --> 00:03:49,970 Ac arall mae hyn yn beth sy'n trin Cam Mae dau o'r algorithm Luhn, sy'n yn unig 64 00:03:49,970 --> 00:03:55,010 ychwanegu'r digid os nad yw'n digwydd i fod yn un o'r pob digidau eraill. 65 00:03:55,010 --> 00:04:01,440 Felly, ar ôl i ni gael y, mae hyn yn cadw golwg ar y ddau gyntaf cymeriadau o'r 66 00:04:01,440 --> 00:04:05,220 rhif y cerdyn credyd, y ddau gyntaf digidau, gan ein bod yn mynd yn y pen draw 67 00:04:05,220 --> 00:04:08,980 i am ddefnyddio hynny i lawr yma i wirio, iawn, a Visa wedi dechrau 68 00:04:08,980 --> 00:04:14,440 â hyn, ac mae anghenion American Express i ddechrau gyda hyn, ac yn y blaen. 69 00:04:14,440 --> 00:04:16,850 >> Yn olaf, rydym yn ei wneud cerdyn credyd nifer yn dychwelyd cerdyn credyd 70 00:04:16,850 --> 00:04:18,730 nifer wedi'i rannu â 10. 71 00:04:18,730 --> 00:04:19,829 Pam yr ydym yn gwneud hynny? 72 00:04:19,829 --> 00:04:22,070 Wel, rydym yn unig drin y digid olaf. 73 00:04:22,070 --> 00:04:24,880 Bydd rannu â 10 symud y nifer cyfan drosodd. 74 00:04:24,880 --> 00:04:27,150 Felly nawr pan fyddwn dolen yn ôl, rydym yn mynd i gael ei drin y 75 00:04:27,150 --> 00:04:28,540 ail digid diwethaf. 76 00:04:28,540 --> 00:04:31,060 Yna, pan fyddwn yn taro eto, rydym yn mynd i dorri oddi ar y ail bara 77 00:04:31,060 --> 00:04:35,060 digid, cefn dolen, ac yn trin y trydydd i bara digid, ac yn y blaen, hyd nes y bydd 78 00:04:35,060 --> 00:04:40,120 nifer yn cyrraedd 0, a phryd rydym yn torri allan o'r cylch amser. 79 00:04:40,120 --> 00:04:43,560 >> Rydym ni hefyd yn cadw golwg ar y credyd hyd rhif cerdyn, gan fod hynny'n 80 00:04:43,560 --> 00:04:48,440 bwysig gwahaniaethu a yw'n rhif cerdyn credyd dilys. 81 00:04:48,440 --> 00:04:53,560 Felly nawr, ar ôl i ni wedi cyfrifo y checksum, gallwn benderfynu a yw'n 82 00:04:53,560 --> 00:04:55,180 yn gerdyn dilys. 83 00:04:55,180 --> 00:04:58,010 Y mod checksum 10 yn rhan o algorithm Luhn yn. 84 00:04:58,010 --> 00:05:03,360 Os checksum mod 10 yn dychwelyd rhywbeth heb fod yn sero, yna bydd hyn yn dychwelyd yn wir, 85 00:05:03,360 --> 00:05:06,650 ac os felly, y nifer Mae'n rhaid i fod yn annilys. 86 00:05:06,650 --> 00:05:12,590 >> Fel arall, os mod checksum 10 yn 0, yna gallwn barhau. 87 00:05:12,590 --> 00:05:18,360 Mae hyn yn fawr arall os yn ei ddweud, os yw'r cyntaf ddau ddigid yn hafal i Amex 1, 88 00:05:18,360 --> 00:05:23,640 lle i fyny yma, gwelwn fod AMEX 1, yn unol â'r fanyleb, yn 34. 89 00:05:23,640 --> 00:05:26,595 A byddwn hefyd gymharu i Amex 2, sef 37. 90 00:05:26,595 --> 00:05:30,360 91 00:05:30,360 --> 00:05:34,210 Ac mae'r cerdyn credyd hyd rif yw hafal i'r disgwyliedig American Express 92 00:05:34,210 --> 00:05:37,910 hyd gerdyn, yna gallwn argraffu American Express. 93 00:05:37,910 --> 00:05:41,920 >> Byddwn yn gwneud rhywbeth tebyg gyda Visa. 94 00:05:41,920 --> 00:05:51,940 Mae angen y ddau ddigid cyntaf o fod yn fwy na neu'n hafal i 40, neu lai 95 00:05:51,940 --> 00:05:54,290 na neu'n hafal i 49. 96 00:05:54,290 --> 00:05:57,180 Mae'r rhai cynrychioli cardiau Visa dilys. 97 00:05:57,180 --> 00:06:01,530 Ac mae angen i'r hyd i fod yn hafal i Visa Hyd 1 neu Visa Hyd 2. 98 00:06:01,530 --> 00:06:07,320 Ac felly mae'n rhaid i'r hyd fod naill ai 13 neu 16 digid. 99 00:06:07,320 --> 00:06:12,240 >> Ac yn olaf gyda MasterCard, mae'n debyg i Visa, bod y ddau gyntaf 100 00:06:12,240 --> 00:06:15,340 Mae angen digidau fod mewn rhai amrywiaeth, ac mae'n rhaid i'r hyd 101 00:06:15,340 --> 00:06:19,440 fod yn union 16 digid. 102 00:06:19,440 --> 00:06:24,390 Felly, os unrhyw un o'r achosion hynny yn dal, yna yn yr achos cyntaf, byddwn yn argraffu AMEX. 103 00:06:24,390 --> 00:06:26,310 Os yw'r achos hwn yn dal, byddwn yn argraffu Visa. 104 00:06:26,310 --> 00:06:28,400 Os yw'r achos hwn yn dal, byddwn ni argraffu MasterCard. 105 00:06:28,400 --> 00:06:32,170 >> Ond os nad oes un o'r rhai yn dal, hyd yn oed os yw'r checksum yn ddilys, 106 00:06:32,170 --> 00:06:33,900 rydym yn dal i argraffu annilys. 107 00:06:33,900 --> 00:06:37,050 Oherwydd nad yw'n un o mathau hynny o gardiau. 108 00:06:37,050 --> 00:06:40,030 Fy enw i yw Rob, ac yr wyf yn gobeithio y byddwch yn diddorol credyd dod o hyd. 109 00:06:40,030 --> 00:06:46,272