Форум программистов, компьютерный форум, киберфорум
C для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.63/8: Рейтинг темы: голосов - 8, средняя оценка - 4.63
0 / 0 / 0
Регистрация: 23.11.2017
Сообщений: 63

Таблица истинности

30.07.2018, 12:27. Показов 1653. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет! Тема такая: есть программа - логический интерпретатор, умеет переводить запись в ОПЗ, выполнять логические действия ( конъюнкция, инверсия и т.д.). Хочу научить интерпретатор считать количество правильных решений, то есть:

Есть у нас выражение(логическое ИЛИ), допустим:

C
1
a+b=0
Это решение правильно при а и b равных 0, то есть 1 решение, на вывод 1.

Или, такое (импликация):

C
1
a->b=1
Это выражение истинно всегда, кроме a=1, а b=0, значит 3 решения, на вывод 3.

Естественно будут более сложные выражение, это только для примера. Я понимаю, что это все надо делать перебором и теперь главный вопрос: Как этот перебор организовать? (программа уже умеет считать выражения типа 1+1 (выдаст 1) и т.д. все логические операции) Может кто помочь? Крайне не хочу использовать классы и структуры, но если кто и с этим подскажет, буду благодарен. Так же стоит сказать, что в 1 выражении переменные могу встречаться по нескольку раз, к примеру вот так ( -> это импликация, а * это логическое И:


C
1
(x1 - x2) * (x2 - x3) * (x3 - x4) = 1

Тут у нас x2 и x3 встречается несколько раз и, получается, простой хак с подсчетом переменных в лексаторе не подойдет, нужно что-то покруче. Буду рад всему, что напишете, заранее спасибо за все подсказки!
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
30.07.2018, 12:27
Ответы с готовыми решениями:

Таблица истинности
Нужно написать программу для построения таблицы истинности функции. F ≡ ((A ↔ B) → C)∧((¬B∧A) → D) В...

Таблица истинности
Таблица истинности

Таблица истинности
Извините что с таким вопросом, но как быстро построить таблицу истинности, смотрела в интернете. Как то непонятно. Перед построением...

3
106 / 93 / 44
Регистрация: 26.07.2015
Сообщений: 197
30.07.2018, 15:07
Очень интересная тема. Нечто подобное видел здесь https://habr.com/company/pvs-studio/blog/414669/ с их механизмом допустимых виртуальных значений.
0
698 / 140 / 57
Регистрация: 20.08.2017
Сообщений: 255
30.07.2018, 20:07
Лучший ответ Сообщение было отмечено Кирилл Корнеев как решение

Решение

На самом деле все не так уж и сложно. Нам все лишь нужно решить уравнение для всех комбинаций значений переменных.

К примеру, у нас есть следующее уравнение: a + b = 0.
Все возможные варианты значений переменных: (0, 0), (0, 1), (1, 0), (1, 1).
Подставляем их в уравнение: (0 + 0 = 0), (0 + 1 = 0), (1 + 0 = 0), (1 + 1 = 0).
Считаем: (0 = 0), (1 ≠ 0), ( 1 ≠ 0), (1 ≠ 0).
Ответ: 1.

Теперь — реализация.

Начнем с самого простого — вариант, где нам изначально известно кол-во переменных:

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
#include <stdio.h>
#include <stdbool.h>
 
/* Функция, проверяющая наше уравнение. Если равенство верно —
   возвращается истина, иначе — ложь. */
bool f(bool a, bool b, bool c, bool d) {
    return (a + b + c + d) == 0;
}
 
int main(void) {
    /* Счетчик кол-ва решений. */
    size_t counter = 0;
 
    /* Четыремя циклами мы добьемся проверкой всех возможных
       комбинаций значений переменных. В общем случае кол-во
       циклов должно равнятся кол-ву переменных. */
    for (unsigned a = 0; a != 2; a++)
        for (unsigned b = 0; b != 2; b++)
            for (unsigned c = 0; c != 2; c++)
                for (unsigned d = 0; d != 2; d++)
                    /* Если равенство верно, увеличиваем счетчик. */
                    if (f(a, b, c, d))
                        counter++;
 
    printf("%zu\n", counter);
}
Теперь — сложнее. Допустим, мы не знаем кол-во переменных в уравнении. Очевидно, что в таком случае мы не сможешь решить задачу первым способом.

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
#include <stdio.h>
#include <stdbool.h>
#include <stdint.h>
 
/* Не стоит использовать библиотечную функцию pow в целочисленных вычислениях,
   т. к. функция pow(a, b) — это фактически exp(a * log(b)). Так что
   мы напишем нашу собственную целочисленную реализацию.
   Можете не обращать на нее внимания. */
unsigned pw(unsigned a, unsigned n) {
    if (n == 0)
        return 1;
 
    unsigned res = a;
 
    while (--n)
        res *= a;
 
    return res;
}
 
/* Функция возвращает значение выражения a_0 + a_1 + … + a_vars_nm.
 
   Как это работает: переменная n содержит 32 бита. Каждый бит считается
   значением одной логической переменной a (т. е. максимально кол-во переменных
   в выражении — 32).
 
   В цикле мы проходим по каждому биту числа n (т. е. по каждой логической переменной
   и прибавляем значение этого бита (лог. переменной) к переменной result.
 
   Я специально выбрал простейшее выражение, чтобы не усложнять код.
   Вы можете вычленить биты из числа и занести их в какой-нибудь массив,
   а затем вызвать свою функцию проверки значения выражения (я не знаю,
   как вы парсите это выражение).
   */
bool f(uint32_t n, size_t vars_nm) {
    /* Кол-во переменных не может быть больше 32-х,
       иначе они просто не поместятся в uint32_t. */
    assert(vars_nm <= 32);
 
    bool result = 0;
 
    while (vars_nm--) {
        /* n & 1 — это значение текущего младшего бита переменной n (т. е. значение
           одной из логических переменных. */
        result += n & 1;
        n >>= 1;
    }
 
    return result == 1;
}
 
/* Для примера вычисляем кол-во решений уравнения a + b + c = 1. */
int main(void) {
    /* Счетчик справедливых равенств. */
    size_t counter = 0;
    /* Кол-во переменных в равенстве. */
    size_t const vars_nm = 3;
 
    /* Здесь самое интересное: 
                                                 abc
       i = 0 = 00000000 00000000 00000000 00000|000
       i = 1 = 00000000 00000000 00000000 00000|001
       i = 2 = 00000000 00000000 00000000 00000|010
       i = 3 = 00000000 00000000 00000000 00000|011
       i = 4 = 00000000 00000000 00000000 00000|100
       i = 5 = 00000000 00000000 00000000 00000|101
       i = 6 = 00000000 00000000 00000000 00000|110
       i = 7 = 00000000 00000000 00000000 00000|111
       *КОНЕЦ ЦИКЛА*
        
       Происходит перебор всех возможных комбинаций значений
       переменных (не забудьте, что одна переменная — это один бит числа i).
 
       Обратите внимание, что я отделил младшие три бита в таблице. Это и есть
       три наших переменных в выражении (см. переменную vars_nm).
 
       В функции f эти три бита будут использоваться для вычисления
       значения выражения.
 
       Для чего нужно pw(2, vars_nm)? Нам нужно ограничить кол-во повторений
       цикла степенью двойки. Например, 2^3 даст нам 3 значащих бита.
       */
    for (uint32_t i = 0; i < pw(2, vars_nm); i++)
        /* Если равенство верно, увеличиваем счетчик. */
        if (f(i, vars_nm))
            counter++;
 
    printf("%zu\n", counter);
}
P. S. Знаю, что ответ несколько сумбурный, но, думаю, понятно что я имел в виду . Если нет, обязательно спрашивайте что не понятно!
2
0 / 0 / 0
Регистрация: 23.11.2017
Сообщений: 63
30.07.2018, 23:22  [ТС]
Спасибо огромное за ответ и за разъяснение, буду пробовать! Возможно вы спасли мне жизнь
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
30.07.2018, 23:22
Помогаю со студенческими работами здесь

Таблица истинности на си
Здравствуйте,помогите пожалуйста прогнать 3 выражения через таблицу истинности,нужно каждое,У меня не получается,подскажите где что и...

Таблица истинности
Зная уравнение сднф,как построить столбец значений истинности?

Таблица истинности
Очень срочно! Помогите записать по другому код (более компактно). Что бы в расчет вставлялись готовые формулы или что наподобие. Сама...

Таблица истинности
Помогите , пожалуйста. Если не трудно,проверьте, правильно ли я составила таблицу, и если нет, укажите на ошибки. Заранее большое спасибо! ...

таблица истинности
составить таблицу истинности для функции алгебры логики 4-х переменных (х3, х2, х1, х0), заданной в виде десятичного числа 16808. Базис...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru