如何用字典或数组求最大值和最小值?
时间:2011-08-10
来源:互联网
请坛里的高人看看,如何用字典或数组求最大值和最小值?示例见附件。
最大值最小值.rar(8.12 KB)
附件

2011-8-10 23:44, 下载次数: 4
作者: mjzxlmg 发布时间: 2011-08-10
复制内容到剪贴板
Dim d As Object, r, i%, k%
Set d = CreateObject("Scripting.Dictionary")
r = Range("a2:b" & [a65536].End(3).Row)
For i = 1 To UBound(r)
If Not d.exists(r(i, 1)) Then
If r(i, 2) <> "" Then d(r(i, 1)) = r(i, 2)
Else
If r(i, 2) > d(r(i, 1)) Then d(r(i, 1)) = r(i, 2)
End If
Next
[d2].Resize(d.Count, 1) = Application.Transpose(d.keys)
[e2].Resize(d.Count, 1) = Application.Transpose(d.items)
For i = 1 To UBound(r)
If d.exists(r(i, 1)) Then
If r(i, 2) <> "" And r(i, 2) < d(r(i, 1)) Then d(r(i, 1)) = r(i, 2)
End If
Next
[f2].Resize(d.Count, 1) = Application.Transpose(d.items)
Set d = Nothing
End Sub
[ 本帖最后由 白云2011 于 2011-8-11 01:21 编辑 ]
代码:
Sub yy()Dim d As Object, r, i%, k%
Set d = CreateObject("Scripting.Dictionary")
r = Range("a2:b" & [a65536].End(3).Row)
For i = 1 To UBound(r)
If Not d.exists(r(i, 1)) Then
If r(i, 2) <> "" Then d(r(i, 1)) = r(i, 2)
Else
If r(i, 2) > d(r(i, 1)) Then d(r(i, 1)) = r(i, 2)
End If
Next
[d2].Resize(d.Count, 1) = Application.Transpose(d.keys)
[e2].Resize(d.Count, 1) = Application.Transpose(d.items)
For i = 1 To UBound(r)
If d.exists(r(i, 1)) Then
If r(i, 2) <> "" And r(i, 2) < d(r(i, 1)) Then d(r(i, 1)) = r(i, 2)
End If
Next
[f2].Resize(d.Count, 1) = Application.Transpose(d.items)
Set d = Nothing
End Sub
附件

2011-8-11 01:21, 下载次数: 0
作者: 白云2011 发布时间: 2011-08-11
虽然没做好,还是谢谢这么晚了还帮忙。
作者: mjzxlmg 发布时间: 2011-08-11
请测试,改了简单思路

作者: 白云2011 发布时间: 2011-08-11
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28