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

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

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

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

配列

配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

Q&A

解決済

5回答

1285閲覧

配列の要素から誤った最大値を取得してしまう。

ceg34ry

総合スコア5

C

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

配列

配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

0グッド

0クリップ

投稿2020/06/08 09:49

前提・実現したいこと

配列の要素から最小値、最大値を取得したいです。
最小値も最大値も同様の方法で取得しているにも関わらず、最小値は意図したものが、
最大値のみ誤ったものが出力されます。

発生している問題・エラーメッセージ

最小値は16 最大値は42

該当のソースコード

C

1#include <stdio.h> 2int main(void){ 3 int array[10]={50,38,21,54,83,23,94,67,16,42}; 4 int min = array[0];//仮の最小値 5 int max = array[0];//仮の最大値 6 7 for(int i=0;i<=9;i++){//最小値を求める 8 if(array[i]>array[i+1]){ 9 min = array[i+1]; 10 } 11 } 12 13 for(int j=0;j<=9;j++){//最大値を求める 14 if(array[j]<array[j+1]){ 15 max = array[j+1]; 16 } 17 } 18 19 printf("最小値は%d\n",min); 20 printf("最大値は%d",max); 21}

試したこと

サンプルの値を下記のようの代入した場合は最小値、最大値ともに正しい実行結果が得られました。
int array[10]={80,70,31,24,88,90,4,63,116,12};

最小値は12
最大値は116

補足情報(FW/ツールのバージョンなど)

本来、サンプルの値に関わらず最小値と最大値を求められることを想定しています。
実行環境はpaiza.ioです。

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

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

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

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

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

guest

回答5

0

ええと、現在のソースで最大値と最小値が正しく求められているのは偶然そうなっているだけです。
(たとえば、「試したこと」のサンプルの最後の2つの値が全体の最大値と最小値になっている)

最小値で説明すると、minに「それまでの最小値」を入れるためには、if文は「minと配列の要素の値」を比較し、minよりも小さければ、minにその配列の要素の値を代入する、ように書かなければいけません。

ついでに言うと、元のソースは array[10] (配列の範囲外の値)を使っています。

投稿2020/06/08 09:59

Daregada

総合スコア11990

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

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

ceg34ry

2020/06/08 10:33

回答ありがとうございます。偶然もっともらしい値が得られてしまうことも勉強になりました。
guest

0

ベストアンサー

最小値、最大値の検索内で、配列内の値の大小を比較していますが、比較対象は、仮の最小値、最大値である、min、maxです。

C

1#include <stdio.h> 2int main(void){ 3 int array[10]={50,38,21,54,83,23,94,67,16,42}; 4 int min = array[0];//仮の最小値 5 int max = array[0];//仮の最大値 6 7 for(int i=1;i<=9;i++){//最小値を求める 8 if(array[i]<min){ 9 min = array[i]; 10 } 11 } 12 13 for(int j=1;j<=9;j++){//最大値を求める 14 if(array[j]>max){ 15 max = array[j]; 16 } 17 } 18 19 printf("最小値は%d\n",min); 20 printf("最大値は%d",max); 21}

なお、元のコードは、配列外へのアクセスがある危険なコードです。
また、試したことの場合の最小値は4が正解なので、誤った結果です。

投稿2020/06/08 10:01

YT0014

総合スコア1708

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

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

ceg34ry

2020/06/08 10:33

回答ありがとうございます。わかった事は以下のとおりです。 ・比較対象は配列同士ではなく仮の最小値(または仮の最大値)であること ・配列外アクセスの危険なコードであること ・「試したこと」も正常に動作していなかった事
guest

0

プログラムが間違っていますので、正しく求まったり、求まらなかったりするのは、データによってたまたまです。

隣と比べて大きいか小さいかを見ても無意味です。
今までの最小値や最大値と比べましょう。

投稿2020/06/08 09:58

otn

総合スコア84557

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

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

ceg34ry

2020/06/08 10:34

回答ありがとうございます。
guest

0

C

1 for(int i=0;i<=9;i++){//最小値を求める 2 if(array[i] < min) { // minより小さいのが見つかったらminを更新 3 min = array[i]; 4 } 5 }

じゃなくて?
※ maxも同様

投稿2020/06/08 09:55

episteme

総合スコア16614

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

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

ceg34ry

2020/06/08 10:34

回答ありがとうございます。
guest

0

forループの中のifで配列要素同士ではなくminmax変数と比較する必要があります。
最小値の方もたまたま正常に動作してるように見えるだけです。

投稿2020/06/08 09:54

kuuote

総合スコア705

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

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

ceg34ry

2020/06/08 10:34

回答ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問