Форум программистов, компьютерный форум, киберфорум
Lisp
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 26.10.2017
Сообщений: 1

Функция для упрощения выражения

26.10.2017, 21:39. Показов 1377. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Сначала я создал функцию которая трансформирует инфиксную форму в префиксную.
Lisp
1
2
3
4
5
6
7
(defun infixToPrefix(l)
    (cond ((null l) nil) 
         ((equal (length l) 1)(car l))
        ((not(member (car l) `(+ -))) 
         (list (cadr l)(infixToPrefix(cddr l))(car l)))))
(infixToPrefix (reverse`(A + B + C))) 
;(infixToPrefix (reverse`(A - B - C)))
Результат получился таков:
(+ (+ A B) C)
Bторая задача была для упрощения выражения:
Пример:
(+ (+ A B) C) -> (+ A B C) или (- (- A B) C) -> (- A B C)
Спасибо заранее.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
26.10.2017, 21:39
Ответы с готовыми решениями:

Упрощения логического выражения
Помогите решить задачу(Я незнал к какому разделу отнести) Нужно упростить логическое выражение для D (¬A∨ B)∨ (B ∨ C)∨ ( A & C)

Применить функцию для упрощения вычислений
в данной программе для упрощения вычислений надо ввести дополнительную функцию. Помогите, пожалуйста, найти ошибку. Компилятор говорит об...

каким методом воспользоваться для упрощения?
24/((5^1/3)+(3^1/3)) т.е. двадцать четыре разделить на сумму кубических корней из 5 и 3.

1
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38195 / 21128 / 4309
Регистрация: 12.02.2012
Сообщений: 34,736
Записей в блоге: 14
28.10.2017, 22:22
Что-то вроде:

Lisp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
(defun simp (ex)
  (cond ((atom ex) ex)
        (t (let ((s1 (car ex))
                  (s2 (car (cadr ex)))
                  (v1 (simp (cadr (cadr ex))))
                  (v2 (simp (caddr (cadr ex))))
                  (v3 (simp (caddr ex))))
            (if (eq s1 s2) (list s1 v1 v2 v3) (list s1 (list s2 v1 v2) v3))))))       
 
==> SIMP
 
(simp '(+ (+ a b) c))
 
==> (+ A B C)
 
(simp '(+ (- a b) c))
 
==> (+ (- A B) C)
 
(simp '(- (- a b) c))
 
==> (- A B C)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
28.10.2017, 22:22
Помогаю со студенческими работами здесь

Программа для упрощения логических выражений
Всё как всегда. Буквы дружат с буквами, цифры с цифрами. Но возникает вопрос: если у меня на входе a+b+1+2+b+a, то как получить, чтобы...

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

Посоветуйте тулзы для упрощения работы в tty
Установил себе debian без графического интерфейса. Есть только tty. Работа в нем отличается от того же gnome-terminal. Нет возможности...

1C Обработка для упрощения назначения прав объектам
Столкнулась с проблемой, при создании новой роли, и назначении прав например для документа. Так как документу мало того что ты назначишь...

Программы для упрощения установки драйверов на много машин
Требования: 1. Бесплатность 2. Нормальная работа, в том числе на WinXP 3. Без всякой дряни в комплекте Перепробовал несколько...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита "ПричинаСписания". . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Программное заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru