質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Haskell

Haskellは高い機能性をもった関数型プログラミング言語で、他の手続き型プログラミング言語では難しいとされている関数でも容易に行うことができます。強い静的型付け、遅延評価などに対応しています。

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

Q&A

解決済

2回答

144閲覧

Yコンビネータの質問ですが多分算数の話かも

nyahonyaho

総合スコア83

Haskell

Haskellは高い機能性をもった関数型プログラミング言語で、他の手続き型プログラミング言語では難しいとされている関数でも容易に行うことができます。強い静的型付け、遅延評価などに対応しています。

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

1グッド

1クリップ

投稿2017/07/18 07:03

編集2017/07/18 07:05

http://d.hatena.ne.jp/r-west/20090417/1239972722
このサイトでYコンビネータをおべんきょうしているのですが、

「Fにfを入力してみよう」

「すると、出力されるのは、3x+4+f(x-1)。入力である 3x+4+f(x-1)とまったく同じです。」
のくだり、

私の計算だと 6x + 5 + f(x - 2)になっちゃいます。
3x+4+g(x-1)に3x+4+f(x-1)セットして計算したらそうなっちゃわない!?

Chironian👍を押しています

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

LouiS0616

2017/07/18 07:12

見ましたが、これFは特定の関数を指していませんよね? 『 関数を入力として受け取り、その関数を使う新しい関数を作って出力する関数』Fは「左記を満たしているなにか」なので、入力と同じ関数を出力しても全く不思議ではありません。
guest

回答2

0

難しく考えすぎです。

F(f) = 3x + 4 + f(x-1)
とある関数f = f_を代入したら
F(f_) = 3x + 4 + f_(x-1)

f_ = 3x + 4 + f_(x-1)とすると

f_ = F(f_)

投稿2017/07/18 07:37

編集2017/07/18 07:37
ozwk

総合スコア13521

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

恐らく展開しちゃったんですね。

定義:
f(x) = 3x + 4 + f(x-1)
F(g) = 3x + 4 + g(x-1)

のとき F に f を代入する。

F(f)
= 3x + 4 + f(x-1) -- (1) g を f に置換しただけ
= 3x + 4 + (3(x-1) + 4 + f(x-2)) -- (2) f(x) に (x-1) を代入して展開
= 6x + 5 + f(x-2) -- (3) それを計算

記事が主張している「全く同じ」とは (1) のことを指します。
単純に g を f に置換した関数 F(f) は元の関数 f と同じという意味です。
(2),(3) の計算は F(g) に f を代入した段階ではしないのです。

投稿2017/07/18 07:32

nobutada

総合スコア17

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問