![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?5a7ff87)
次のプログラムは、初期化により文字列を定義し、辞書式配列にしたとき、どの文字列が先頭にくるかを調べるプログラムなのですが。■■■を教えてください
#include <stdio.h>
#include <string.h>
#define N 5
//関数のプロトタイプ宣言
char *min(char *p[] , int n);
int main(void)
{
char *p[N] = {"Hello" , "Hi" , "Happy" , "HaHaHa" , "Heaven"};
printf("辞書式配列で先頭となる文字列は%s\n" , ■■■);
}
char *min(char *p[] , int n)
{
int min; //最小値のアドレス
Int i; //カウンタ
min = 0;
for(i = 1; i < n; i++){
if (strcmp(■■■ , ■■■) > 0){
■■■= ■■■;
}
}
return ■■■;
}
A 回答 (5件)
- 最新から表示
- 回答順に表示
No.5
- 回答日時:
内容としては----以下のとおりです
・関数minはp[min]=最小となる文字列へのポインタを返すのでprintfの%sにそのまま渡します
・変数minが、最小となる要素へのインデックスを覚えておくので、
strcmp(p[min] , p[i]) でp[i]の方が小さければ、
min=i で最小インデックスminをiに更新します
----
#include <stdio.h>
#include <string.h>
#define N 5
//関数のプロトタイプ宣言
char *min(char *p[] , int n);
int main(void)
{
char *p[N] = {"Hello" , "Hi" , "Happy" , "HaHaHa" , "Heaven"};
printf("辞書式配列で先頭となる文字列は%s\n" , min(p, N));
}
char *min(char *p[] , int n)
{
int min; //最小値のアドレス
int i; //カウンタ
min = 0;
for(i = 1; i < n; i++){
if (strcmp(p[min] , p[i]) > 0){
min=i;
}
}
return p[min];
}
No.4
- 回答日時:
> 辞書式配列
というのがよくわかりませんが、strcmp関数では単純比較しかできませんので違うように思います。
strxfrm関数で変換してから比較するのかもしれませんが、この穴埋めではsetlocaleを呼び出すのは無理があります(関数を無理やり呼ぶことはできますが、<locale.h>をインクルードできないので、LC_COLLATEまたはLC_ALLの定義が得られません)。
どうすべきなのかをもう少し明確にしてください。
No.3
- 回答日時:
#1ですが、さすがに答を直書きでは問題ですよね?
というわけで、きちんと先頭を探すプログラムを書きます。
(i) 配列を破壊しないもの
最初の■■■:
(strcmp(a[0], a[1]) < 0) ? (strcmp(a[0], a[2]) < 0) ? (strcmp(a[0], a[3]) < 0) ? (strcmp(a[0], a[4]) < 0) ? a[0] : a[4]
: (strcmp(a[3], a[4]) < 0) ? a[3] : a[4]
: (strcmp(a[2], a[3]) < 0) ? (strcmp(a[2], a[4]) < 0) ? a[2] : a[4]
: (strcmp(a[3], a[4]) < 0) ? a[3] : a[4]
: (strcmp(a[1], a[2]) < 0) ? (strcmp(a[1], a[3]) < 0) ? (strcmp(a[1], a[4]) < 0) ? a[1] : a[4]
: (strcmp(a[3], a[4]) < 0) ? a[3] : a[4]
: (strcmp(a[2], a[3]) < 0) ? (strcmp(a[2], a[4]) < 0) ? a[2] : a[4]
: (strcmp(a[3], a[4]) < 0) ? a[3] : a[4]
後の■■■:前回の回答と同じ
(ii) 配列を破壊するもの
最初の■■■:
(
(a[0] = (strcmp(a[0], a[1]) < 0) ? a[0] : a[1]),
(a[0] = (strcmp(a[0], a[2]) < 0) ? a[0] : a[2]),
(a[0] = (strcmp(a[0], a[3]) < 0) ? a[0] : a[3]),
(a[0] = (strcmp(a[0], a[4]) < 0) ? a[0] : a[4]),
a[0]
)
後の■■■:前回の回答と同じ
代わりに宿題です。上で何をやっているのか説明しなさい。
No.2
- 回答日時:
C/C++の宿題片付けます 154代目
http://hibari.2ch.net/test/read.cgi/tech/1322562 …
Java の宿題ここで答えます Part 71
http://toro.2ch.net/test/read.cgi/tech/130907689 …
No.1
- 回答日時:
#include <stdio.h>
#include <string.h>
#define N 5
//関数のプロトタイプ宣言
char *min(char *p[] , int n);
int main(void)
{
char *p[N] = {"Hello" , "Hi" , "Happy" , "HaHaHa" , "Heaven"};
printf("辞書式配列で先頭となる文字列は%s\n" , p[3]);
}
char *min(char *p[] , int n)
{
int min; //最小値のアドレス
Int i; //カウンタ
min = 0;
for(i = 1; i < n; i++){
if (strcmp("" , "") > 0){
min= min;
}
}
return NULL;
}
宿題のようなので、真面目な答えは自分で考えましょう。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# C言語のエラーについて 2 2022/07/11 13:56
- C言語・C++・C# c言語 プログラムのエラー 1 2023/02/11 20:31
- C言語・C++・C# c言語配列の結合についてです。 なぜうまくいかないのでしょうか。 #include <stdio.h 4 2022/05/30 22:42
- C言語・C++・C# c言語でユーザ関数を利用して入力された文字列を反転させるプログラムを作りたいです。 3 2023/01/29 19:47
- C言語・C++・C# 宣言する関数の形が決まっている状態で、 str1とstr2の文字列をこの順に引っ付けてstrに保存し 2 2022/05/30 18:21
- C言語・C++・C# このプログラミング誰か教えてくれませんか 1 2022/06/02 15:27
- C言語・C++・C# プログラミングの授業の課題です 1 2023/01/17 22:15
- C言語・C++・C# プログラミングを教えて欲しいです。 配列aは、int a[9]={7,6,12,8,3,5,10,9 4 2022/12/19 23:27
- C言語・C++・C# 並列プログラミングのπ計算について 1 2022/07/16 22:30
- C言語・C++・C# カードシャッフルのブログラムを使ってc言語でブラックジャックをしたい 2 2022/04/12 15:13
関連するカテゴリからQ&Aを探す
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
関数から配列を返すには?
-
int i, int i[1];
-
配列の要素数に変数を入れたい...
-
C言語において、 配列要素をひ...
-
アドレス格納のための二次元配...
-
define で 配列
-
c言語 構造体
-
MFC - ダイアログボックスのPic...
-
コンボボックスでデフォルト値...
-
c言語
-
この変数名はわかりにくいですか?
-
C言語で重複組合せを全列挙
-
C言語(サイズ指定のない配列)
-
MFCのCArrayを使った二次元配列
-
構造体のextern方法
-
C言語から質問です。
-
構造体の配列 char *' 型は 'ch...
-
C#で構造体の配列を持った構造...
-
要素数・要素の値が未定の配列...
-
C言語についてです 5人のテスト...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
おすすめ情報