需要一个excel的函数,求一个整数的所有素因子的乘积

没学过vba语言,不太清楚怎么弄,参数就是一个整数,然后给出他的根数
例如12=223,那么radical(12)=23=6
16=2
222,radical(16)=2
现在要做excel中用,,就酱
matlab的函数也需要,要求一样,就是要一个这样的函数

追加:
今早看了以下稍微写了一点东西,但是写出来是错的,还请大家帮忙看下错在哪
还有由于准备要算的数据有的多,这个写的很粗糙,希望能优化一下节省算力

Public Function radical(abc As Double)
Dim x As Long
x = 1
For i = 2 To abc
If prime(abc) = 1 And abc Mod i = 0 Then x = x * i
Next
radical = x
End Function

Public Function prime(num)
For i = 2 To num
If num Mod i = 0 Then
prime = 0
Exit For
Else: If i = num Then prime = 1
End If
Next
End Function


Imports System

Module Module1
    Public Function Radical(abc As Long) As Long
        Dim x As Long
        Dim i As Long
        x = 1
        For i = 2 To abc
            'Console.WriteLine("i is : {0}", i)
            If (abc Mod i = 0) AndAlso (IsPrime(i) = True) Then
                x = x * i
                'Console.WriteLine("x is : {0}", x)
            End If
        Next
        return x
    End Function

    Public Function IsPrime(num As Long) As Boolean
        'Console.WriteLine("num is : {0}", num)
        Dim i As Long
        Dim flag As Boolean
        flag = True
        For i = 2 To Math.Sqrt(num)
            If num Mod i = 0 Then
                flag = False
                Exit For
            End If
        Next
        'Console.WriteLine("flag is : {0}", flag)
        return flag
    End Function

    Sub Main()
        Console.WriteLine("Radical of 12 is : {0}", Radical(90))
    End Sub
   
End Module

两个地方可以减少计算量:
判断num是不是质数的时候,只需要测试从2到Math.Sqrt(num)的所有整数。
判断i是不是abc的质因数的时候,采用AndAlso实现短路代码,只有i是因数的时候才判断是否为质数。

您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632