
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で質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) VBA横データを縦にしたいです 2 2023/08/08 19:38
- Ruby 初心者プログラミング 3 2022/10/12 11:31
- Java Java 南京錠 2 2023/02/04 11:46
- Visual Basic(VBA) ファイル全てを .xlsm に変更したところ、プログラムが途中で落ちてしまっています 17 2022/12/07 12:03
- Microsoft ASP プログラミング関係で質問です。 3 2022/10/11 16:06
- その他(プログラミング・Web制作) python質問 1 2023/08/14 11:54
- C言語・C++・C# C言語プログラム変更 2 2022/12/21 15:03
- Visual Basic(VBA) vba 等間隔の列に対しての計算 6 2022/05/17 20:15
- PHP 配列の値の更新方法について 1 2022/08/05 09:49
- Excel(エクセル) Excelにて、フォルダ内のTextファイルをマクロで統合すると文字化けしてしまう時の解消コード 4 2023/01/01 07:32
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Dir関数で読み取り順を操作でき...
-
VBA 変数名に変数を使用したい。
-
jqueryで配列をMySQLのように扱...
-
Excelのメモリ(配列)の上限は2G...
-
配列のペースト出力結果の書式...
-
エクセルでXY座標に並べられた...
-
vba フィルター 複数条件 3つ以...
-
VBA ReDim と ReDim Preserve ...
-
.NET 文字コードの変換
-
2次元配列のソート
-
C#でbyte配列から画像を表示さ...
-
Msgboxのループ
-
VBAでMODE関数をつくる
-
ActiveReports(アクティブレポ...
-
Segmentation Fault (メモリ制限?)
-
クイズゲームのフォームについて
-
C言語によるプログラミング
-
データ数の定まらないデータを...
-
テキストボックの文字を一行ず...
-
エクセル VBAの処理速度について
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBA 変数名に変数を使用したい。
-
vba フィルター 複数条件 3つ以...
-
C#でbyte配列から画像を表示さ...
-
Dir関数で読み取り順を操作でき...
-
エクセルでXY座標に並べられた...
-
配列のペースト出力結果の書式...
-
定数配列の書き方
-
大量の変数を定義するにはどう...
-
構造体配列の特定のメンバーをF...
-
Redim とEraseの違いは?
-
複数のtextboxの処理を一括で行...
-
VB.NETの配列にExcelから読み込...
-
COBOLの基本的な事なので...
-
Excel2010のinputboxで複数デー...
-
VBAでMODE関数をつくる
-
レコードセットの中身を配列に...
-
ReDim PreserveよりもReDimが遅い
-
EXCELを使って、アクセスログを...
-
配列の中の最大値とそのインデ...
-
VB6のメモリ解放に関して
おすすめ情報