1 00:00:00,000 --> 00:00:13,290 2 00:00:13,290 --> 00:00:14,570 >> ROB BOWDEN: Ola, eu son Rob. 3 00:00:14,570 --> 00:00:17,610 E eu espero que cobra up para o crédito. 4 00:00:17,610 --> 00:00:20,710 Entón o primeiro que temos que facer é solicitar a tarxeta de crédito 5 00:00:20,710 --> 00:00:22,710 número do usuario. 6 00:00:22,710 --> 00:00:25,060 Aquí, estamos usando getLongLong. 7 00:00:25,060 --> 00:00:29,070 Tamén podería usar getString, pero nese caso, ten que comprobar 8 00:00:29,070 --> 00:00:32,340 que non houbese non numérica caracteres na cadea. 9 00:00:32,340 --> 00:00:34,560 Entón imos usar getLongLong. 10 00:00:34,560 --> 00:00:38,070 >> Lembre que non pode usar algo como getInt, xa que o número será 11 00:00:38,070 --> 00:00:40,650 demasiado grande para caber nun enteiro. 12 00:00:40,650 --> 00:00:44,480 Unha vez que temos ese número, nós ver aquí este loop while. 13 00:00:44,480 --> 00:00:48,210 Polo tanto, este loop while está implementando Algoritmo de Luhn que 14 00:00:48,210 --> 00:00:50,980 ver na especificación pset. 15 00:00:50,980 --> 00:00:53,830 >> E iso está realmente a suceder a ser un pouco intelixente. 16 00:00:53,830 --> 00:01:00,800 Entón, na especificación pset, teña en conta que Etapas un e dous son separados. 17 00:01:00,800 --> 00:01:05,160 En primeiro lugar, pasar por riba de todo a tarxeta de crédito número, mirando para todos os demais 18 00:01:05,160 --> 00:01:09,775 personaxe a partir do segundo para último carácter, e multiplicándose os 19 00:01:09,775 --> 00:01:11,750 e engadindo as díxitos. 20 00:01:11,750 --> 00:01:16,150 Entón, despois diso, nós engadimos en todos os outros díxitos. 21 00:01:16,150 --> 00:01:20,660 >> Entón, en vez de facer os dous etapas separadas, imos combinar 22 00:01:20,660 --> 00:01:24,430 los nunha iteración sobre o número completo da tarxeta de crédito. 23 00:01:24,430 --> 00:01:29,710 Aquí vemos int iguais díxitos actual número da tarxeta de crédito, mod 10. 24 00:01:29,710 --> 00:01:32,050 Cal é o número da tarxeta de crédito mod 10 está facendo? 25 00:01:32,050 --> 00:01:35,750 Está nos dando o último díxito o número enteiro. 26 00:01:35,750 --> 00:01:39,340 Entón lembre de que se dividiu o número por 10, entón o resto 27 00:01:39,340 --> 00:01:42,180 sería todo o que o último díxito é. 28 00:01:42,180 --> 00:01:46,560 23 dividido por 10, o restante será 3. 29 00:01:46,560 --> 00:01:53,760 >> Así, o último díxito, agora aquí vemos estamos ramificados en gráfica por 2. 30 00:01:53,760 --> 00:01:57,630 Entón, o que nós imos estar usando gráfica por 2 para diferenciarse 31 00:01:57,630 --> 00:02:02,110 un dos "todos os outros números de o segundo "números. 32 00:02:02,110 --> 00:02:08,310 Gráfica por 2 comezará como falsos, xa que o último díxito non debe 33 00:02:08,310 --> 00:02:11,750 ser considerada a partir do segundo para último díxito. 34 00:02:11,750 --> 00:02:16,760 >> Entón, a continuación, a finais deste loop, nós ver que nós imos cambiar isto 35 00:02:16,760 --> 00:02:18,870 de teito para verdadeiro. 36 00:02:18,870 --> 00:02:22,520 Na seguinte iteración do bucle para, vai considerada verdadeira ata 37 00:02:22,520 --> 00:02:25,090 Ao final, cando cambiamos que de certo para falso. 38 00:02:25,090 --> 00:02:28,290 Porque, entón, estaremos no terceiro para último díxito, o que non é un dos 39 00:02:28,290 --> 00:02:32,210 díxitos que debemos multiplicar por 2. 40 00:02:32,210 --> 00:02:37,410 >> Entón, se ocorrer de estar nun dos díxitos que queremos multiplicar por 2, 41 00:02:37,410 --> 00:02:40,610 vemos que estamos aumentando a nosa suma de comprobación. 42 00:02:40,610 --> 00:02:43,640 E aquí, nós estamos usando o operador ternário para xa 43 00:02:43,640 --> 00:02:45,470 novo ser un pouco intelixente. 44 00:02:45,470 --> 00:02:50,170 Polo tanto, se actual díxito é inferior a 5, a continuación, podemos só facer veces díxitos actual 2. 45 00:02:50,170 --> 00:02:50,690 Isto é simple. 46 00:02:50,690 --> 00:02:52,770 De ser 1, entón queremos engadir 2. 47 00:02:52,770 --> 00:02:54,090 De ser 2, queremos engadir 4. 48 00:02:54,090 --> 00:02:55,530 Se é 4, queremos engadir 8. 49 00:02:55,530 --> 00:02:57,400 >> Entón, o que hai de especial sobre 5? 50 00:02:57,400 --> 00:03:00,290 Ben, 5 veces 2 é 10. 51 00:03:00,290 --> 00:03:05,920 E lembre de que a especificación pset queremos engadir os díxitos do 52 00:03:05,920 --> 00:03:09,300 veces o número 2, e non o número de veces en si 2. 53 00:03:09,300 --> 00:03:13,920 Así, se o número orixinal é de 7, 7 veces 2 é 14. 54 00:03:13,920 --> 00:03:18,930 Queremos engadir 1 máis 4 ao número, non 14. 55 00:03:18,930 --> 00:03:24,050 >> Entón, aquí, se o número for 5 ou superior, o que estamos facendo é o díxito cur 56 00:03:24,050 --> 00:03:26,470 veces 2 menos 9. 57 00:03:26,470 --> 00:03:29,940 E se pensar sobre iso, 5 veces 2 é 10. 58 00:03:29,940 --> 00:03:33,130 E así estamos engadindo 1, que é 10 menos 9. 59 00:03:33,130 --> 00:03:35,490 E 6 veces 2 é 12. 60 00:03:35,490 --> 00:03:38,380 Entón, nós estamos engadindo 3, que é 12 menos 9. 61 00:03:38,380 --> 00:03:40,250 E iso funciona para todos os números. 62 00:03:40,250 --> 00:03:43,330 >> Entón é iso que nós estamos engadindo para a suma de verificación. 63 00:03:43,330 --> 00:03:49,970 E esa outra cousa é o que está lidando Paso Dous dos algoritmo de Luhn, que é só 64 00:03:49,970 --> 00:03:55,010 engadindo o díxito, se iso non acontecer ser un dos outros díxitos cada un. 65 00:03:55,010 --> 00:04:01,440 Así, unha vez que temos de que, este é manter ruta dos dous primeiros caracteres 66 00:04:01,440 --> 00:04:05,220 o número da tarxeta de crédito, os dous primeiros díxitos, xa que estamos indo finalmente 67 00:04:05,220 --> 00:04:08,980 querer usar isto aquí abaixo para comprobar, todo ben, a Visa ten que comezar 68 00:04:08,980 --> 00:04:14,440 con iso, e un necesidades American Express comezar con este, e así por diante. 69 00:04:14,440 --> 00:04:16,850 >> Finalmente, facemos tarxeta de crédito número é igual a tarxeta de crédito 70 00:04:16,850 --> 00:04:18,730 número dividido por 10. 71 00:04:18,730 --> 00:04:19,829 Por que facemos isto? 72 00:04:19,829 --> 00:04:22,070 Ben, nós só colleu o último díxito. 73 00:04:22,070 --> 00:04:24,880 Dividindo por 10 vai cambiar o número enteiro máis. 74 00:04:24,880 --> 00:04:27,150 Entón agora cando volta ao principio, estamos será o manexo 75 00:04:27,150 --> 00:04:28,540 segundo para último díxito. 76 00:04:28,540 --> 00:04:31,060 Entón, cando se loita de novo, nós imos para cortar o penúltimo lugar 77 00:04:31,060 --> 00:04:35,060 díxito, de volta loop, e xestionar a terceira ao último díxito, e así por diante, ata que o 78 00:04:35,060 --> 00:04:40,120 número chega a 0, en que punto que saír do loop while. 79 00:04:40,120 --> 00:04:43,560 >> Estamos tamén mantendo o control do crédito lonxitude número da tarxeta, xa que é 80 00:04:43,560 --> 00:04:48,440 importante distinguir se é un número de tarxeta de crédito válido. 81 00:04:48,440 --> 00:04:53,560 Entón, agora, unha vez que xa calculou o checksum, podemos determinar se 82 00:04:53,560 --> 00:04:55,180 é unha tarxeta válida. 83 00:04:55,180 --> 00:04:58,010 O mod suma 10 é parte do algoritmo de Luhn. 84 00:04:58,010 --> 00:05:03,360 Se de checksum mod 10 volve algo distinto de cero, entón iso vai voltar true, 85 00:05:03,360 --> 00:05:06,650 caso en que, o número debe ser válido. 86 00:05:06,650 --> 00:05:12,590 >> En caso contrario, súmase mod 10 é 0, entón podemos continuar. 87 00:05:12,590 --> 00:05:18,360 Este gran cousa se está a dicir, o primeiro dous díxitos son iguais a American Express 1, 88 00:05:18,360 --> 00:05:23,640 onde ata aquí vemos que AMEX 1, de acordo coa especificación, é de 34. 89 00:05:23,640 --> 00:05:26,595 E nós tamén imos comparalos-lo a American Express 2, que é 37. 90 00:05:26,595 --> 00:05:30,360 91 00:05:30,360 --> 00:05:34,210 E a lonxitude do número de tarxeta de crédito é igual ao esperado American Express 92 00:05:34,210 --> 00:05:37,910 lonxitude tarxeta, entón podemos imprimir American Express. 93 00:05:37,910 --> 00:05:41,920 >> Imos facer unha cousa semellante coa Visa. 94 00:05:41,920 --> 00:05:51,940 Os dous primeiros díxitos Debe ser maior que ou igual a 40, ou menos 95 00:05:51,940 --> 00:05:54,290 que ou igual a 49. 96 00:05:54,290 --> 00:05:57,180 Aqueles representan tarxetas Visa válidos. 97 00:05:57,180 --> 00:06:01,530 E a lonxitude debe ser igual Visa ou Visa Lonxitude 1 Lonxitude 2. 98 00:06:01,530 --> 00:06:07,320 E así, a lonxitude debe ser tanto 13 ou 16 díxitos. 99 00:06:07,320 --> 00:06:12,240 >> E, finalmente, coa MasterCard, é semellante ao visto, que os dous primeiros 100 00:06:12,240 --> 00:06:15,340 díxitos precisan estar nun certo variedade, e a lonxitude debe 101 00:06:15,340 --> 00:06:19,440 ser exactamente 16 díxitos. 102 00:06:19,440 --> 00:06:24,390 Así, se calquera destes casos soster, entón en No primeiro caso, imos imprimir AMEX. 103 00:06:24,390 --> 00:06:26,310 Se este caso ten, imos imprimir Visa. 104 00:06:26,310 --> 00:06:28,400 Se este caso ten, imos imprimir MasterCard. 105 00:06:28,400 --> 00:06:32,170 >> Pero se ningún dos soster, aínda O checksum é válido, 106 00:06:32,170 --> 00:06:33,900 aínda imprimir válido. 107 00:06:33,900 --> 00:06:37,050 ¿Por que non é un dos estes tipos de tarxetas. 108 00:06:37,050 --> 00:06:40,030 O meu nome é Rob, e eu espero que penso interesante de crédito. 109 00:06:40,030 --> 00:06:46,272