第3講 数字を入れる箱を活用しよう
第9話 数字の加工
1+2+3+4+5+6+7+8+9+10を考える手がかりを得るために、
1+2+3を考えてみましょう。
複雑な問題のヒントを考えるために、
単純化した問題を考える、
プログラミングだけでなく、分野を問わず有効な考え方ですね。
さて、1+2+3の計算をさせるのに、
Private Sub CommandButton1_Click()
Dim a As Byte, b As Byte, c As Byte
a = 1
b = 2
c = 3
Cells(6, 1) = "1+2+3の計算結果は?"
Cells(7, 1) = "1+2+3="
Cells(7, 2) = a + b + c
End Sub
というのが1つの答えです。
ですが、前話の最後の方に用意する箱は、
1つであると書いてあったことを思い出してください。
用意する箱を1つにして、このマクロを改善してください。
解答例は、例によって30行下です。
解答例
Private Sub CommandButton1_Click()
Dim w As Byte
w = 0
w = w + 1
w = w + 2
w = w + 3
Cells(6, 1) = "1+2+3の計算結果は?"
Cells(7, 1) = "1+2+3="
Cells(7, 2) = w
End Sub
『えっ?』
と感じている方、多いですよね。
そうです。
初心者には難しいところですので、解説しましょう。
尚、そんなの簡単だよと思った方もいらっしゃるかもしれませんが、そんな優秀な方も
後の同じことの繰り返し(ループ処理)につながる大事な考え方ですので、
以下を熟読してください。
最初の2行
Dim w As Byte
w = 0
については、特に疑問はないと思いますが、
3行目から5行目の
w = w + 1
w = w + 2
w = w + 3
には???の方も当然いらっしゃいますよね。
=が数学のイコールならw = w + 1なんてことあり得ません。
左辺のwを右辺に移項するなら、
w - w = 1 から 0 = 1 になってしまいます。
この話を聞いて、
第2講 文字を入れる箱を活用しよう
第6話 =の意味
の話を思い出した方多いのではないでしょうか。
そうです。
=は決してイコールではなく、むしろ←をイメージした方がよかったですよね。
w ← w + 1
つまり、
Dim w As Byte
w = 0
w = w + 1
w = w + 2
w = w + 3
でやっていること図にしますと、
ということになります。
1+2+3についてはおわかりになったと思います。
では、1+2+3+4+5+6+7+8+9+10について考えてみてください。
第8話へ 第10話へ
vc++講義へ
初心者のための世界で一番わかりやすいVisual C++入門基礎講座
初心者のための世界で一番わかりやすいVisual Basic入門基礎講座へ
vb講義へ
VB講義基礎へ
初心者のためのJava 入門 基礎から応用まで
数学研究室に戻る