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

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

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

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

再帰

情報工学における再帰とは、プログラムのあるメソッドの処理上で自身のメソッドが再び呼び出されている処理の事をいいます。

Q&A

解決済

3回答

1689閲覧

再帰呼び出し segmentation fault

qwertyhghv

総合スコア19

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

再帰

情報工学における再帰とは、プログラムのあるメソッドの処理上で自身のメソッドが再び呼び出されている処理の事をいいます。

0グッド

0クリップ

投稿2021/11/26 02:08

2つの整数 a, b を引数にとり、a の b 乗を出力したいが、a または bがマイナスの条件を入れるとsegmentation faultになってしまう。
実行例
Input two integers : 2 -3
a^b = 0.125000

Input two integers : -3 5
a^b = -243.000000

#include <stdio.h> float my_pow( int a, int b ){ if ( a < 0 || b < 0){ float y, z; y = my_pow( a, -b); z = 1.0 / y; return y; } if ( a == 0 ) return 1; else return a * my_pow( a, b - 1 ); } int main(void) { int a; int b; printf("Input two integers : "); scanf("%d %d", &a, &b ); printf("a^b = %f\n", my_pow(a, b)); return 0; }

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

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

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

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

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

guest

回答3

0

ぱっと見、aが0以外だと無限再帰になってクラッシュするように見えます。

my_pow(1, 0) と呼んだときに何が起きるべきで、実際は何が起きているかを調べてみると原因がわかるかと思います。

投稿2021/11/26 02:22

int32_t

総合スコア20843

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

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

0

提示コードだと,aとbが共に正でもスタックを食いつぶします.
全体的に間違っています.

  • (そもそも,なぜわざわざ再帰で書く? というのは置いとくとしても)
  • aが負であることを特別視する必要は無い
  • aが0なら結果を1とするというのが間違っている

  1. 「マイナスがどうの」とか言う前に,まずは「a>=0, b>=0 の条件ならまともに動くもの」を作るべき.
  2. 1.ができたならば,それを使う形で b<0 のときの処理を書けばいいのでは.

投稿2021/11/26 02:21

編集2021/11/26 02:29
fana

総合スコア11654

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

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

0

ベストアンサー

b の符号だけで判定すればいいでしょう。

b < 0 なら 1 / my_pow(a, -b) b == 0 なら 1 b > 0 なら a * my_pow(a, b-1)

投稿2021/11/26 02:35

編集2021/11/26 02:36
kazuma-s

総合スコア8224

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

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

fana

2021/11/26 02:43

(aが0か否か という判定も要るでしょうけど)
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問