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

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

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

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

Q&A

解決済

1回答

1986閲覧

最大値を求めるには?

senbe

総合スコア27

C

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

0グッド

0クリップ

投稿2015/04/05 07:02

AIZU ONLINE JUDGE
(http://judge.u-aizu.ac.jp/onlinejudge/description.jsp?id=0001)
の問題「山の高さをメートル単位の整数で表した 10 個のデータがあります。
その 10 個のデータを読み込んで、その中で、高い順から3つ出力して
終了するプログラムを作成して下さい。」
にとりくんでいます。

前にでていた最大値をのぞいて一番大きい最大値を三回さがす、と
考えてみました。

他の方の解答にある一番小さい数を配列の最後におしこんでいく
という方法にくらべると、ぶさいくなやり方なのですが、どうして
うまく通らないのか、ご指摘おねがいします。

lang

1/* http://judge.u-aizu.ac.jp/onlinejudge/description.jsp?id=0001 2山の高さをメートル単位の整数で表した 10 個のデータがあります。 3その 10 個のデータを読み込んで、その中で、高い順から3つ出力して 4終了するプログラムを作成して下さい。 5*/ 6 7#include<stdio.h> 8 9int main(){ 10 int s[10],t[3]; 11 int i,j; 12 int bigger,biggest; 13 14 for (i = 0; i < 10; i++) { 15 scanf("%d",&s[i]); 16 } 17 18 bigger = 0; 19 biggest = 10000 + 1; //10000 が入力の最大値 20 for (j = 0; j < 3; j++) { 21 for (i = 0; i < 10; i++) { 22 if (bigger < s[i] && s[i] < biggest) { 23 bigger = s[i]; 24 } 25 } 26 t[j] = bigger; 27 biggest = bigger; 28 bigger = 0; 29 } 30 for (j = 0; j < 3; j++) { 31 printf("%d\n",t[j]); 32 } 33 34 return 0; 35}

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

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

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

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

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

guest

回答1

0

ベストアンサー

以下のように途中にprintf()関数を入れて途中の値を表示するとどこがまずいかわかると思いますよ。

lang

1 bigger = 0; 2 biggest = 10000 + 1; //10000 が入力の最大値 3 for (j = 0; j < 3; j++) { 4 for (i = 0; i < 10; i++) { 5 if (bigger < s[i] && s[i] < biggest) { 6 printf(" [j=%d][i=%d]:%d\n", j, i, s[i]); 7 bigger = s[i]; 8 } 9 } 10 t[j] = bigger; 11 biggest = bigger; 12 bigger = 0; 13 printf("biggest = %d\n", biggest); 14 } 15 printf(" #### 結果 ###### \n"); 16 for (j = 0; j < 3; j++) { 17 printf("%d\n", t[j]); 18 }

そのときの実行結果は以下の通りです。
100
101
101
100
1
2
3
4
5
6
[j=0][i=0]:100
[j=0][i=1]:101 <=== jのループ1回目の最大値
biggest = 101 <=== 2回目のjループでは101より小さい最大値を見つける。
[j=1][i=0]:100 <=== jのループ2回目の最大値
biggest = 100 <=== 3回目のjループでは100より小さい最大値を見つける。
[j=2][i=4]:1
[j=2][i=5]:2
[j=2][i=6]:3
[j=2][i=7]:4
[j=2][i=8]:5
[j=2][i=9]:6 <=== jのループ3回目の最大値
biggest = 6

結果

101
100
6

参考までに提示のコードをちょっといじってみました。

lang

1int main(){ 2 int s[10], t[3]; 3 int i, j; 4 int bigger, biggest; 5 int pos; /* 最大値を見つけたときの配列の位置 */ 6 7 for (i = 0; i < 10; i++) { 8 scanf_s("%d", &s[i]); 9 } 10 11 bigger = 0; 12 biggest = 10000 + 1; //10000 が入力の最大値 13 pos = 0; 14 for (j = 0; j < 3; j++) { 15 for (i = 0; i < 10; i++) { 16 if (bigger < s[i] ) { 17 printf(" [j=%d][i=%d]:%d\n", j, i, s[i]); 18 bigger = s[i]; 19 pos = i; 20 } 21 } 22 t[j] = bigger; 23 biggest = bigger; 24 bigger = 0; 25 s[pos] = 0; /* 最後に見つけた最大値をゼロクリアすれば次回のループでこの場所は最大値じゃなくなる */ 26 printf("biggest = %d\n", biggest); 27 } 28 printf(" #### 結果 ###### \n"); 29 for (j = 0; j < 3; j++) { 30 printf("%d\n", t[j]); 31 } 32 33 return 0; 34}

投稿2015/04/05 14:40

TaroToyotomi

総合スコア1430

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

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

senbe

2015/04/06 12:00

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問