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

Функция разбивающая строку на пары

18.11.2017, 13:56. Показов 2073. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужно определить функцию, разбивающую список (a b c d е) на пары ((a b) (c d) (е) ) с использованием циклов, а не рекурсии. Была такая идея
Lisp
1
2
3
4
(defun pairs (lst)
(loop while ((AND (cdr lst) (cddr lst))) do ( (setq newlst (cons  newlst (list (car x) (cadr x))))
                                                               (setq lst (cddr lst))))
      if (null (cdr lst)) (setq newlst (cons nelst (list (car lst))))  (setq newlst (cons newlst (list (car lst) (cadr lst)))))
Но она оказалась нерабочей
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
18.11.2017, 13:56
Ответы с готовыми решениями:

Функция, разбивающая список на подсписки
Добрый день Не могли бы вы подсказать мне, как сделать функцию, которая разбивает список элементов таким образом: Допустим, на вход...

Функция, разбивающая изображение на фрагменты
Разработайте функцию, разбивающую изображение на фрагменты, в каждом из которых остается только один канал G

Функция разбиения чисел на пары
Всем доброго времени суток! Не могу разобраться с задачей, буду рад любой помощи. Задача следующая: С клавиатуры ввести 2*n целых...

4
4528 / 3522 / 358
Регистрация: 12.03.2013
Сообщений: 6,038
18.11.2017, 15:53
Хотел вам написать, что когда что-то не работает, лучше приводить возникающие ошибки и/или некорректно работающие примеры. Но в данном случае это, наверно, не помогло бы. Вы в каком редакторе работаете? У вас каша из скобок.

Что бросается в глаза — переменная newlst не определена. (Лучше называть переменные полными словами — list, new-list).

Давайте совместными усилиями доведём вашу идею до ума. Вы можете её описать словами?
1
defun
603 / 617 / 44
Регистрация: 30.04.2011
Сообщений: 702
18.11.2017, 19:36
Lisp
1
2
3
4
5
(defun f (l)
  (loop
     for (a b) on l by #'cddr
     while b ;; nil?
     collect (list a b)))
Lisp
1
2
3
4
5
6
7
(defun f (l)
  (loop
     for n = 0 then (+ 2 n)
     for f = (nth n l)
     for s = (nth (1+ n) l)
     while s
     collect (list f s)))
Добавлено через 7 минут
Lisp
1
2
3
4
5
6
7
(defun f (l)
  (let (r)
    (do ((first (first l) (first rest))
     (second (second l) (second rest))
     (rest (cddr l) (cddr rest)))
    ((null rest) (nreverse r))
      (push (list first second) r))))
Добавлено через 32 минуты
Lisp
1
2
3
4
5
6
7
8
(defun f (l)
  (let (#'nil buff)
    (dolist (v l `(,@(nreverse function) ,(nreverse buff)))
      (cond
    ((= (length buff) 2)
     (push (nreverse buff) function)
     (setf buff (list v)))
    ((push v buff))))))
1
 Аватар для _sg
4710 / 4405 / 380
Регистрация: 12.05.2012
Сообщений: 3,102
18.11.2017, 20:04
Лучший ответ Сообщение было отмечено Ksenlya как решение

Решение

как вариант:
Lisp
1
2
3
4
5
6
7
8
9
10
(defun pair (w &aux (b (car w)))
  (loop for a in (cdr w)
        when b collect (list b a) into z
        do (if b (setf b nil) (setf b a))
        finally (return (if b (append z `((,b))) z))))
 
> (pair '(a b c d e f))
((A B) (C D) (E F))
> (pair '(a b c d e))
((A B) (C D) (E))
Добавлено через 2 минуты
Lisp
1
2
3
4
5
6
7
8
9
(defun pair (w)
  (loop for (a b) on w by #'cddr
        if b collect (list a b)
        else collect (list a)))
 
> (pair '(a b c d e f))
((A B) (C D) (E F))
> (pair '(a b c d e))
((A B) (C D) (E))
Добавлено через 10 минут
Lisp
1
2
3
4
5
6
7
8
(defun pair (w)
  (loop for (a b) on w by #'cddr
        collect (if b (list a b) (list a))))
 
> (pair '(a b c d e f))
((A B) (C D) (E F))
> (pair '(a b c d e))
((A B) (C D) (E))
Добавлено через 51 секунду
Lisp
1
2
3
4
5
6
7
8
(defun pair (w)
  (loop for (a b) on w by #'cddr
        collect (if b `(,a ,b) `(,a))))
 
> (pair '(a b c d e f))
((A B) (C D) (E F))
> (pair '(a b c d e))
((A B) (C D) (E))
2
0 / 0 / 0
Регистрация: 18.05.2017
Сообщений: 2
19.11.2017, 13:11  [ТС]
у меня LispWorks
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
19.11.2017, 13:11
Помогаю со студенческими работами здесь

Функция поиска в а-списке L точечной пары, соответствующей ключу k
Напишите функцию от двух аргументов (аналог встроенной функции assoc(l, k)), которая в а-списке l ищет точечную пару, соответствующую...

Функция находящая все пары дружественных чисел, лежащих в диапазоне от n до m
Даны натуральные числа n и m. Найти все пары дружественных чисел, лежащих в диапазоне от n до m. Два числа называются дружественными, если...

Процедура, разбивающая число на цифры
написать процедуру, которая разбивает число на цифры: - название процедуры - number - входной параметр - целое число - получаемые...

Программа, разбивающая картинку на сегменты( квадраты)
Здравствуйте, есть задание написать приложение которое загруженную картинку разбивает на сегменты(квадраты), их число задает пользователь,...

Функция - Pos(s,s1). Назначение - поиск первого вхождения подстроки s1 в строку s (аналогичная функция C - strstr)
Функция - Pos(s,s1). Назначение - поиск первого вхождения подстроки s1 в строку s (аналогичная функция C - strstr).Помогите плииз


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Программный контроль заполнения реквизита табличной части документа
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
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru