
No.5ベストアンサー
- 回答日時:
No1です。
2個テストで作ったので試してください。
配列で比較する方法だと配列の数(インデックス)の増減にかかわらず
コードを変更しなくてはいいので、メンテナンスが楽になると思います。
2個目は他の方の回答のワークシート関数と配列を使ったものです。
===============================================
Sub Test1()
Dim x(0 To 2) As Long
Dim i As Integer
Dim lngMax As Long
x(0) = 10
x(1) = 1
x(2) = 5
For i = LBound(x) To UBound(x)
If x(i) > lngMax Then
lngMax = x(i)
End If
Next i
MsgBox "最大値:" & lngMax
End Sub
===============================================
Sub Test2()
Dim x As Variant
Dim i As Integer
Dim lngMax As Long
x = Array(10, 1, 5)
MsgBox "最大値:" & Application.WorksheetFunction.Max(x)
End Sub
No.4
- 回答日時:
質問者のやり方(IF a>b )でやるとすると。
。'-----------------------------------
Sub 最大数()
Dim a As Long
Dim b As Long
Dim c As Long
Dim Max As Long
a = 10
b = 200
c = 30
Max = a
If b > Max Then
Max = b
ElseIf c > Max Then
Max = c
End If
MsgBox "a,b,cの中で一番大きな数は " & Max & " です"
End Sub
'----------------------------------
以上です。
No.3
- 回答日時:
こんなの最大値を求めるアルゴリズムとして、一番簡単なものだよ。
広く勉強しないと、VBの本を読んでいるだけではダメだという証拠。
エクセルでは
Sub test91()
d = Range("a65536").End(xlUp).Row
m = Cells(1, 1)
For i = 2 To d
If Cells(i, "A") > m Then
m = Cells(i, "A")
End If
Next i
MsgBox m
End Sub
1
ひとつの椅子がある。まずじゃんけんに勝ったほうが,椅子に座るゲームを想像せよ。
勝つとはこの質問の場合は値の大のほうだ。
始めの人が椅子に座る。
次の人が来て、2人でじゃんけんして、次の人が勝てば椅子に座り、負ければ、去る。これを最後の人までつづける。
最後に残った人が答え。
質問の場合はジャンジケンで無く、数の書いたカードを持っていて、見せ合いをして、自分の持っているカードにある数を比較すると考えればよい。
椅子に当たるのが、上記コードのmです。
ジャンケンの判定が
If Cells(i, "A") > m Then
に当たるのです。
普通の本の説明では、数は配列にあるものとして説明して、コードを書いてあります。
Sub test02()
Dim x(10)
'配列に値設定
d = UBound(x)
MsgBox d
m = x(0)
For i = 1 To d
If x(i) > m Then
m = x(i)
End If
Next i
MsgBox m
End Sub
ーーー
最小を求める場合も>が<に変わるだけ。
No.1
- 回答日時:
こんにちは。
質問のような形で変数を使う場合は配列の変数にするとやりやすいと思います。
dim x(0 to 2) as long
x(0) = 1
x(1) = 10
x(2) = 100
等の場合はループで配列の数字を比較していけばいいと思います。
for i = lbound(x) to ubound(x)
ここで比較
next i
このような場合は別途一時格納用の変数を設けるなどして
やるのが一般的かなと思います。
早速のご回答ありがとうございます。
しかし使い方がよくわかりませんでした。
「ここで比較」の部分に、どういうコードを書けばよろしいでしょうか?
上記の例だと、x(2) が最大値になりますが
どうやったらx(2) を求めることができるのでしょうか?
勉強不足で申し訳ございません。
再度ご回答いただければ幸いです。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) VBAで質問ですが、皆さんはどの様に導き出しているのでしょうか? 6 2022/05/03 21:53
- Visual Basic(VBA) ExcelVBAでDo Until loopのネスト、IF文を使って一致する物と一致しない物としたい 11 2022/12/24 17:46
- Visual Basic(VBA) いつもお世話になっております、VBAで教えて頂きたいのですが 2 2022/05/05 22:20
- Excel(エクセル) VBAで組み合わせ算出やCOUNTIFSの処理を高速化したいです。 4 2022/04/07 02:38
- Visual Basic(VBA) vba 最大値 条件分岐 4 2022/12/10 10:20
- Excel(エクセル) VBAについて 3 2022/06/19 18:19
- Visual Basic(VBA) VBA 行削除した連番 4 2023/06/27 16:00
- Visual Basic(VBA) コード名シートA列と集計シートA列のコードが一致したら、コード名シートA5からk12の範囲をコピーし 1 2022/08/29 23:46
- Visual Basic(VBA) 【VBA】写真の縦横比を変えずに貼り付ける 5 2023/06/13 11:42
- Visual Basic(VBA) VBA 請求書自動作成 3 2022/04/24 01:58
このQ&Aを見た人はこんなQ&Aも見ています
-
EXCELで2つの数値のうち大きい方を採択する数式
Excel(エクセル)
-
エクセルのラベルの値(文字列)を垂直方向で中央揃えにするには?
Excel(エクセル)
-
VBA 変数名に変数を使用したい。
Visual Basic(VBA)
-
-
4
VBAでループ内で使う変数名を可変にできないか。
Visual Basic(VBA)
-
5
配列の中の最大値とそのインデックス番号を取得する方法
Visual Basic(VBA)
-
6
VBAでエクセルシートを更新(リフレッシュ)する方法を教えて下さい。
Excel(エクセル)
-
7
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
8
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
9
UserForm1.Showでエラーになります。
工学
-
10
VBAでブックを非表示で開いて処理して閉じる方法
Excel(エクセル)
-
11
VBAでワークシートを引数としてサンプル関数に渡したい
Visual Basic(VBA)
-
12
エクセルのエラーメッセージ「400」って?
Visual Basic(VBA)
-
13
Enterキーでマクロを起動さす。
その他(ソフトウェア)
-
14
文字列からタブコードを取り除きたい
Visual Basic(VBA)
-
15
VBA エンターキーでイベントに入りたい。
PowerPoint(パワーポイント)
-
16
VBAで文字列を数値に変換したい
Excel(エクセル)
-
17
複数の条件に合う行番号を取得するには
その他(Microsoft Office)
-
18
実行時エラー 438になった時の対処法を教えて下さい。
Visual Basic(VBA)
-
19
別ブックをダイアログボックスで指定してそこにあるシートをコピーしたい
Excel(エクセル)
-
20
【Excel VBA】CSV取込時、数字の先頭の0を消えないようにするには?
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
配列数式の解除
-
2次元動的配列の第一引数のみを...
-
VBA 1次元配列を2次元に追加する
-
ListViewで、非表示列って作れ...
-
配列変数の添字が範囲外ですと...
-
ArrayListの初期値に二次元配列...
-
VBAで多次元配列のインデックス...
-
VB6 配列を初期化したい
-
2つ以上の変数を比較して最大数...
-
MATLABにて場合分け関数を定義...
-
subの配列引数をoptionalで使う...
-
for each の現在の配列ポインタ...
-
fortran 途中まで考えたのです...
-
【VBA】配列とWorksheetFunctio...
-
FORTRANのCOMMON文
-
特定のセル範囲で4文字以上入力...
-
VBA Match関数の限界
-
VBのFunctionで、配列を引数...
-
エクセルで最小値から0を除く方法
-
エクセルマクロで配列の値から...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
配列数式の解除
-
2つ以上の変数を比較して最大数...
-
VBA 1次元配列を2次元に追加する
-
特定のセル範囲で4文字以上入力...
-
subの配列引数をoptionalで使う...
-
VB6 配列を初期化したい
-
配列変数の添字が範囲外ですと...
-
2次元動的配列の第一引数のみを...
-
ListViewで、非表示列って作れ...
-
Excel-VBAの配列「Public Const...
-
for each の現在の配列ポインタ...
-
AES暗号にて、AES_set_encrypt_...
-
Dim は何の略ですか?
-
VBのFunctionで、配列を引数...
-
配列を任意の数値で埋める方法
-
verilogで配列の任意の8bitを取...
-
エクセルで最小値から0を除く方法
-
《エクセル2000》A列・B列の商...
-
配列内の内容を全て表示する方法
-
配列に同じ値を入れる方法
おすすめ情報