рефераты конспекты курсовые дипломные лекции шпоры

Реферат Курсовая Конспект

Работа с данными типа string

Работа с данными типа string - раздел Программирование, Логическое программирование   Concat( Строка1, Строка2, Строказ) (String,string,st...

 

concat( строка1, строка2, строкаЗ)

(string,string,string):(i,i,i)(i,i,o)(i,o,i)(o,i,i)

 

В зависимости от конкретизации выполняется лексикографическая

операция строка1+строка2=строкаЗ.

 

frontchar( строка, первый_знак_строки,остаток_строки)

(string,char,string): (l,1, i)( i, i,o)( i,o; i)(o,1,l)(i,o,o)

 

В зависимости от конкретизации выполняется лексикографическая

операция строка = первы_знак_строки + остаток_строки.

Например, преобразование строки в список отдельных знаков и

наоборот:

 

domains .

charlist =char*

predicates

str_lst(string,charlist)

clauses

str..lst("", []):-!'

str_lst(S,[H|T]):-.

bound(S),!, /* имеется строка? */

frontchar(S,H,Rs),

str_lst(Rs,T).

str_lst(S,[H|T]):-

bound(H), /* имеется список знаков? */

str_lst(Rs,T),

frontchar(S,H,Rs).

 

После-запуска программы (Run) возможно указать разные цели:

 

Goal: str_lst("Это строка",X)

Х=[' Э',' т',' о',' ',' с',' т',' р',' о',' к',' а' ]

1 Solution (одно решение)

Goal: str_lst(X,[' з','н','а',' к',' и' ])

Х=знаки

1 Solution

Goal:<ESC> (ключ для выхода в главное меню)

 

frontstr(количество,строка,передняя_строка,остаток_строки)

(integer,string,string,string): (i,i,o,o)

 

Из указанной строки количество знаков возвращается в передней

строке, а остальные в остатке строки.

 

fronttoken(строка,токен,остаток_строки)

(string,string,string): (i,i,i)(i,i,o)(i,o,i)(o,i,i)(i,o,o)

 

В зависимости от конкретизации выполняется лексикографическая

операция строка = токен + остаток_строки. При этом один или

несколько знаков образуют токен в следующих случаях:

- они образуют имя Турбо-Пролога;

- они представляют целое или действительное число;

- знаки "+" и "-" являются отдельными знаками;

- имеется отдельно стоящий знак (кроме пробела).

Например fronttoken("это тест",Х,У) дает Х="это", Y=" тест".

 

str_len(строка,длина) ' .

(string,integer):(i,i)(i,o)

 

Проверяется (i,i) или возвращается (i,o) длина строки.

 

– Конец работы –

Эта тема принадлежит разделу:

Логическое программирование

Логическое программирование... После многолетних теоретических работ по математической логике в году в... Для программиста особенность языка Пролог состоит в том что он на основе выражений логики предикатов может заниматься...

Если Вам нужно дополнительный материал на эту тему, или Вы не нашли то, что искали, рекомендуем воспользоваться поиском по нашей базе работ: Работа с данными типа string

Что будем делать с полученным материалом:

Если этот материал оказался полезным ля Вас, Вы можете сохранить его на свою страничку в социальных сетях:

Все темы данного раздела:

Логика высказываний
Формально-логические высказывания представляются с помощью букв, с которыми производятся логические операции. Например, предложение: Машина находится у дома. Является выс

Логика предикатов
С помощью логики предикатов можно выразить связи между различными вещами. Формально высказывания в логике предикатов имеют вид: P(t1,t2,…tn), Где t1, t2, …, tn – аргументы,

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

Дизъюнкты
База данных составляется с помощью предикатов, каждый из которых описывается множеством дизъюнктов: Функтор(аргумент1, аргумент2, …):-условие1,условие2,… . Где функтор- имя предик

Константы и переменные
Константы должны начинаться с маленькой буквы, либо стоять в одинарных или бинарных кавычках, либо они являются числами: -mother -price -list‘f’ 169 1.4e-3  

Секции программы
Секция domains-(объявление областей определения). 1 Способ. имя области = d где d- любой тип. Например person=string nomer=integer

Обработка программ Турбо Прологом
Обработка программ ведется по принципу “поиска вглубь”.Это означает, что ТП всегда пытается доказать утверждение в дизъюнктах слева направо с помощью фактов и правил из базы данных. Целево

Возврат и отсечение
ТП в случае, если есть больше одного дизъюнкта для одного предиката, отмечает этот дизъюнкт точкой решения, чтобы он мог вернутся в эту точку и продолжить работу со следующим дизъюнктом, даже есла

Рекурсия
Вычисление факториала: .f(0)=1 f(n+1)=(n+1)*f(n) .predikrtes fak(integer, real) .clauses fak(0,1):-!. /* 0!=1 */ fak(N, Fak):- N>0, /*только

Работа с файлами
/* telefon book + file */ trace domains name,adr= string datad=c(name,adr) file=d predicates person(name,adr) getdata(file)

Изменения в базе данных
  asserta(факт) (dbasedom): (i)   Добавляет новый факт перед остальными фактами того жe предиката в оперативную базу данных. Факт должен быть

Арифметика
  Арифметические утверждения присваивания имеют следующий общий вид:   результат = операнд1 оператор операнд2   В качестве опера

Преобразование типов
  Все предикаты преобразования типов действуют в обе стороны ((i,о) и (o,i)), а случай (i,i) проверяет истинность (не для предиката real). Преобразование между типам

Команды операционной системы
  Для выполнения команд system и dir необходимо, чтобы Турбо-Прологу была доступна дискета с COMMAND. СОМ.   system(команда) (string):(i)

Версии Турбо-Пролога
  Данные методические указания описывают версию 1.0. Уже доступная версия Турбо-Пролог 1.1 имеет следующие дополнительные возможности: - предикат makewindow

Внешняя среда системы Турбо-Пролог
  Турбо-Пролог после запуска предпологает определенную конфигурацию своих и пользовательских файлов. Различаются пять каталогов: 1. Турбо-каталог. Здесь дол

Хотите получать на электронную почту самые свежие новости?
Education Insider Sample
Подпишитесь на Нашу рассылку
Наша политика приватности обеспечивает 100% безопасность и анонимность Ваших E-Mail
Реклама
Соответствующий теме материал
  • Похожее
  • Популярное
  • Облако тегов
  • Здесь
  • Временно
  • Пусто
Теги