No.1
- 回答日時:
#include <stdio.h>
int maxsec(int n, int a[])
{
int t, i, j;
for (i = 0; i < n - 1; i++) {
for (j = i + 1; j < n; j++) {
if (a[i] < a[j]) {
t = a[i], a[i] = a[j], a[j] = t;
}
}
}
return a[1];
}
int main(void)
{
int a[] = { 3, 5, 8, 4, 7, 2, 9, 6, 0, 1 };
printf("%d\n", maxsec(sizeof(a) / sizeof(a[0]), a));
return 0;
}
要するに、引数として渡した配列を降順にソートして、
先頭から2つ目の要素を返す、ということです。
No.2
- 回答日時:
配列の先頭から順に見て、一番大きな値と2番目の値を求める方法
int maxsec(int n, int a[])
{
int v1,v2;
int i;
v1=a[0];
v2=a[0];
for (i=0; i<n; i++) {
if ((v1 < a[i]) {
v2 = v1;
v1 = a[i];
}
else if (v2 < a[i]) {
v2 = a[i];
}
}
return v2;
}
No.4
- 回答日時:
以前、類題に回答したことがあります。
int maxsec(int n , int a[])
{
int max, second, i;
max=0;
for ( int i=1; i<n; ++i ) if ( a[max]<a[i] ) max=i;
second=0;
if ( max==0 ) second=1;
for ( i=second+1; i<max; ++i ) if ( a[second]<a[i] ) second=i;
for ( i=max+i; i<n; ++i ) if ( a[second]<a[i] ) second=i;
return a[second];
}
参考URL:http://oshiete.goo.ne.jp/qa/5317566.html
No.5
- 回答日時:
No.3 で触れられていますが、「定義の問題」は大切ですよね。
10, 10, 9, 8 というデータがあった場合、そもそも「2番目に大きな値」とは?
1)10, 10, 9, 8 をソートした場合の2番目だから、10
2)数字としては、3種類で、2番目に大きな値は、9
あと、なんか見落としている気もするけど……。
No.6
- 回答日時:
せっかくなので、作ってみました。
No.5 の方針2)で
それぞれの関数の中でやっていることは、全く単純なことというのが、ウリです。
#include <stdio.h>
// 最大の数を返す
int max(int n, int a[])
{
int maxValue = a[0];
int i;
for(i = 1; i < n; i++)
if (maxValue < a[i]) maxValue = a[i];
return maxValue;
}
// 大きさ n の 配列 a[] の中から、 maxValue と同じものを削除して配列を縮める
// 返り値は、縮めた後の配列の大きさ(というか、データの数 - 1)
int pack(int n, int maxValue, int a[])
{
int i;
int j;
for(i = j = 0; i < n; i++)
{
if(a[i] != maxValue)
a[j++] = a[i];
}
return j - 1;
}
// 2番目に大きな値を返す
int maxsec(int n, int a[])
{
return max(pack(n, max(n, a), a), a);
// max(n, a) で、最大値を出して、それれを抜いた配列を pack(n, max(n, a), a) でつくる
// 最後に(最大値が削除された大きさ、pack(n, max(n, a), a) の配列 a の最大値を求める
}
No.7ベストアンサー
- 回答日時:
No.6 訂正です。
int pack(int n, int maxValue, int a[])
{
int i;
int j;
for(i = j = 0; i < n; i++)
{
if(a[i] != maxValue)
a[j++] = a[i];
}
return j; // 配列の「大きさ」なので、j - 1 ではなくて、j が正解。
}
この回答へのお礼
お礼日時:2014/07/16 17:57
もっとも丁寧に回答してくださったのでBAとさせて頂きました。
質問の仕方がいまいちよくなかったのは反省点です。
他の方もわかりやすい回答ありがとうございました!
No.8
- 回答日時:
基本的にNo.1の方と同じですが、
関数に入った時に、
if( n<=1 ){
return( -1 );
}
という2番目が存在しない場合に-1か何かを返すのか、
何を返すのかが明確では有りませんね。(笑)
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# c言語の問題です 課題1 (二分探索木とセット) 大きさ size の配列 array を考える。す 2 2023/01/10 21:08
- Java javaでのプログラム(配列)について質問です. 2 2022/10/14 22:27
- C言語・C++・C# C言語の課題が出たのですが自力でやっても分かりませんでした。 要素数がnであるint型の配列v2の並 3 2022/11/19 17:41
- C言語・C++・C# このプログラミング誰か教えてくれませんか 1 2022/06/02 15:27
- C言語・C++・C# このプログラミングの問題を教えて欲しいです。 キーボードから整数kを入力し、kが配列aの中に何個存在 2 2022/12/19 22:50
- C言語・C++・C# C言語 3 2022/10/04 15:07
- C言語・C++・C# C言語初心者 ポインタについて、お助けください、、 2 2023/03/15 23:50
- C言語・C++・C# c言語 プログラムのエラー 1 2023/02/11 20:31
- C言語・C++・C# 至急教えてください! プログラミングの問題です! お願いします! 出力2と全く同じ出力をするように、 2 2022/06/22 23:10
- Java Java 配列<選挙> 4 2023/07/31 15:07
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「指定されたキャストは有効で...
-
複数桁10進数の*桁目だけを抽出...
-
#define _CRT_SECURE_NO_WARNIN...
-
C言語での引数の省略方法
-
【C++】関数ポインタの使い方
-
比較回数と交換回数表示について
-
C言語で三目並べをするプログラ...
-
if と配列の組み合わせ
-
商と剰余を同時に求める(C言語)
-
C言語での奇数の和
-
ラップ関数とはどんなものですか?
-
Arduinoのプログラムにエラーが...
-
C言語
-
並列プログラミングのπ計算につ...
-
C言語 エラーの原因がわからな...
-
インライン展開されているか確...
-
GlobalAllocの変数を関数に引き...
-
HANDLEて何ですか?
-
read関数をノンブロッキングで...
-
C++でvectorにテキストファイル...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
C言語での引数の省略方法
-
#define _CRT_SECURE_NO_WARNIN...
-
「指定されたキャストは有効で...
-
C言語 配列と関数の練習問題
-
複数桁10進数の*桁目だけを抽出...
-
(int *)の意味
-
if と配列の組み合わせ
-
ラップ関数とはどんなものですか?
-
卒業研究でよく分からないとこ...
-
【C++】関数ポインタの使い方
-
c言語
-
足して100になるような乱数のア...
-
C言語初心者です、、、お助けく...
-
数字列を3桁ごとにカンマで区切...
-
C言語 エラーの原因がわからな...
-
実数の整数部,小数部の取得
-
課題でつまってます・・・
-
商と剰余を同時に求める(C言語)
-
C言語の配列をC++のvectorに高...
-
std::set<int> で、ある値が何...
おすすめ情報