
プログラミング初心者です。
先日『nが入力されたときに、n段のパスカルの三角形を出力するプログラムを作成しなさい』という課題が出ました。
まだ理解しきれていないところが多いもので、手元にある資料をマネて、とりあえず動いてくれるように書いてみました。
今消化不良をおこしているのは以下の2点です。
1 一部理解できない箇所がある
→解説をいただきたい
2 出力される三角形が、パスカルの三角形ではなくただの『d』の三角形になってしまう
→どこが間違っているのかご指摘いただきたい
以下が書いたプログラムです。
#include<stdio.h>
int comb(int n, int r)
{
if (r==0 || r==n) return 1;
elese return comb(n - 1, r - 1) + comb(n - 1, r);
}
main()
{
int n,i,j;
printf("n?");
scanf("%d",&n);
for (i=0; i<=n, i++) {
for(j=0; j<=i, j++) {
printf("d%",comb(i,j));
}
printf("\n");
}
}
ちなみに理解できていない(自分自身で説明できない)箇所は
main関数の前、
if (r==0 || r==n) return 1;
elese return comb(n - 1, r - 1) + comb(n - 1, r);
の二行です。お恥ずかしい話、記号の意味もよくわかってません;
どなたかご指導お願いします!!(><)
A 回答 (3件)
- 最新から表示
- 回答順に表示
No.3
- 回答日時:
※質問者です。
パスワード忘れで再登録したのでこちらから失礼します
お二人とも本当に有難うございます。
綴りミスを直して実行できました^^
お二人の解説ポイントを中心に確認して、内容のおさらいもできました。的確なアドバイス、本当に有難うございました!!!
とても参考になりました。
No.2
- 回答日時:
>理解できていない(自分自身で説明できない)箇所は
>if (r==0 || r==n) return 1;
>elese return comb(n - 1, r - 1) + comb(n - 1, r);
>の二行です。
組み合わせ comb(n, r) の値は
・comb(n, 0) または comb(n, n) のときは 1
・それ以外のときは回答No.1にある等式の右辺を使って計算
ということを表しています。
再帰呼び出しを知らないと理解できないでしょう。
>2 出力される三角形が、パスカルの三角形ではなくただの『d』の三角形になってしまう
>→どこが間違っているのかご指摘いただきたい
dを出力している行は上記のプログラムの中に一つしかありません。そこを直せばいいだけです。printfの例題の初歩。
No.1
- 回答日時:
下に挙げることを理解していればプログラムの意味も分かるし、間違いも修正できます。
・関数combは数学の組み合わせ (combination) を表している
・パスカルの三角形は組み合わせと密接な関係がある
・組み合わせについて、nCr = (n-1)Cr + (n-1)C(r-1) という等式が成り立つ
・再帰呼び出し
・||は論理積を表す
・printf()でint型の値を出力するにはどう書けばいいか
・elseのつづり
・for文の ( ) の中にはセミコロンが2つ要る
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
c言語でAからZまでを表示する...
-
コマンドラインに出力した文字...
-
コンパイルエラーについて
-
TeraPadの設定方法
-
*を使ったジグザグのラインをプ...
-
wsprintfの書式制御文字列につ...
-
現在時刻の表示について
-
C言語の問題です
-
C言語 プログラミング
-
CTRL+Dでループを抜けるには
-
テキストカーソル位置の取得
-
パスカルの三角形についてのCプ...
-
空Enterの扱い方
-
cshの文字列操作(0埋め)
-
文字を動かしたい
-
すごろくに使用するサイコロ
-
C言語での、年複利の計算方法...
-
error C2143: 構文エラー : ';'...
-
C++ 二次関数の重解、虚数解が...
-
三角形の判別
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
10個出力で改行したいのですが...
-
c言語でAからZまでを表示する...
-
(C言語)めちゃくちゃな値にな...
-
コマンドラインに出力した文字...
-
コンパイルエラーについて
-
コマンドプロンプトがすぐ消える
-
勝率をプログラムに
-
テキストカーソル位置の取得
-
三角形の判別
-
【C言語教えてください】sin波...
-
4の倍数を論理演算で表す。。
-
C言語で、「自然数nを入力し、n...
-
入力したお金の金額からお札の...
-
cshの文字列操作(0埋め)
-
switch分のケースを範囲数?に...
-
scanfに文字が入力されたときに...
-
プログラミングについての質問です
-
unsigned int型について
-
ダブルポインタで2次元配列を作成
-
円の面積を求めるプログラミン...
おすすめ情報