No.5ベストアンサー
- 回答日時:
>次に発生するデータを配列に追加する処理を考えていたので発生するデータが1個であれば1つずらして空きをつくりそこに代入しようと考えていました。
それならやはりリングバッファが目的にかなっているではないですか。
X = (X + 1) Mod 3000 '最初の添え字は最後になる
a(X) = NewData '最初にデータを追加
Debug.Print a(X + n) 'n番目のデータを表示する
こういうのがアルゴリズムというものです。
ちなみに、"補足" を利用した場合、1つのところに書くとすべての回答者にメールが行くので、同じことを書く必要はありません。
No.7
- 回答日時:
本質問の解答にはならないかもしれませんが、有名な「リングバッファー」というデータ構造について、読んで考えて見られては。
何かの参考になるかも知れない。http://www5c.biglobe.ne.jp/~ecb/c/14_06.html
など、リングバッファーでWEB検索する。また「データ構造」の教科書などを見る。Javaでは、この名のクラスも
あります。
本質問は(可能なら)配列(ファイルレコード?)の後ろの方から逆読みをして、自分の土俵の配列の後ろへ追加していけば、元ファイルと同じ順になり処理スタートとしてはそれで良いのではないのでしょうか。
No.6
- 回答日時:
#3のものです。
>リアルタイム処理で・・・
リアルタイム処理かどうかの問題は関係無いと思います。
>1個であれば1つずらして空きをつくりそこに代入しようと・・・
普通は配列には後ろ(使用配列要素数が最大の次に)にデータを追加する ものではないでしょうか。
それに対し本件では第1要素a(1)に追加しなければならない理由こそ明らかにすべきだと思います。その必然性を解答者が納得すれば、答えも最適なものが出やすいと思います。
この回答への補足
質問が不備で大変御迷惑お掛けしました。
ややこしい文になってしまわないかと心配して簡略になってしまいました。
具体的には、以下のようなことをやろうとしていました。
Aテーブルに日付と座標データが一定時間毎にレコードが作成されていきMAX3000レコードになったら一番古いレコードが削除されて新しい日付と座標データが一番最後に追加される処理が別で動いています。
そのAテーブルからデータを読み出して、配列に格納してグラフ表示をさせるのが目的です。データレコードが自動で更新されているので、その都度最初から読み直せば良いと思うのですが、追加されたデータだけを読んで配列に追加できないかな?
と考えていました。(既に読み込んでいるデータを再度読まなくても済むように)
追加する配列要素は最大の次です。ちなみにSQLで読み込みます
No.4
- 回答日時:
C的な考え方ですが、インデックス何番目が、扱うときの0番目であるかをメモればいいのではないでしょうか?
適当な変数Xに最初の要素の番号を入れるのです。
アクセスするときは常に((X+n) Mod 3000)でアクセスします。
そうすれば、データを移動することなく、データの番号をずらすことができます。
データ移動後のアクセスがあまりに多い場合は、アクセス時の計算量が増えるので、効率が良いかどうかは微妙です。
しかし、アクセス数が3000回に満たないなら、この方法はお得です。
この回答への補足
早速のお返事有難うございました。
説明不足で申し訳ございません。
リアルタイム処理で次に発生するデータを配列に追加する処理を考えていたので発生するデータが1個であれば1つずらして空きをつくりそこに代入しようと
考えていました。
No.3
- 回答日時:
配列要素3000と言えば(メモリーが少なかった)昔なら相当なレコード量で、配列に持つなど考えられなっかたです。
もう線形で持つのは止めて、適当な「構造」を配列部分に持ちこむべきではないでしょうか。例えばHeap,Treeなど。
なぜ「ずらす」必要があるのか。まず考えついたロジックで安易にやって居ないか考えて見るべきで、その最適ロジックが無いかこそ質問すべきことではないのでしょうか。見当外れだとお許し下さい。
それと、「ずらしたい」ときは最後の方からやらないとダメでは。
× for i=0 to 2999
a[i]=a[i+1]
○ For i=2999 to 0 Step -1
a(i+1)=a(i)
Next i
この回答への補足
早速のお返事有難うございました。
説明不足で申し訳ございません。
リアルタイム処理で次に発生するデータを配列に追加する処理を考えていたので発生するデータが1個であれば1つずらして空きをつくりそこに代入しようと
考えていました。
有難うございました。
ロジックの考え方が悪いのでしょうね?
データの追加は、配列要素の最大値に入れますので
配列要素の最大値に空きを作ります。
ずらす方法は、最大値から行なうのですね
大変勉強になりました。
No.2
- 回答日時:
処理速度についての問題でしょうか?
だとするとソートプログラムでもない限り
配列を入れ替えるというのは無駄なように思います。
配列を読む方でiの値を動かす方がいいでしょう。
特にVB6ではそういった単調作業が苦手のようです。
VCで作ったDLLにでも配列を渡せば、3000個程度の
long型であれば瞬時ですけどね。
この回答への補足
早速のお返事有難うございました。
説明不足で申し訳ございません。
リアルタイム処理で次に発生するデータを配列に追加する処理を考えていたので発生するデータが1個であれば1つずらして空きをつくりそこに代入しようと
考えていました。
No.1
- 回答日時:
こんにちは。
maruru01です。コレクションを使う方法があります。
使用方法はすでにご存知かも知れませんが、
Dim myCollection As New Collection
と宣言して、
myCollection.Add Item:=a
とコレクションに追加していきます。
追加した順に1からインデックスがつきます。
そして不要なデータを、
myCollection.Remove i
(iはインデックス番号)
と削除すると、削除された分インデックスが前に詰められます。
ただし、追加順が不定の場合はそのまま使えないので、とりあえず配列に入れておいて、全部入れた後で、
For i = 1 To 3000
myCollection.Add Item:=Hairetu(i - 1)
Next i
と、まとめて追加するか、
For i = 1 To 3000
myCollection.Add Item:=""
Next i
みたいに、ダミーデータで追加しておいて、
myCollection(100) = "a"
などと中身を後で代入するかです。
この回答への補足
早速のお返事有難うございました。
説明不足で申し訳ございません。
リアルタイム処理で次に発生するデータを配列に追加する処理を考えていたので発生するデータが1個であれば1つずらして空きをつくりそこに代入しようと
考えていました。
補足で大変御迷惑をお掛けしました。
コレクションコントロールでは、
少し使ったことがありますが未だ勉強不足です
有難うございました
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
あなたの「必」の書き順を教えてください
ふだん、どういう書き順で「必」を書いていますか? みなさんの色んな書き順を知りたいです。 画像のA~Eを使って教えてください。
-
大人になっても苦手な食べ物、ありますか?
大人になっても、我慢してもどうしても食べれないほど苦手なものってありますよね。 あなたにとっての今でもどうしても苦手なものはなんですか?
-
CDの保有枚数を教えてください
ひとむかし前はCDを買ったり借りたりが主流でしたが、サブスクで簡単に音楽が聴ける今、CDを手に取ることも減ってきたかと思います。皆さんは2024年現在、何枚くらいCDをお持ちですか?
-
ちょっと先の未来クイズ第4問
11月ごろに発表される、2024年の「新語・流行語大賞」にノミネートされる言葉を書けるだけ書いてください。
-
あなたの習慣について教えてください!!
あなたが習慣だと思って実践しているものを共有してくださいませんか? 筋肉トレーニングでも朝シャワーでも、あなたが習慣だなと思えば何でも構いません
-
FORMが開いているかどうかの確認方法
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・10秒目をつむったら…
- ・人生のプチ美学を教えてください!!
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VBA 変数名に変数を使用したい。
-
エクセルでXY座標に並べられた...
-
vba フィルター 複数条件 3つ以...
-
C#でbyte配列から画像を表示さ...
-
C#,繰り返し処理での最大値の取...
-
Dir関数で読み取り順を操作でき...
-
大量の変数を定義するにはどう...
-
構造体配列の特定のメンバーをF...
-
VBA 桁数が混在するソート
-
Excel2010のinputboxで複数デー...
-
VB6からの移行したいけど、VB.N...
-
配列のペースト出力結果の書式...
-
配列をランダムに並び替えても...
-
OutOfMemoryExceptionの回避策...
-
RPG 配列宣言について
-
VBAのワークシート関数で配列の...
-
COBOLの基本的な事なので...
-
Redim とEraseの違いは?
-
配列の中から最大値だけ取り出...
-
VB.NETにて、構造体へデータを...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBA 変数名に変数を使用したい。
-
vba フィルター 複数条件 3つ以...
-
エクセルでXY座標に並べられた...
-
C#でbyte配列から画像を表示さ...
-
配列のペースト出力結果の書式...
-
配列の中の最大値とそのインデ...
-
Excel2010のinputboxで複数デー...
-
Dir関数で読み取り順を操作でき...
-
大量の変数を定義するにはどう...
-
Redim とEraseの違いは?
-
VB6のメモリ解放に関して
-
CheckBoxの配列化
-
COBOLの基本的な事なので...
-
コンボボックスのインデックス...
-
構造体配列の特定のメンバーをF...
-
構造体配列内の文字列検索のよ...
-
定数配列の書き方
-
Excelのメモリ(配列)の上限は2G...
-
Segmentation Fault (メモリ制限?)
-
複数のtextboxの処理を一括で行...
おすすめ情報