Помощь - Поиск - Пользователи - Календарь
Полная версия: Булевские ф-ции
Форум «Всё о Паскале» > Pascal, Object Pascal > Задачи
rol5en
Помогите решить задачу!
Данные: строка содержащая булевскую функцию от переменных A, B, .....(отрицание А записывается как \А), для определения которой использованы только операции +, *, \ (скобки отсутствуют).
Задание упростить функцию, исключив повторяющиеся слагаемые или сомножетели и нулевые слагаемые. mega_chok.gif
Заранее спасибо!
klem4
Мог бы ты написать пару примеров входных и выходных данных ?
volvo
To: klem4
А зачем? Без данных слабо? blum.gif
const
max_word = 255;
delimiter = [#32, '+'];
type
wrd_info = record
start, len: byte;
end;
twords = array[1 .. max_word] of wrd_info;
char_set = set of char;

function get_words(s: string; var words: twords;
delimiter: char_set): integer;
var
i, count, curr_len: integer;
begin
count := 0; i := 1;
while i <= length(s) do begin

while (s[i] in delimiter) and (i <= length(s)) do inc(i);

curr_len := 0;
while not (s[i] in delimiter) and (i <= length(s)) do begin
inc(i); inc(curr_len);
end;

if curr_len > 0 then begin
inc(count);
with words[count] do begin
start := i - curr_len;
len := curr_len
end;
end;

end;
get_words := count;
end;

const
num_vars = 2;

var
mult_words: twords;

function check_part(s: string): string;
var
contains: array[false .. true, 1 .. num_vars] of boolean;
i, count: integer;
curr_var: string;
_result: string;
zero: boolean;

begin
for zero := false to true do
for i := 1 to num_vars do
contains[zero, i] := false;

count := get_words(s, mult_words, [#32, '*']);
for i := 1 to count do begin
curr_var := copy(s, mult_words[i].start, mult_words[i].len);
contains[not (curr_var[1] = '\'),
ord(curr_var[length(curr_var)]) - ord('a') + 1] := true;
end;

_result := '';
i := 1; zero := false;
while (i <= num_vars) and not zero do begin

if contains[false, i] <> contains[true, i] then begin

if contains[false, i] then _result := _result + '\';
_result := _result + chr(ord('a') + i - 1) + '*';

end
else
if contains[false, i] = true then zero := true;

inc(i);
end;

if zero then _result := '0*';
check_part := copy(_result, 1, pred(length(_result)));
end;

var
plus_words: twords;
count: byte;

i: byte;

r_str: string;
part: string;

const
s: string = 'a*\a*b+a*\b+b';
{
s: string = 'a*\b + b';
}

begin
r_str := s;

repeat
s := r_str;

count := get_words(s, plus_words, [#32, '+']);
r_str := ' '; { Пробел }

for i := 1 to count do begin
part := check_part(copy(s, plus_words[i].start, plus_words[i].len));

if part <> '0' then begin
if pos(' ' + part, r_str) = 0 then begin
if r_str <> ' ' then r_str := r_str + ' + ';
r_str := r_str + part;
end;
end;
end;

until s = r_str;

writeln('the result: ', r_str);
end.


To: rol5en
Погоняй на разных примерчиках, в принципе (хотя это и не проверялось !!!) должно работать с любым количеством переменных, НО (!!!) обозначения переменных должны быть по порядку: (a, b, c, d, ...)
Само желаемое количество переменных задается здесь:
const
num_vars = 2; { <-- }


Найдешь глюки - говори, на каких значениях поймал их. Задание, кстати, довольно интересное yes2.gif
rol5en
Перед последним begin`ом в строчке // s: string = 'a*\b + b'; ставит курсор
на // и пишет begin expected blink.gif
klem4
В BP и TP нету комментария вида //, убери // и все что за ним стоит или заключи это
между { и }

я думаю дело в этом ...
volvo
lol.gif Вот что значит FPC
Замени на
{ s: string = 'a*\b + b'; }

а можешь вообще удалить, это было просто для теста...
rol5en
Ему не нравиться переменная //s можно поменять на ps !!!
rol5en
А вот ещё если написать строчку s: string = 'a*\a*b+a*\b+b';
как s: string = 'a*\a*b+a*\b+b+b; по идее должно получиться a*\b + 2*b'
там ведь в задание написаноисключив повторяющиеся слагаемые
я это понимаю как b+b=2*b или я что не так понял
volvo
To: rol5en
То, что ты написал в предыдущем посте на вяжется никак с названием топика. У тебя тема какая?
Цитата
Булевские ф-ции, упрощение булевских ф-ций

Допустим, b = True... Что имеем? True + True = 2 * True?

Нет, в булевой алгебре True + True = True or True = True !!! А то, что ты написал - это приведение подобных, и к булевой алгебре никакого отношения не имеет... no1.gif
rol5en
Да ты прав! Извини! good.gif
rol5en
Я тут знаешь подумал над твоим True + True = True or True = True!!! и пришёл к выводу что исключение повторяющихся слагаемых значит b+b=b т.е. a*\a*b+b+b будет равно b! Как бы это сделать??? wacko.gif
volvo
Цитата
Как бы это сделать???

smile.gif Уже сделано... Я исправил программу, проверяй новую версию... Она как раз это и делает...
rol5en
А где её взять? Новую версию? Или ты ту отредактировал?
volvo
Цитата
Или ты ту отредактировал?

yes2.gif Именно... Пост №3... Все исправления будут вноситься мной туда... Там всегда будет самая последняя и правильная версия...
rol5en
А как мне туда перейти? Кинь ссылку=)
volvo
blink.gif А что, в начало этой же страницы ты без ссылки не сможешь подняться?
rol5en
Извини да ступил! Но раз это последняя версия то убери может тогда
// s: string = 'a*\b + b'; и ещё если написать a+b+a*\b+a то получиться
+a+b+a*\b как убрать плюс???
volvo
To: rol5en
В следующий раз копируй программу ПОЛНОСТЬЮ - со всеми пробелами !!! Ты упустил какой-то пробел (ищи теперь сам где он был), и теперь будешь получать неверный результат... У меня только что нормально отработало.
rol5en
Ещё раз извини! unsure.gif
rol5en
Ещё вопрос это я упустил или а*а даёт ноль?
rol5en
Всё всё всё это я лузер!
Lomik
Помогите организовать всё тоже самое только ещё со скобками! Вложенных скобок нет! Спасибо заранее!
volvo
To: Lomik
Ха, ну попробуй реализуй... Я посмотрю, как у тебя это получится... Кстати, помочь - это не значит сделать за тебя. Ты уже видишь алгоритм решения подобной задачи, попробуй подумать, что нужно делать в первую очередь, а что потом, для того чтобы получить правильный результат...

Полностью ЗА ТЕБЯ этого делать никто не будет...

А вот правила еще никто не отменял.
Цитата(Правила Форума)
9. Запрещена регистрация нескольких профилей. В случае обнаружения нарушителей, один из профилей удаляется.
За создание второго аккаунта будешь наказан... mad.gif
Altair
полуоффтоп

НЕ булевские а булевы!
Guest
Исходная информация: строка, содержащая булевскую функцию от переменных A, B,...(отрицание А записывается как \А), для определения которой использованы только операции +.*,\ и скобки.
Задание: преобразовать функцию к нормальной совершенной форме
volvo
Цитата
преобразовать функцию к нормальной совершенной форме

Пользуйся поиском... Уже делал ...

Сообщения разделены в тему: Упрощение логических выражений
Это текстовая версия — только основной контент. Для просмотра полной версии этой страницы, пожалуйста, нажмите сюда.