struct S_Data
{
----char ID[16];
----char PW[16];
};
とし、
S_Data Data[100];
とします。
IDとPWを入力すると、100個のID・PW群からその組み合わせがあるかを検索し、その結果を返したいのですが、いい方法が思いつきません。
単純にやるとすれば、入力されたID、PWをそれぞれid、pwとすると
for( int i=0 ; i<100 ; i++ )
{
----if( strcmp(Data[i].ID,id) == 0 )
----{
--------if( strcmp(Data[i].PW,pw) == 0 )
--------{
------------return 1;
--------} else {
------------return -1;
--------}
----}
}
return 0;
とすればいいのですが、もっと簡単にやる(実行速度が速い)方法はないでしょうか?
No.1ベストアンサー
- 回答日時:
検索が一回きりなら、提示の方法が一番早いでしょう。
相当回数検索するなら、ソートしてバイナリサーチとか。
使用される文字に制限があるなら、先頭文字の種類ごとに配列を分けるとか。
たとえば、IDがすべて数値なら、配列を10に分割できますよね。
ハッシュを使うという方法もありますが、100件くらいだと、効果はあまりないかもしれません。
ここにまとめてお礼を書かせていただきます。
皆さん、ありがとうございました。
ベストアンサーはmaru_yoshi_さんかtitokaniさんか迷ったのですが、
titokaniさんにさせていただきます。
構造体内にいろんな変数が合って配列の添え字で人を識別しようとしているので(こんな感じです)
struct S_Data
{
----int Num;
----char ID[16];
----char PW[16];
----int Month;
----int Day;
----int Type;
----float Time;
};
として、
IDとPWが合っていたらNumを返して(Numの値は配列の添え字と同じ)
以下例えば
printf( "100m走のタイムは%f\n",Data[10].Time);
のようにしたいのですが、データはランダムかつ不定期に増えるので、並び替えていると参照部が変わってきてしまうので並び替えは難しいです。
これ質問部に予め書くべきでしたね・・・・・・・
No.2
- 回答日時:
ランダムなデータから一致するものを探すなら総当たりしかないように思えます。
一定のルールに並んだデータから一致するものを探すならバイナリサーチでもいいでしょう。
構造体配列に入れられたデータから検索するのであっても、その構造体配列にデータを
いれる処理がどこかにあるはずなので、そのルールはわかっているはず。
それが分かっていれば、探索手順を短くすることも可能でしょう。
もしかすると、構造体配列に入れる際にいろいろな工夫をすることもできるかも。
いずれにせよ、検索そのものの時間コスト、検索の準備(ソートなど)の為のコストを見積もり、
トータルで性能を考える必要があります。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- モバオク! PayPay銀行のログインID PWのどちらも分からず、ログイン出来ずに困っています 5 2023/04/07 18:04
- Wi-Fi・無線LAN ルーター設定画面のログアウト方法がわからない 3 2023/04/08 13:40
- その他(動画サービス) 実家の親が知らぬ間にU-NEXTに申し込んでしまい、毎月2000円支払ってることに気づきました。 I 0 2023/05/06 09:56
- その他(セキュリティ) システムのセキュリティに詳しい方〜 飛行機のチケット使わなかったときのチケット費用補償保険/旅行キャ 1 2022/04/06 09:49
- その他(SNS・コミュニケーションサービス) ZOOMの使い方について 2 2022/07/06 11:03
- C言語・C++・C# c言語の問題です 3 2023/01/10 16:15
- JavaScript jQueryでのドラッグアンドドロップについて 1 2022/07/07 21:04
- gooブログ ブログIDって何でしょうか? 2 2022/05/15 09:44
- 電子マネー・電子決済 IDカードは便利? 3 2022/04/02 12:27
- gooブログ ブログ開設方法 2 2022/05/15 14:28
このQ&Aを見た人はこんなQ&Aも見ています
-
それもChatGPT!?と驚いた使用方法を教えてください
仕事やプライベートでも利用が浸透してきたChatGPTですが、こんなときに使うの!!?とびっくりしたり、これは画期的な有効活用だ!とうなった事例があれば教えてください!
-
あなたにとってのゴールデンタイムはいつですか?
一週間の中でもっともテンションが上がる「ゴールデンタイム」はいつですか? その逆で、一週間でもっとも落ち込むタイミングでも構いません。 よかったら教えて下さい!
-
これが怖いの自分だけ?というものありますか?
人によって怖いもの(恐怖症)ありませんか? 怖いものには、怖くなったきっかけやエピソードがあって聞いてみるとそんな感覚もあるのかと新しい発見があって面白いです。
-
ちょっと先の未来クイズ第5問
日本漢字能力検定協会が主催し、12月12日に発表される、2024年の「今年の漢字」に選ばれる漢字一文字は何でしょう?
-
【大喜利】【投稿~11/22】このサンタクロースは偽物だと気付いた理由とは?
【お題】 ・このサンタクロースは偽物だと気付いた理由とは?
-
VB.NET 構造体の配列の検索機能について
Visual Basic(VBA)
-
構造体のメンバをfor文で回したい
C言語・C++・C#
-
ファイルから読み込んだデータを構造体に格納できますか?
C言語・C++・C#
-
-
4
C言語で構造体のメンバを簡単に出力する方法ありますか?
C言語・C++・C#
-
5
構造体の勉強中です 合計点の高い順に並べ替えがわかりません
C言語・C++・C#
-
6
CString型 全角半角を意識せずに「1文字」ずつ取り出す
C言語・C++・C#
-
7
バッファとは何ですか
C言語・C++・C#
-
8
セグメントエラー
C言語・C++・C#
-
9
fopne で失敗する原因
C言語・C++・C#
-
10
動的配列が存在(要素が有る)か否かを判定できますか?
Visual Basic(VBA)
-
11
DWORDの実際の型は何でしょうか
C言語・C++・C#
-
12
CStringのFindで文字列検索を行いたいのですが
C言語・C++・C#
-
13
構造体配列のソート
Visual Basic(VBA)
-
14
*をユーザーが入力した数字の数だけ表示するプログラムの作り方を教えてください
C言語・C++・C#
-
15
fopenでのパス指定
C言語・C++・C#
-
16
構造体のデータを丸ごとコピーしたい
C言語・C++・C#
-
17
構造体配列の特定のメンバーをFor~Eachで
Visual Basic(VBA)
-
18
ADO VBA 実行時エラー3021
Visual Basic(VBA)
-
19
CString から LPCTSTRの型に変換
C言語・C++・C#
-
20
構造体配列のvectorへの変換とアルゴリズムでの検索方法
C言語・C++・C#
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~12/2】 国民的アニメ『サザエさん』が打ち切りになった理由を教えてください
- ・ちょっと先の未来クイズ第5問
- ・【お題】ヒーローの謝罪会見
- ・これが怖いの自分だけ?というものありますか?
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・【大喜利】【投稿~11/22】このサンタクロースは偽物だと気付いた理由とは?
- ・お風呂の温度、何℃にしてますか?
- ・とっておきの「まかない飯」を教えて下さい!
- ・2024年のうちにやっておきたいこと、ここで宣言しませんか?
- ・いけず言葉しりとり
- ・土曜の昼、学校帰りの昼メシの思い出
- ・忘れられない激○○料理
- ・あなたにとってのゴールデンタイムはいつですか?
- ・とっておきの「夜食」教えて下さい
- ・これまでで一番「情けなかったとき」はいつですか?
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VBA 変数名に変数を使用したい。
-
エクセルでXY座標に並べられた...
-
C#でbyte配列から画像を表示さ...
-
VB.NETの配列にExcelから読み込...
-
Excel2010のinputboxで複数デー...
-
Dir関数で読み取り順を操作でき...
-
COBOLの基本的な事なので...
-
VB6からの移行したいけど、VB.N...
-
クイズゲームのフォームについて
-
Variant型配列の文字コード変換
-
配列の中の最大値とそのインデ...
-
VB.NETの配列の限界を教えてく...
-
VBAでMODE関数をつくる
-
VBで組み合わせのプログラム...
-
エクセル(VBA)の空白配列の削除...
-
EXCEL VBA 配列デー...
-
2次元配列を部分的に削除する方法
-
Redim とEraseの違いは?
-
構造体配列の特定のメンバーをF...
-
乱数で決めた値の範囲を表示する
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBA 変数名に変数を使用したい。
-
vba フィルター 複数条件 3つ以...
-
エクセルでXY座標に並べられた...
-
C#でbyte配列から画像を表示さ...
-
配列のペースト出力結果の書式...
-
配列の中の最大値とそのインデ...
-
Excel2010のinputboxで複数デー...
-
Dir関数で読み取り順を操作でき...
-
大量の変数を定義するにはどう...
-
Redim とEraseの違いは?
-
VB6のメモリ解放に関して
-
CheckBoxの配列化
-
COBOLの基本的な事なので...
-
コンボボックスのインデックス...
-
構造体配列の特定のメンバーをF...
-
構造体配列内の文字列検索のよ...
-
定数配列の書き方
-
Excelのメモリ(配列)の上限は2G...
-
Segmentation Fault (メモリ制限?)
-
複数のtextboxの処理を一括で行...
おすすめ情報