
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で質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
プロが教える店舗&オフィスのセキュリティ対策術
中・小規模の店舗やオフィスのセキュリティセキュリティ対策について、プロにどう対策すべきか 何を注意すべきかを教えていただきました!
-
VBA 変数名に変数を使用したい。
Visual Basic(VBA)
-
VBA シートのボタン名を変更したい
Visual Basic(VBA)
-
EXCEL VBAで全選択範囲の解除
Excel(エクセル)
-
-
4
VBAでループ内で使う変数名を可変にできないか。
Visual Basic(VBA)
-
5
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
6
エクセルVBAのIF文の否定の複数条件
Excel(エクセル)
-
7
Excel マクロ VBA プロシージャが大きすぎます のエラー対処方法
Visual Basic(VBA)
-
8
最も近い数値のあるセルを探す
Excel(エクセル)
-
9
VBAでの Replace関数で、ワイルドカードは使えないのでしょうか?
Visual Basic(VBA)
-
10
エクセルVBAのIf,Then 構文でOr条件とAnd条件の結合方法?
Excel(エクセル)
-
11
TextBoxから数字が文字として入力される?
Visual Basic(VBA)
-
12
VBAでエクセルシートを更新(リフレッシュ)する方法を教えて下さい。
Excel(エクセル)
-
13
(Excel VBA)and,orについて
Excel(エクセル)
-
14
配列の中から最大値だけ取り出す方法
Visual Basic(VBA)
-
15
VBAでユーザーフォームの表示を確認
Visual Basic(VBA)
-
16
エクセルVBAで分岐処理と繰り返し処理を使って最大値を求める方法
Excel(エクセル)
-
17
EXCEL VBAのユーザーフォームに引数を渡す方法について
Excel(エクセル)
-
18
EXCELで2つの数値のうち大きい方を採択する数式
Excel(エクセル)
-
19
array関数で格納した配列の型を変更する
Visual Basic(VBA)
-
20
メッセージボックスに表示する文字を大きくしたい
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
人気Q&Aランキング
-
4
MATLABにて場合分け関数を定義...
-
5
配列で飛び飛びの値を指定して...
-
6
ListViewで、非表示列って作れ...
-
7
do-while文でa〜zまでを表示さ...
-
8
VB2008: CSV を二次元配列に読...
-
9
特定のセル範囲で4文字以上入力...
-
10
モンテカルロ法を用いた積分計...
-
11
VBA Match関数の限界
-
12
2つ以上の変数を比較して最大数...
-
13
Excel VABについて 下記記述が...
-
14
Excel・Word リサーチ機能を無...
-
15
教えて下さい
-
16
特定のPCだけ動作しないVBAマク...
-
17
Excel マクロ VBA プロシー...
-
18
ExcelのVBA。public変数の値が...
-
19
matlabでの標高断面図の作成
-
20
UserForm1.Showでエラーになり...
おすすめ情報
公式facebook
公式twitter