package com.study.login;
import java.util.ArrayList;
import java.util.List;
import java.util.Hashtable;
/**
* Test demo
*
* @author wangjie
*
*/
public class Test {
public static void main(String[] args) {
int inputGroup = 4; // 输入分的组数
float[] importNumber = new float[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }; // 排序后的数组
float[] group = new float[inputGroup]; //声明一个长度为输入长度的数组作为一个number标识
float number = (importNumber[importNumber.length - 1] - importNumber[0])
/ inputGroup; // 最大值与最小值的差除以输入的组数
for (int i = 0; i < inputGroup; i++) { // 为数组group的每个元素赋值
group[i] = (importNumber[0] + number * i); // 值为输入数组中最小值的元素与number与i的积的和
}
// 声明一个hastable,key为Float类型,value为一个Float类型的集合
Hashtable> hastable = new Hashtable>();
// 用来存放大于group数组中最大数的集合
List maxNumList = new ArrayList();
for (float num : importNumber) { // 循环遍历经过排序后的数组
for (int j = 0; j < group.length; j++) { // 循环遍历group数组
if (j == group.length - 1) {
// 大于group数组中最大数的元素先放到maxNumList中
if (num > group[group.length - 1]) {
maxNumList.add(num);
// 再把maxNumList存放到hastable中
hastable.put(group[j], maxNumList);
break;
}
} else {
// 以group中相邻两个元素为区间将importNumber数组中的元素进行分组
if (num >= group[j] && num <= group[j + 1]) {
// 如果存在则直接存放到刚声明的数组中
if (hastable.get(group[j]) != null) {
hastable.get(group[j]).add(num);
break;
} else {
// 如果hastable中不存在以group数组中的元素为key,则要声明
List fList = new ArrayList();
fList.add(num);
hastable.put(new Float(group[j]), fList);
break;
}
}
}
}
}
// 循环输出经过分组后的各个组中的元素
for (int i = 0; i < hastable.size(); i++) {
System.out.println("第"+(i+1)+"组包括:");
List list = hastable.get(group[i]);
for (int j = 0; j < list.size(); j++) {
System.out.println(list.get(j));
}
}
}
}
程序运行结果:
第1组包括:
1.0
2.0
3.0
第2组包括:
4.0
5.0
第3组包括:
6.0
7.0
第4组包括:
8.0
9.0
10.0
注:以上程序用的是java语言,你需要用.net语言进行改写,inputGroup是你在窗体上输入的组数,importNumber是排序后的数组,每一步骤的操作 我都写了注释,希望你的程序也能遵循编码的规范,有什么不明白的地方再问我,好好努力吧!