How to Shift an array circularly on VBA [closed]

≯℡__Kan透↙ 提交于 2019-12-08 15:40:03

问题


I have the array (1,2,3) and I would like to do a circular shift in order to obtain for example (3,1,2) or (2,3,1). In Matlab I know how to do that using the following code:

 Y = circshift(A,K)

Can u please help me with this task? I'd appreciate any sample codes...


回答1:


Code:

Private Function RotateArrayRight(ByVal ArrayToRotate As Object(), ByVal iPlacesToRotate As Integer) As Object()

        Dim objNewArray As Object()
        Dim iOldArrayPos, iNewArrayPos As Integer
        Dim iArrayLength As Integer

        ' Check that the array to be processed has been initialized
        If Not ArrayToRotate Is Nothing Then

            ' Check that the number of places to rotate is greater than zero - running the function with a value 
            ' of places to rotate whiich is less than zero would cause problems, possibly causing the function to crash
            If iPlacesToRotate > 0 Then

                ' get the length of the array to rotate, we'll be using it a few times so will
                ' load it into a local variable at the start of the function
                iArrayLength = ArrayToRotate.Length

                ' Array will be initialised from 0 to ArrayLength -1
                ' so it will contain ArrayLength elements
                ReDim objNewArray(iArrayLength - 1)

                ' This will remove any extra complete rotations through the array
                ' The mod operator returns trhe remainder of an integer divide operation
                iPlacesToRotate = iPlacesToRotate Mod iArrayLength

                ' Initialise the array position indexes
                iOldArrayPos = iPlacesToRotate
                iNewArrayPos = 0

                ' Copy objects from one array to the next
                ' First start at iPlacesToRotate into the old array
                ' and copy to the start of the new array.
                While iOldArrayPos < iArrayLength
                    objNewArray(iNewArrayPos) = ArrayToRotate(iOldArrayPos)

                    iOldArrayPos += 1
                    iNewArrayPos += 1
                End While

                iOldArrayPos = 0

                ' Copy from the start of the old array into the end of the 
                ' new array
                While iOldArrayPos < iPlacesToRotate
                    objNewArray(iNewArrayPos) = ArrayToRotate(iOldArrayPos)

                    iOldArrayPos += 1
                    iNewArrayPos += 1
                End While
            Else
                Throw New ArgumentOutOfRangeException("Values for 'Places to Rotate' must be greater than zero.")
            End If
        Else
            Throw New NullReferenceException("Cannot rotate an null array.")

        End If

        Return objNewArray

    End Function

You can use the function as Example:

Dim iInputArray() As Object
iInputArray = {4, 9, 2, 1}
Dim iArray2(), iArray3() As Object

iArray2 = RotateArrayRight(iInputArray, 2) ' Shift right two positions
iArray3 = RotateArrayRight(iInputArray, 98977) ' Shift right 98977 positions

Edit:

iOldArrayPos += 1 => iOldArrayPos = iOldArrayPos+ 1
End While => Wend
Throw => MsgBox



回答2:


Option Explicit
Option Base 1 

Sub shiftCircArray()
Dim iInputArray(3) As Integer
iInputArray(1) = 1
iInputArray(2) = 2
iInputArray(3) = 3
Dim iArray2() As Integer
iArray2 = RotateArrayRight(iInputArray)
End Sub

Function RotateArrayRight(ArrayToRotate)
Dim objNewArray() As Integer, iOldArrayPos As Integer, iNewArrayPos As Integer, iArrayLength     
As Integer
Dim iPlacesToRotate As Integer
' Check that the array to be processed has been initialized
iPlacesToRotate = Application.CountA(ArrayToRotate)
If iPlacesToRotate <> 0 Then 
    ' Check that the number of places to rotate is greater than zero - running the
    ' function with a value
    ' of places to rotate which is less than zero would cause problems, possibly causing            
    'the function to crash
    If iPlacesToRotate > 0 Then
        ' get the length of the array to rotate, we'll be using it a few times so will
        ' load it into a local variable at the start of the function
        iArrayLength = Application.CountA(ArrayToRotate)
        ' Array will be initialised from 0 to ArrayLength -1
        ' so it will contain ArrayLength elements
        ReDim objNewArray(iArrayLength)
        ' This will remove any extra complete rotations through the array
        ' The mod operator returns the remainder of an integer divide operation
        ' Initialise the array position indexes
        iOldArrayPos = iPlacesToRotate
        iNewArrayPos = 1
        ' Copy objects from one array to the next
        ' First start at iPlacesToRotate into the old array
        ' and copy to the start of the new array.
        While iOldArrayPos < iArrayLength + 1
            objNewArray(iNewArrayPos) = ArrayToRotate(iOldArrayPos)
            iOldArrayPos = iOldArrayPos + 1
            iNewArrayPos = iNewArrayPos + 1
        Wend
            iOldArrayPos = 1
            ' Copy from the start of the old array into the end of the
            ' new array
        While iOldArrayPos < iPlacesToRotate
            objNewArray(iNewArrayPos) = ArrayToRotate(iOldArrayPos)
            iOldArrayPos = iOldArrayPos + 1
            iNewArrayPos = iNewArrayPos + 1
        Wend
    Else
    MsgBox ("Values for 'Places to Rotate' must be greater than zero.")
    End If
Else
MsgBox ("Cannot rotate an null array.")
End If
RotateArrayRight = objNewArray()
End Function


来源:https://stackoverflow.com/questions/25075742/how-to-shift-an-array-circularly-on-vba

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!