- ベストアンサー
プロローグ(=Prolog)について質問です。
wolvの回答
先頭から調べていって、すでに見つけたもののリストがA,現在調べているものがHに入っているようですね。 HがAに含まれない場合は、 dupacc([H|T], A, L) :- dupacc(T, [H|A], L). の行でリストに追加されますが、[H|A]によってリストの先頭に追加されます。 そこで、この行を、 dupacc([H|T], A, L) :- dupacc(T,Appended,L),append(H,A,Appended). に変更すれば、リストの後ろに現在チェック中のアイテムが追加されるはずなので、うまく動作するように思います。 ただし、appendという関数(定義)は append(Item,Orig,Appended) Item:追加するアイテム Orig:もとのリスト Apended:アイテムを末尾に追加されたリスト と定義されているとして回答しました。 (動作確認はしていません)
関連するQ&A
- Prologについて
リストの末尾への要素に追加するプログラムを教えてください。 第2引数のリストの末尾へ、第1引数が加えられたリストが第3引数として得られるようなプログラムで、次のように動作すればいいです。 ?-add_last(e,[a,b,c,d],L). [[Enter]] L = [a, b, c, d, e] ; [[Enter]] No ?-add_last(X,L,[a,b,c,d,e]). [[Enter]] X = e L = [a, b, c, d] ; [[Enter]]
- 締切済み
- その他(プログラミング・開発)
- prologのプログラムについて
?- ss([3,4,1,2,5],[1,2],X) X=[3,4,5] ?- ss([car(X,Y),car(Z,W)],[car(a,b),car(c,d),train(a),car(e,g)],List) List=[train(a),car(e,f)] List=[car(c,d),train(a)] List=[car(a,b),train(a)] ?- ss(X,[1,2],[3,4]) X=[1,2,3,4] となるようなprologのプログラムをつくりたいです。 丸一日、試行錯誤したのですが、結果どおりに動いてくれません。 分かる方がいらっしゃいましたら、教えていただけませんでしょうか。
- ベストアンサー
- その他(プログラミング・開発)
- prologでの数式の簡単化
prologで微分をするプログラムを作ったのですが計算した結果が、例えば、 0*x^2+a*(2*x^1*1)+(0*x+b*1)+0 のように無駄に長くなってしまいます。そこでこれを簡単化する述語simple(P)を作りたいのですがどのようにしたら良いでしょうか? ?- simple(0*x^2+a*(2*x^1*1)+(0*x+b*1)+0). 2*a*x+b yes できれば上のような動作がするぐらいのものが作りたいです。 少なくとも余計な0,1を除去するくらいはしたいのですが・・・ お願いします。
- 締切済み
- その他(プログラミング・開発)
- prologリスト処理
prologやり始めたんですけどリストのところで分からないところがあります。 リストAからリストBを取り除いたリストCを作り出す定義は? A[a,b,b,c]-B[a,b,c]⇒C[b] という問題なんですが、どうすれば出せるのでしょうか?取り除こうとすると重複しているbすべてを取り除いてしまい答えが出せません。 ご教授お願いします。
- ベストアンサー
- その他(プログラミング・開発)
- prolog言語で積分計算
PROLOG計算 prolog言語で積分計算のできるプログラムを作っています。 積分定数Cを表示させるようにしているのですが 、3*x^3の積分の結果が 3* (x^2/2+c)+cとなってしまいます。 ()内のcを消すにはどーしたらよいでしょうか? プログラムは以下のように書きました。 t(x,x^2/2+c). t(Y ,Y*x+c) :- integer(Y). t(Y+Z,TY+TZ+c):- t(Y,TY),t(Z,TZ). t(Z*Y,Z*TY+c) :- integer(Z),t(Y,TY). t(Y^N ,(1/N)*Y^N1*TY+c):-integer(N),N1 is N+1,t(Y,TY). t(Y-Z,TY-TZ+c):-t(Y,TY),t(Z,TZ).
- 締切済み
- その他(プログラミング・開発)
- Prologについて教えてください!
リストLにおいて二つの項XとYがこの順番に隣接しているとき真となる関係nextto(X,Y,L)を定義しなさい。 ?-nextto(a,b,[a,b,c]). true ?-nextto(a,c,[a,b,c]). この問題の答えを教えてください。
- ベストアンサー
- その他(プログラミング・開発)
- prologについて
第2引数で与えられたリストに、第1引数の要素を挿入(位置はどこでも良い)したリストが、第3引数になるようなプログラムを教えてください。 以下のように動作すればいいです。 ?-insert(p,[a,b,c],L). [[Enter]] L = [p, a, b, c] ; [[Enter]] L = [a, p, b, c] ; [[Enter]]
- 締切済み
- その他(プログラミング・開発)
- question about Prolog
Prologについて質問があります。 私は今Prologで簡易和英・英和翻訳機をつくろうとしているのですが、途中でつまづいています。 以下のようなPrologリストを読み込んで、``in rooms''を日本語に直そうとして :-prep_phrase([in,rooms], [], B, []). と入力すると、 B = [heya,no,naka,no] と正しい答が返ってきますが、逆に``heya no naka no''を英語に直そうと :-prep_phrase(A, [], [heya,no,naka,no], []). と入力しても、無限ループに陥ってしまうようでエラーメッセージとして ``stack overflow'' が返ってきます。 トレースしてみたところ、noun_phrase と prep_phrase が交互に次々と呼ばれていました。 どうしてこのようなことが起こるのでしょうか(英->和はできているのに)。また、これを回避する方法はあるのでしょうか。 %% プログラムリストここから %% 英語の「名詞+前置詞節」を日本語の「前置詞節+名詞」に %% 翻訳する %% ex. in rooms -> heya no naka no %% 名詞節 noun_phrase(A, C, X, Z):-noun(A, B, Y, Z), prep_phrase(B, C, X, Y). %% 前置詞節 prep_phrase(A, C, X, Z):-prep(A, B, Y, [no|Z]), noun_phrase(B, C, X, [no|Y]). prep_phrase(A, A, X, X). %% 前置詞 prep([in|A], A, [naka|X], X). %% 名詞 noun([rooms|A], A, [heya|X], X). %% プログラムリストここまで
- ベストアンサー
- その他(プログラミング・開発)
- Prologの単一化について
(1)p([X|Y]) と p([a]) (2)p(a, [b, c], X) と p(Y1, [Y2|Y3], Y3) (3)?-p([a, b, c], X). p([X|Y], N) :- p(Y, N1), N is N1+1 . (4)?-p([a, b, c], [d, e], X) . p([X|A], B, [X|C]) :- p(A, B, C). (5)?-p([a, b, c], [], X). p([X|R], Y, Z) :- p(R, [X|Y], Z) の述語についてですが、それぞれ単一化すると各変数はどうなるでしょうか。 (3)~(5)については、質問と規則の頭部との単一化です。 どの変数も単一化の前に値を持っていないとします。 教えてください。
- 締切済み
- その他(プログラミング・開発)
- Prologについて教えてください
A,B,Cを使って直角三角形が成り立ち真となる関係right triangleを定義するプログラムを教えてください。今のところ triangle(A,B,C). vertical(seg(point(X,Y),point(X,Y1)). horizontal(seg(point(X,Y),point(X1,Y)). を使うところまではわかっているのですが先に進みません。
- ベストアンサー
- その他(プログラミング・開発)
お礼
自己解決しました。 remdup(L, M) :- dupacc(L, [], M). dupacc([], A, A). dupacc([H|T], A, L) :- member(H, A), dupacc(T, A, L). dupacc([H|T], A, L) :- append(A, [H], X), dupacc(T, X, L). これで仕様どおりに動作します。 wolvさんのコードも実行してみましたがエラーが出たようです。 1 ?- remdup([a, b, c, a, d, c], X). ERROR: Out of global stack Exception: (13) dupacc([c], [b, c, a, d|_G78], _G31) ? なにはともあれ、助かりました。ありがとうございました。