Still celebrating National IT Professionals Day with 3 months of free Premium Membership. Use Code ITDAY17

x
?
Solved

MS Excel - working with Arrays and looping through code

Posted on 2006-07-18
4
Medium Priority
?
187 Views
Last Modified: 2010-04-30
I am trying to create an array from two values. For example, lets say cell A1 = 5 and B1 = 7. I want code that examines the two values, identifies the smallest, creates an array that counts from the smallest down to 0, while increasing the largest at the same time:

5   7
4   8
3   9
2   10
1   11
0   12

My code is not working, and I am coming up with some funny values. What am I doing wrong?  Here is my code:

Function createArray(cellA, cellB)

Dim MPos1, getMin, myNewArray(100, 2), rw, prw
Dim myArray(100, 2)

    If cellA <= cellB Then
        MPos1 = 1
        getMin = cellA
    Else
        MPos1 = 2
        getMin = cellB
    End If
   
myNewArray(0, 1) = cellA
myNewArray(0, 2) = cellB

For rw = 1 To getMin

    prw = rw - 1

    If MPos1 = 1 Then myNewArray(rw, 1) = myNewArray(prw, 1) - 1 Else myNewArray(rw, 1) = myNewArray(prw, 1) + 1
    If MPos1 = 1 Then myNewArray(rw, 2) = myNewArray(prw, 1) + 1 Else myNewArray(rw, 1) = myNewArray(prw, 2) - 1
    rw = rw + 1
   
Next

createArray = myNewArray(rw - 1, 2)


End Function
0
Comment
Question by:smehle
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
4 Comments
 
LVL 93

Accepted Solution

by:
Patrick Matthews earned 1000 total points
ID: 17135286
Hi smehle,

Function createArray(cellA As Long, cellB As Long)

    Dim myArray() As Long
    Dim First As Long
    Dim Second As Long
    Dim Counter As Long

    If cellA <= cellB Then
        First = cellA
        Second = cellB
    Else
        First = cellB
        Second = cellA
    End If

    ReDim myArray(0 To First, 0 To 1) As Long

    For Counter = 0 To UBound(myArray, 1)
        myArray(Counter, 0) = First - Counter
        myArray(Counter, 1) = Second + Counter
    Next

    createArray = myArray

End Function

Regards,

Patrick
0
 

Author Comment

by:smehle
ID: 17138162
Thank you both, this was driving me NUTS!
0
 
LVL 93

Expert Comment

by:Patrick Matthews
ID: 17138247
You're welcome :)
0

Featured Post

VIDEO: THE CONCERTO CLOUD FOR HEALTHCARE

Modern healthcare requires a modern cloud. View this brief video to understand how the Concerto Cloud for Healthcare can help your organization.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Introduction While answering a recent question (http://www.experts-exchange.com/Q_27402310.html) in the VB classic zone, I wrote some VB code in the (Office) VBA environment, rather than fire up my older PC.  I didn't post completely correct code o…
Enums (shorthand for ‘enumerations’) are not often used by programmers but they can be quite valuable when they are.  What are they? An Enum is just a type of variable like a string or an Integer, but in this case one that you create that contains…
Get people started with the process of using Access VBA to control Outlook using automation, Microsoft Access can control other applications. An example is the ability to programmatically talk to Microsoft Outlook. Using automation, an Access applic…
Get people started with the process of using Access VBA to control Excel using automation, Microsoft Access can control other applications. An example is the ability to programmatically talk to Excel. Using automation, an Access application can laun…
Suggested Courses

722 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question