ExcelTip.Net留存知识帖 ---【注:附件之前被网盘供应商清空后,现已修复-现已修复-现已修复为本地下载!】
现在位置:首页 > E问E答 > Excel VBA > 如何返回落号重新组合三位数中出现次数前三的号码?

如何返回落号重新组合三位数中出现次数前三的号码?

作者:绿色风 分类: 时间:2022-08-17 浏览:137
楼主
liuguansky
Q:[彩票]如何返回落号重新组合三位数中出现次数前三的号码?
A:用如下代码可以实现:

  1. Sub juesttest()
  2.     Dim arr, i%, j%, str1$, dic, k%, arrt(), m%, n%, str2$, d, arrs, arrre1(), arrre2(), arrre3(), s1%, s2%, s3%
  3.     Set dic = CreateObject("scripting.dictionary")
  4.     arr = [d475:M541]
  5.     For i = 1 To UBound(arr, 1) - 1
  6.         str1 = ""
  7.         For j = 1 To UBound(arr, 2)
  8.             If arr(i, j) = arr(i + 1, j) Then
  9.                 str1 = str1 & arr(i, j)
  10.             End If
  11.         Next j
  12.         k = 0
  13.         For j = 1 To 9
  14.             If InStr(1, str1, j) > 0 Then
  15.                 k = k + 1
  16.                 ReDim Preserve arrt(1 To k)
  17.                 arrt(k) = j
  18.             End If
  19.         Next j
  20.         If k >= 3 Then
  21.             For j = 1 To k - 2
  22.                 For m = j + 1 To k - 1
  23.                     For n = m + 1 To k
  24.                         str2 = j & m & n
  25.                         If dic.exists(str2) Then
  26.                             dic(str2) = dic(str2) + 1
  27.                             Else: dic.Add str2, 1
  28.                         End If
  29.             Next n, m, j
  30.         End If
  31.     Next i
  32.     If dic.Count > 0 Then
  33.         s = 0
  34.         arrs = dic.items
  35.         For Each d In dic.keys
  36.             Select Case dic(d)
  37.                 Case Application.Large(arrs, 1)
  38.                     s1 = s1 + 1
  39.                     ReDim Preserve arrre1(1 To s1)
  40.                     arrre1(s1) = d
  41.                 Case Application.Large(arrs, 2)
  42.                     s2 = s2 + 1
  43.                     ReDim Preserve arrre2(1 To s2)
  44.                     arrre2(s2) = d
  45.                 Case Application.Large(arrs, 3)
  46.                     s3 = s3 + 1
  47.                     ReDim Preserve arrre3(1 To s3)
  48.                     arrre3(s3) = d
  49.                 Case Else
  50.             End Select
  51.         Next d
  52.         MsgBox "落号组合第一的三位数是" & Join(arrre1, ",") & vbCrLf & _
  53.             "落号组合第二的三位数是" & Join(arrre2, ",") & vbCrLf & _
  54.              "落号组合第三的三位数是" & Join(arrre3, ",")
  55.         Else: MsgBox "未有落号产生"
  56.     End If
  57.     Set dic = Nothing
  58. End Sub
2楼
い卋玑┾宝珼
谢谢分享

免责声明

有感于原ExcelTip.Net留存知识的价值及部分知识具有的时间限定性因素, 经与ExcelTip.Net站长Apolloh商议并征得其同意, 现将原属ExcelTip.Net的知识帖采集资料于本站点进行展示, 供有需要的人士查询使用,也慰缅曾经的论坛时代。 所示各个帖子的原作者如对版权有异议, 可与本人沟通提出,或于本站点留言,我们会尽快处理。 在此,感谢ExcelTip.Net站长Apolloh的支持,感谢本站点所有人**绿色风(QQ:79664738)**的支持与奉献,特此鸣谢!
------本人网名**KevinChengCW(QQ:1210618015)**原ExcelTip.Net总版主之一

评论列表
sitemap