Cells(2, i).Formula = "=trunc(SQRT(" & Cells(2, j).Address & "^2 + " & Cells(3, j).Address & "^2))"

montecarlo2012

Well-known Member
Joined
Jan 26, 2011
Messages
986
Office Version
  1. 2010
Platform
  1. Windows
Hi everyone.
This question has to do with programming logic,
Outer loop and inner loop how to decide wich variable will be where and why.
In this presentation I can see clearly what change (variables) and constants.
so how to process this idea, how to pick inner and outer.

VBA Code:
Cells(2, 43).Formula = "=trunc(SQRT(" & Cells(2, 2).Address & "^2 + " & Cells(3, 2).Address & "^2))"

Cells(2, 44).Formula = "=trunc(SQRT(" & Cells(2, 3).Address & "^2 + " & Cells(3, 3).Address & "^2))"

Cells(2, 45).Formula = "=trunc(SQRT(" & Cells(2, 4).Address & "^2 + " & Cells(3, 4).Address & "^2))"

Cells(2, 46).Formula = "=trunc(SQRT(" & Cells(2, 5).Address & "^2 + " & Cells(3, 5).Address & "^2))"

Cells(2, 47).Formula = "=trunc(SQRT(" & Cells(2, 6).Address & "^2 + " & Cells(3, 6).Address & "^2))"
so applying the idea mentioned before I come out with

VBA Code:
Sub Logic1()
Dim I As Integer
Dim J As Integer

For I = 43 To 47
For J = 2 To 6
Cells(2, I).Formula = "=trunc(SQRT(" & Cells(2, J).Address & "^2 + " & Cells(3, J).Address & "^2))"
Next J
Next I

End Sub
and,,, do not give me the results I was expecting, give me some results but wrong.
Book1
BCDEFG
1
245192436
3815182933
4
Sheet1

This the little example
and this is the right answer
Book1
GHIJKLMN
1
2WRONG4848484848
3
4CORRECT815263748
5
6
Sheet1


thanks for reading
 

Excel Facts

Add Bullets to Range
Select range. Press Ctrl+1. On Number tab, choose Custom. Type Alt+7 then space then @ sign (using 7 on numeric keypad)
Hi @montecarlo2012.
Thanks for posting on the forum.​

Check my following explanation:
You don't need 2 cycles. Only one cycle for cells AQ2 to AU2 (cells(2, 43) to cells(2, 47)), that is, the cycle from 43 to 47.
And a counter that starts at 2 and ends at 6, this counter will increment with each cycle, that is, the cycle starts at 43, the counter at 2, then the cycle changes to 44 and the counter to 3, then 45 and 4 , then 46 and 5, and finally 47 and 6.

That would be an option:
VBA Code:
Sub Logic2()
  Dim i As Integer
  Dim j As Integer
  
  j = 2
  For i = 43 To 47
    Cells(2, i).Formula = "=trunc(SQRT(" & Cells(2, j).Address & "^2 + " & Cells(3, j).Address & "^2))"
    j = j + 1
  Next i
End Sub

Another option to put formulas without cycles:
VBA Code:
Sub Logic3()
  With Range("AQ2:AU2")
    .Formula = "=TRUNC(SQRT(B2^2 + B3^2))"
  End With
End Sub

Try and tell me.
Cordially
Dante Amor
 
Upvote 1
Solution

Forum statistics

Threads
1,223,911
Messages
6,175,324
Members
452,635
Latest member
laura12345

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top