#include<stdio.h>
typedef struct{
char mozi[10];
char namae[30];
}PE;
void input_profile(PE *p,int *a);
void printf_profile(PE *p,int *a);
int main(void)
{
int i=0;
PE c[999];
input_profile(c,&i);
return 0;
}
void input_profile(PE *p,int *a){
int c,b;
for(b=0;999>b;b++)
{
printf("名前を入力\n");
scanf("%s",(p+b)->namae);
printf("文字を入力\n");
scanf("%s",(p+b)->mozi);
printf("入力を終えるなら0を入力してください\n続けるなら、それ以外の数字を入力してください\n");
scanf("%d",&c);
if(c==0)break;
}
b++;
*a=b;
printf_profile(p,a);
}
void printf_profile(PE *p,int *a)
{
int b;
for(b=0;*a>b;b++)
{
printf("NO%d\n",b+1);
printf("文字%s\n",(p+b)->mozi);
printf("名前%s\n",(p+b)->namae);
}
}
このプログラムを
自分で関数を作って
データ一覧をmoziのアルファベット順に表示するように書きなおしたいんですけど
どうなるのでしょうか?
どうか教えてください
No.3ベストアンサー
- 回答日時:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
typedef struct {
char mozi[10];
char namae[30];
} PE;
void input_profile(PE *p,int *a);
void printf_profile(PE *p,int *a);
int comp_profile(const void* vx, const void* vy) {
const PE* px = (const PE*)vx;
const PE* py = (const PE*)vy;
return strcmp(px->mozi, py->mozi);
}
int main(void) {
int i = 0;
PE c[999];
input_profile(c,&i);
qsort(c, i, sizeof(PE), &comp_profile);
printf_profile(c,&i);
return 0;
}
/* あとは同じ */
No.2
- 回答日時:
「ソート」で検索すればいくらでもサンプルコードが見付かります。
サンプルコードでは、大抵数値(intとかdoubleとか)の配列の並び換えになっていますが、少し変えると構造体にも使えます。
・不等号では期待する比較にできないので、比較用関数でも用意する。
・構造体の配列そのものを並びかえるなら、サンプルでintとかになっているところを構造体に変更するだけです。
構造体の作り方によってはコピーが期待通りにならない、という問題はありますが、今回のなら大丈夫です。詳しくは「浅いコピー 深いコピー」で検索。
あと、パフォーマンスは悪いです。
・元のデータはそのまま、ポインタの配列を使うのが、よくある方法です。
PE *pp[999] ;
の様に用意し
pp[0]=&p[0],pp[1]=&p[1] ...
という内容にして、p[i]ではなく*(pp[i])を使って比較し配列ppを並び換えるものです。
同様に、インデックスの配列でやる方法もあります。
(int idx[999] ;pp[0]=0,pp[1]=1...p[i]ではなくp[idx[i]]で比較、idxを並び換える。)
・一番最初に表示するものを検索→表示(表示したことをフラグ用の配列にでも覚えておく)
残ってる中で、一番最初に表示するものを検索→表示
..を繰り返す。「選択ソート」のアルゴリズムで、実際の並び換えを行わないものです。
これもパフォーマンスはわるいですが。
それから、せっかくinput_profileとprintf_profileとに機能を分けているですから、inputの中でprintするのはどうかと設計的にどうか、と思います。
input_profile(c,&i);
printf_profile(c,i);
のように使うのが一般的です。
No.1
- 回答日時:
ソート(sort)って聞いたことありませんか? 一番単純なのがバブルソートですので、処理時間がかかっても良いならバブルソートについて調べてみて、それで作ってみましょう。
すごく簡単ですよ。注意点としては、moziの大小比較をどうするかです。私なら、strcmp関数を使います。
http://stocks.finance.yahoo.co.jp/stocks/chart/? …
関数の作り方はご存知ですよね?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# 宣言する関数の形が決まっている状態で、 str1とstr2の文字列をこの順に引っ付けてstrに保存し 2 2022/05/30 18:21
- C言語・C++・C# c言語の問題です 3 2023/01/10 16:15
- 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# C言語のエラーについて 2 2022/07/11 13:56
- C言語・C++・C# C言語 プログラミング 4 2022/05/22 11:53
- C言語・C++・C# C言語プログラム変更 2 2022/12/21 15:03
- C言語・C++・C# プログラミングの授業の課題です 1 2023/01/17 22:15
- C言語・C++・C# C言語の課題が出たのですが自力でやっても分かりませんでした。 要素数がnであるint型の配列v2の並 3 2022/11/19 17:41
- C言語・C++・C# プログラミング c言語 4 2023/03/07 01:05
関連するカテゴリからQ&Aを探す
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
C言語での引数の省略方法
-
#define _CRT_SECURE_NO_WARNIN...
-
「指定されたキャストは有効で...
-
C言語 エラーの原因がわからな...
-
【C++】関数ポインタの使い方
-
数字列を3桁ごとにカンマで区切...
-
c++でテンプレートのコードでわ...
-
複数桁10進数の*桁目だけを抽出...
-
(int *)の意味
-
ラップ関数とはどんなものですか?
-
C言語
-
プログラミング☆
-
実数の整数部,小数部の取得
-
system関数がうまくいかない
-
Arduinoのプログラムにエラーが...
-
毎回違う乱数を生成するにはど...
-
16進数の計算の仕方を教えて下さい
-
PowerShellがうまくいかない
-
このプログラミング誰か教えて...
-
構造体の勉強中です 合計点の高...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「指定されたキャストは有効で...
-
C言語での引数の省略方法
-
#define _CRT_SECURE_NO_WARNIN...
-
複数桁10進数の*桁目だけを抽出...
-
へんな現象
-
【C++】関数ポインタの使い方
-
C言語 エラーの原因がわからな...
-
if と配列の組み合わせ
-
C言語での奇数の和
-
C言語 配列と関数の練習問題
-
ラップ関数とはどんなものですか?
-
(int *)の意味
-
C言語
-
実数の整数部,小数部の取得
-
足して100になるような乱数のア...
-
卒業研究でよく分からないとこ...
-
数字列を3桁ごとにカンマで区切...
-
c言語
-
std::set<int> で、ある値が何...
-
比較回数と交換回数表示について
おすすめ情報