Войти в систему

Home
    - Создать дневник
    - Написать в дневник
       - Подробный режим

LJ.Rossia.org
    - Новости сайта
    - Общие настройки
    - Sitemap
    - Оплата
    - ljr-fif

Редактировать...
    - Настройки
    - Список друзей
    - Дневник
    - Картинки
    - Пароль
    - Вид дневника

Сообщества

Настроить S2

Помощь
    - Забыли пароль?
    - FAQ
    - Тех. поддержка



Некто написал,
Вот в Agda, например:

_*_ : ℕ → ℕ → ℕ
zero * n = zero
suc m * n = (m * n) + n

m-zero-right : (n : ℕ) → n * 0 ≡ 0
m-zero-right zero = refl
m-zero-right (suc n) = trans (sym (p-zero-right (n * 0))) (m-zero-right n)

m-nsm : (n m : ℕ) → m * (suc n) ≡ (m * n) + m
m-nsm n zero = refl
m-nsm n (suc m) with m-nsm n m
m-nsm n (suc m) | eq = begin
suc m * suc n
≡⟨ refl ⟩
((m * suc n) + (suc n))
≡⟨ cast-gen (λ x → m * suc n + suc n ≡ x + suc n) eq refl ⟩
m * n + m + suc n
≡⟨ trans (p-assoc (m * n) m (suc n)) refl ⟩
(m * n + (m + suc n))
≡⟨ (cast-gen (λ x → m * n + (m + suc n) ≡ m * n + x) (sym (p-snm-nsm m n)) refl) ⟩
(m * n + (suc m + n))
≡⟨ (cast-gen (λ x → m * n + (suc m + n) ≡ m * n + x) (p-comm (suc m) n) refl) ⟩
(m * n + (n + suc m))
≡⟨ (trans (sym (p-assoc (m * n) n (suc m))) refl) ⟩
(m * n + n + suc m ∎)

m-comm : (n m : ℕ) → n * m ≡ m * n
m-comm n zero = m-zero-right n
m-comm n (suc m) with m-comm n m
m-comm n (suc m) | eq = trans (m-nsm m n) (cast-gen (λ (x : ℕ) → x + n ≡ m * n + n) (sym eq) refl)


(Читать комментарии)

Добавить комментарий:

Как:
(комментарий будет скрыт)
Identity URL: 
имя пользователя:    
Вы должны предварительно войти в LiveJournal.com
 
E-mail для ответов: 
Вы сможете оставлять комментарии, даже если не введете e-mail.
Но вы не сможете получать уведомления об ответах на ваши комментарии!
Внимание: на указанный адрес будет выслано подтверждение.
Имя пользователя:
Пароль:
Тема:
HTML нельзя использовать в теме сообщения
Сообщение:



Обратите внимание! Этот пользователь включил опцию сохранения IP-адресов пишущих комментарии к его дневнику.