1 00:00:07,090 --> 00:00:07,370 [Powered by Google Translate] Vipul Шехават: Привет. 2 00:00:07,370 --> 00:00:09,410 В этом видео я буду знакомить вас с одним из самых 3 00:00:09,410 --> 00:00:11,260 основные понятия в логике и 4 00:00:11,260 --> 00:00:13,880 программирование, логическое значение. 5 00:00:13,880 --> 00:00:16,210 Если вам интересно, о наименовании, логические значения и 6 00:00:16,210 --> 00:00:19,440 Условия назван в честь Джорджа Буля, 19-го века 7 00:00:19,440 --> 00:00:22,030 математика, который впервые, что сейчас называется булевой 8 00:00:22,030 --> 00:00:23,980 Логика, основанная на группировке и 9 00:00:23,980 --> 00:00:26,030 сравнение логических значений. 10 00:00:26,030 --> 00:00:28,250 >> Так что же такое логическое значение? 11 00:00:28,250 --> 00:00:30,920 Логическое значение переменной, которая просто имеет два возможных 12 00:00:30,920 --> 00:00:33,710 условий, истинного и ложного. 13 00:00:33,710 --> 00:00:35,380 Вы можете думать об этом как выключатель света. 14 00:00:35,380 --> 00:00:38,530 Это может быть либо включен, либо выключен, истинным или ложным. 15 00:00:38,530 --> 00:00:41,880 Кроме того, двоичные числа могут быть либо один, либо нулю, что 16 00:00:41,880 --> 00:00:45,680 аналогично то же самое, истинное или ложное. 17 00:00:45,680 --> 00:00:46,840 Просто, не так ли? 18 00:00:46,840 --> 00:00:48,750 Понятие логической переменной легко 19 00:00:48,750 --> 00:00:51,720 понимаю, но способы, которыми вы можете управлять и 20 00:00:51,720 --> 00:00:54,570 объединить их позволяет гораздо большей сложностью. 21 00:00:54,570 --> 00:00:57,030 В дополнение к двум основным логические значения, 22 00:00:57,030 --> 00:00:59,350 Есть много логических операторов, которые могут объединить два 23 00:00:59,350 --> 00:01:01,760 Логические значения в один. 24 00:01:01,760 --> 00:01:03,540 >> Два самых основных, но самое важное 25 00:01:03,540 --> 00:01:06,570 Операторы, есть и и OR. 26 00:01:06,570 --> 00:01:09,950 И оператор результатов в значении верно, только если оба 27 00:01:09,950 --> 00:01:14,630 значения она принимает верны, так ложной и истинной является ложным. 28 00:01:14,630 --> 00:01:17,540 Кроме того, ложные и ложным является ложным. 29 00:01:17,540 --> 00:01:21,080 Только Верный и Истинный равно правда. 30 00:01:21,080 --> 00:01:24,050 Или результаты оператора в значение истина, если любой из 31 00:01:24,050 --> 00:01:25,620 значения она принимает верны. 32 00:01:25,620 --> 00:01:30,460 Таким образом, ложная или ложным является ложным, но истинно или ложно это правда, и 33 00:01:30,460 --> 00:01:33,710 истинное или истинное утверждение также верно. 34 00:01:33,710 --> 00:01:36,560 НЕ оператор просто принимает логические переменные и дает 35 00:01:36,560 --> 00:01:37,830 Вы противоположную от него. 36 00:01:37,830 --> 00:01:40,950 Таким образом, истинное становится ложным и ложное становится истинным. 37 00:01:40,950 --> 00:01:43,130 Если вы положите все это вместе, переменные 38 00:01:43,130 --> 00:01:46,320 Операторы, вы создаете логическое выражение. 39 00:01:46,320 --> 00:01:48,550 >> Теперь давайте посмотрим на пример вложения этих булевых 40 00:01:48,550 --> 00:01:49,950 выражений. 41 00:01:49,950 --> 00:01:51,840 Вы помните порядок операций? 42 00:01:51,840 --> 00:01:54,700 Как с числами, логические выражения могут быть сгруппированы по 43 00:01:54,700 --> 00:01:56,270 с помощью скобок. 44 00:01:56,270 --> 00:02:00,150 Таким образом, существует три основных выражений здесь, а не г, у ИЛИ 45 00:02:00,150 --> 00:02:04,740 НЕ г, а х и у ИЛИ НЕ г. 46 00:02:04,740 --> 00:02:07,080 Мы можем понять значения этих, глядя на 47 00:02:07,080 --> 00:02:09,020 внутри и работает наш выход. 48 00:02:09,020 --> 00:02:12,850 Итак, давайте предположим, х, правда, у верно, и г тоже верно. 49 00:02:12,850 --> 00:02:15,270 Что бы не оценивать г к? 50 00:02:15,270 --> 00:02:20,970 Поскольку мы начинаем с истинной, а не г будет просто ложной. 51 00:02:20,970 --> 00:02:26,230 Так что теперь у нас есть ложная или у. 52 00:02:26,230 --> 00:02:29,740 Если посмотреть сверху, можно увидеть, что у верно, у или ложной 53 00:02:29,740 --> 00:02:32,870 будет по-прежнему просто быть правдой. 54 00:02:32,870 --> 00:02:37,580 Наконец мы имеем х и верно. 55 00:02:37,580 --> 00:02:39,300 Так что х и правдой? 56 00:02:39,300 --> 00:02:42,590 х истинно и верно, то верно, так все это дело 57 00:02:42,590 --> 00:02:45,070 истинен. 58 00:02:45,070 --> 00:02:47,270 >> Далее, давайте посмотрим, как эти логические выражения могут 59 00:02:47,270 --> 00:02:49,890 на самом деле быть использованы в языке программирования. 60 00:02:49,890 --> 00:02:52,900 В C, синтаксис для логических операций несколько отличается 61 00:02:52,900 --> 00:02:55,520 со слов AND, OR, и не очень. 62 00:02:55,520 --> 00:02:57,210 Давайте рассмотрим синтаксис. 63 00:02:57,210 --> 00:03:00,510 Для использования И оператор, мы пишем двойной амперсанд. 64 00:03:00,510 --> 00:03:03,620 ИЛИ оператор двойной характер трубопровода. 65 00:03:03,620 --> 00:03:05,780 Это прямой вертикальной линии, которую вы, вероятно, может 66 00:03:05,780 --> 00:03:09,070 Найти над Ввод или Возврат клавиши на клавиатуре. 67 00:03:09,070 --> 00:03:12,550 И НЕ оператор просто восклицательный знак. 68 00:03:12,550 --> 00:03:15,550 Таким образом, чтобы переписать выражение, что было раньше, мы бы просто 69 00:03:15,550 --> 00:03:27,010 написать эту х && у | |! г. 70 00:03:27,010 --> 00:03:29,250 Вот только принимать именно то, что мы имели раньше, и поворот 71 00:03:29,250 --> 00:03:31,870 его в синтаксисе C. 72 00:03:31,870 --> 00:03:34,370 >> Теперь, когда мы перевели наши логическое выражение в коде, 73 00:03:34,370 --> 00:03:36,160 Как мы на самом деле его использовать? 74 00:03:36,160 --> 00:03:38,170 Допустим, у нас есть некоторый код, который должен выполняться только если 75 00:03:38,170 --> 00:03:40,330 определенное выражение истинно. 76 00:03:40,330 --> 00:03:42,750 Для этой цели в значительной степени все языки программирования 77 00:03:42,750 --> 00:03:45,190 поддержки, если состояние. 78 00:03:45,190 --> 00:03:47,870 Скажем, у нас есть логическая переменная, х, и мы хотим, некоторые 79 00:03:47,870 --> 00:03:50,850 код для выполнения, только если х истинна. 80 00:03:50,850 --> 00:03:54,900 Мы бы просто написать слово, если поставить скобки и положить 81 00:03:54,900 --> 00:03:57,800 Логическое выражение в этих скобках. 82 00:03:57,800 --> 00:03:59,680 После этого мы обернуть код, который мы хотим 83 00:03:59,680 --> 00:04:01,080 выполнить в фигурные скобки. 84 00:04:07,160 --> 00:04:08,150 Что делать, если есть некоторый код, вы хотите, чтобы 85 00:04:08,150 --> 00:04:10,260 выполнить, если х не так? 86 00:04:10,260 --> 00:04:13,310 Просто напишите слово еще после, если заявление, обертывание 87 00:04:13,310 --> 00:04:16,930 другой код в фигурных скобках, а затем, что код будет 88 00:04:16,930 --> 00:04:18,399 выполняться, если х не верно. 89 00:04:26,640 --> 00:04:29,840 >> Еще одной полезной конструкцией языка еще, если. 90 00:04:29,840 --> 00:04:32,210 Пусть имеются две логические вы хотели бы рассмотреть, 91 00:04:32,210 --> 00:04:34,330 назовем их х и у. 92 00:04:34,330 --> 00:04:37,340 Мы заявляем, эти переменные, чтобы быть истинным и ложным. 93 00:04:37,340 --> 00:04:40,540 Если х и у верно, вы выполните первый блок 94 00:04:40,540 --> 00:04:42,630 Код в этих фигурных скобках. 95 00:04:42,630 --> 00:04:46,470 Иначе, если х и у верно, вы выполняете следующий блок 96 00:04:46,470 --> 00:04:50,590 код, и еще, что вы выполните последний блок кода. 97 00:04:50,590 --> 00:04:52,650 Работа с булевыми значениями, как это полезно, но 98 00:04:52,650 --> 00:04:55,750 Вы действительно ограничивается только несколькими условиями. 99 00:04:55,750 --> 00:04:58,400 Логические может стать гораздо более мощным, когда вы вводите 100 00:04:58,400 --> 00:04:59,900 сравнений. 101 00:04:59,900 --> 00:05:01,280 Эти способы для сравнения значений, которые 102 00:05:01,280 --> 00:05:03,300 изначально не Boolean. 103 00:05:03,300 --> 00:05:06,060 Чтобы посмотреть, если два значения равны, вы можете использовать равных 104 00:05:06,060 --> 00:05:09,340 равно, что является истинным, если они равны и ложно, если 105 00:05:09,340 --> 00:05:10,530 они не являются. 106 00:05:10,530 --> 00:05:15,360 Другие распространенные сравнения меньше, больше, меньше 107 00:05:15,360 --> 00:05:19,740 или равным, а больше или равно. 108 00:05:19,740 --> 00:05:22,220 >> Все, что я до сих пор покрыта была довольно абстрактно, так 109 00:05:22,220 --> 00:05:24,320 давайте введем эти сравнения в последней 110 00:05:24,320 --> 00:05:25,850 Конкретный пример. 111 00:05:25,850 --> 00:05:27,130 Предположим, что есть две переменные, 112 00:05:27,130 --> 00:05:29,430 температуры и isHungry. 113 00:05:29,430 --> 00:05:31,560 Температура является число с плавающей точкой, поэтому она может иметь 114 00:05:31,560 --> 00:05:33,090 знаков после запятой. 115 00:05:33,090 --> 00:05:35,440 Вы программирование очень простое приложение, которое говорит 116 00:05:35,440 --> 00:05:38,270 кто-то, что есть в зависимости от температуры. 117 00:05:38,270 --> 00:05:41,010 Если вы голодны, а и температура больше или 118 00:05:41,010 --> 00:05:45,060 равным 100, вы можете распечатать съесть мороженое. 119 00:05:45,060 --> 00:05:48,370 Иначе, если вы голодны и и температура ниже 120 00:05:48,370 --> 00:05:52,420 или равны нулю, вы можете Е ("есть острую пищу"). 121 00:05:52,420 --> 00:05:55,200 Наконец, если вы не голодны вообще, вы можете напечатать "не 122 00:05:55,200 --> 00:05:56,710 ем, а питаюсь ". 123 00:05:56,710 --> 00:06:00,130 >> Я Vipul Shekhawat, и это CS50.