![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?5a7ff87)
No.1ベストアンサー
- 回答日時:
現在の話ですから、BasicというのはVisual Basicの事だと思っていいんでしょうか?
DIM文はもともとはdimension=次元を表し、配列の宣言専門のステートメントだったと聞いた事
があります。
それはさておき、本題に入ります。
【DIM文の使い方】
変数を宣言するステートメントです。
特に配列に関しては、配列の最大の添え字を宣言できると考えた方がいいでしょう。
1)----------------------------------
(Option Base 0)※Option Baseを宣言しないと添え字を0からと解釈する。
Dim x(3) As Integer
Dim x(0 to 3) As Integer
2)----------------------------------
Option Base 1
Dim x(4) As Integer
3)----------------------------------
Dim x(1 to 4) As Integer
------------------------------------
1)~3)まで、要素を4つとるという点では差がありません。1)はx(0)が要素としてあるので要素数は4です。
2)と3)は添え字1~4をとるという意味で等価です。
1)は、添え字を0~3でとるという意味で他の二つとはちょっと違います。
以上は、一次元の配列なので、行列のような二次元以上の配列を宣言する場合には
Dim x(一次元目の添え字宣言、二次元目の添え字宣言、・・・)
となります。
実際,行列を宣言する場合には、4行4列の行列であれば、
Dim matrix(3,3)
Dim matrix(0 to 3,0 to 3)
か
Option Base 1
Dim matrix(4,4)
Dim matrix(1 to 4,1 to 4)
になります。
行列としてみる場合には、一次元目が行、二次元目が列です。
【行列の計算】
行列Aと行列Bの積は、Aの列数とBの行数が等しい時に計算可能です。
行列Aの成分をAlc、Bの成分をBlc、積ABの成分をClcで表すと
(Xlc l:何番目の行か、c:何番目の列か と定義します。)
Clc = Al1*B1c +Al2*B2c・・・Alx*Bxc (xは、Aの列数とBの行数)
という式で積ABの要素は求められます。
積ABの要素Cが行(l)、列(c)の二つの項目を持っているのでそれでを特定するため、まずループ
が二重に必要です。
そしてその要素一つについて、加算のためのループが必要なので、合計ループは三重です。
試みに書いたのは、以下のような感じです。
Dim A(0 To 3, 0 To 3) As Integer
Dim B(0 To 3, 0 To 3) As Integer
Dim AB(0 To 3, 0 To 3) As Integer
Sub main()
Dim i, j, k, sum As Integer
Dim msg As String
'行列の初期化処理を行う
'行列の計算を行う
For i = 0 To 3
For j = 0 To 3
sum = 0
For k = 0 To 3
sum = sum + A(i, k) * B(k, j)
Next k
AB(i, j) = sum
Next j
Next i
End Sub
以上、参考までに。
この回答へのお礼
お礼日時:2006/10/26 09:47
配列のとり方にはいくつかのやり方があることがわかりました。
とても、丁寧な説明ありがとうございました。
とても、わかりやすかったです。
また、自分でも試してみたいと思います。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# C言語 3 2022/10/04 15:07
- その他(プログラミング・Web制作) 3Dモデルにおける法線の計算について(Python,OpenGL) 1 2023/04/25 23:46
- その他(ソフトウェア) F-BASICで計算中の実行が中途で勝手に止まり、大変困っています。 2 2023/03/02 16:15
- その他(プログラミング・Web制作) パイソンのプログラミングについての質問です 2 2023/05/22 12:39
- Visual Basic(VBA) ファイル全てを .xlsm に変更したところ、プログラムが途中で落ちてしまっています 17 2022/12/07 12:03
- 建設業・製造業 河川の積算の勉強に役立つ本はありませんか? 例えば数量計算書や図面から間違いがないか確認し、 確認後 2 2023/02/09 19:40
- 数学 複利毎月積み立てで年利からの計算方法 3 2023/01/11 15:56
- C言語・C++・C# numpyスライス機能を使った数値計算 2 2023/05/08 16:01
- その他(コンピューター・テクノロジー) 50台の織機から回転数を取得・集計しモニターに表示したい 2 2022/11/05 15:48
- 数学 連立微分方程式の解き方について 7 2022/12/16 13:39
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
配列数式の解除
-
for each の現在の配列ポインタ...
-
VBA 1次元配列を2次元に追加する
-
2つ以上の変数を比較して最大数...
-
Dim は何の略ですか?
-
配列変数の添字が範囲外ですと...
-
特定のセル範囲で4文字以上入力...
-
ビンゴ
-
VBのFunctionで、配列を引数...
-
VB2008: CSV を二次元配列に読...
-
行列の積の計算プログラムを教...
-
MATLABにて場合分け関数を定義...
-
fortranでのcsvファイルの読み込み
-
【MATLAB】任意の多次元配列か...
-
配列を任意の数値で埋める方法
-
linest関数に配列を渡す
-
VLOOKUP関数で、一番下...
-
Excel-VBAの配列「Public Const...
-
VBAで近似曲線の係数取得
-
個数が1以上の行を個数分行コ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
配列数式の解除
-
2つ以上の変数を比較して最大数...
-
for each の現在の配列ポインタ...
-
VBA 1次元配列を2次元に追加する
-
特定のセル範囲で4文字以上入力...
-
配列変数の添字が範囲外ですと...
-
subの配列引数をoptionalで使う...
-
えfor文とか使っちゃう時点で時...
-
ListViewで、非表示列って作れ...
-
Excel-VBAの配列「Public Const...
-
VBAで近似曲線の係数取得
-
VB6 配列を初期化したい
-
VBのFunctionで、配列を引数...
-
エクセルで最小値から0を除く方法
-
《エクセル2000》A列・B列の商...
-
Dim は何の略ですか?
-
配列を任意の数値で埋める方法
-
友愛数を探すプログラム
-
verilogで配列の任意の8bitを取...
-
配列内の内容を全て表示する方法
おすすめ情報