![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?e8efa67)
次のプログラムは、初期化により文字列を定義し、辞書式配列にしたとき、どの文字列が先頭にくるかを調べるプログラムなのですが。■■■を教えてください
#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で質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
関数から配列を返すには?
-
c言語
-
配列の要素数に変数を入れたい...
-
define で 配列
-
MFC - ダイアログボックスのPic...
-
基本クラスポインタ = new 派生...
-
IPアドレスを配列に代入する方法。
-
C#で配列が空かを判定するには?
-
fclose()でセグメンテーション違反
-
コンボボックスでデフォルト値...
-
C#で構造体の配列を持った構造...
-
三次元配列の動的メモリの確保?
-
万年カレンダーについて。
-
シマウマの模様を変えるプログラム
-
VBAのプログラムで、DIAG = 1# ...
-
C言語 配列の長さの上限
-
fopne で失敗する原因
-
WSH(VBS)でJSONの文字列を読み...
-
セグメントエラー
-
C# Listを使わずに2次元配列の...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
関数から配列を返すには?
-
構造体のextern方法
-
配列の要素数に変数を入れたい...
-
C言語において、 配列要素をひ...
-
define で 配列
-
c言語
-
C#で構造体の配列を持った構造...
-
C言語 ファイルの指定された行...
-
c言語 構造体
-
コンボボックスでデフォルト値...
-
配列のアドレス部
-
MFCのCArrayを使った二次元配列
-
MFC - ダイアログボックスのPic...
-
C言語についてです 5人のテスト...
-
C言語から質問です。
-
AfxBeginThread の引数について
-
C言語の課題が出たのですが自力...
-
Cのエラー
-
int i, int i[1];
-
C#で配列が空かを判定するには?
おすすめ情報