`
junzai
  • 浏览: 15291 次
  • 性别: Icon_minigender_2
社区版块
存档分类
最新评论

集合框架的练习

阅读更多
1.给定任意int一维数组
  a.去掉数组中的重复元素
  b.给数组排序

思路1:因为HashSet集合中的元素不允许重复,所以可以将得到的任意数组放进
Hsahset中,再把HashSet中的元素放到一个新建的数组中,对数组进行冒泡排序(当然其他排序也可以),这样就可以得到我们所需要的结果。

思路1优化:将数组放进TreeSet(TreeSet可以自然排序),于是就可以省去冒泡排序这一步。



2.给定任意字符串String str = "sadsadljsaljdlsajdlsajdlsajd";
  统计字符串中每个字符出现的次数

思路1:因为HashMap中的K是不能Set类型的,不能重复,V是可以重复的。所以我们可以将字符作为K,次数作为V,字符和数组的键值形成映射。取出字符串中的每一个字符。然后判断map中是否出现过这个字符。将字符和次数分别放入map中。

优化思路:利用三目运算符来判断

代码如下:

import java.util.HashMap;
import java.util.HashSet;
import java.util.Set;
import java.util.TreeSet;

public class Test {

public static void main(String args[]) {
                  //定义任一数组
int array[] = { 3, 5, 4, 2, 1, 2, 3, 4, 1 };

Test t = new Test();
                  //调用方法,返回数组类型的值
int[] arr = t.paixu2(array);
//加强for循环的遍历
for (int num : arr) {
System.out.print(num + "\t");
}
                  //定义任一字符串
String str = "abbcccddddeeeeeffffff";
                  //调用方法,返回值类型
HashMap<Character, Integer> map = t.count(str);
                  //HashSet的遍历一定要会
Set<Character> set = map.keySet();
for (char c : set) {
                           //得到次数
int count = map.get(c);
System.out.println(c + "出现次数:" + count);
}

}

/**
* 对传入的数组去掉重复元素,并且排序 HashSet是不允许存在重复元素的
*
* @param array
*            要处理的数组
* @return 返回去掉重复排好序之后的数组
*/
public int[] paixu(int[] array) {
HashSet<Integer> set = new HashSet<Integer>();
for (int i = 0; i < array.length; i++) {
set.add(array[i]);
}
// 定义新数组,长度就是set中的元素个数
int[] arr = new int[set.size()];
int k = 0;
for (int num : set) {
arr[k] = num;
k++;
}

// 冒泡排序
for (int i = 0; i < arr.length; i++) {
for (int j = i + 1; j < arr.length; j++) {
if (arr[i] > arr[j]) {
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}

}

}

return arr;
}
         //排序
public int[] paixu2(int[] array) {

TreeSet<Integer> set = new TreeSet<Integer>();
for (int i = 0; i < array.length; i++) {
set.add(array[i]);
}
// 定义新数组,长度就是set中的元素个数
int[] arr = new int[set.size()];
int k = 0;
for (int num : set) {
arr[k] = num;
k++;
}
return arr;
}

/**
* 统计指定字符串中每个字符出现的次数
*
* @param str
*            要统计的字符串
* @return 返回 字符-->次数的键值对 映射
*/
public HashMap<Character, Integer> count(String str) {

HashMap<Character, Integer> map = new HashMap<Character, Integer>();

// 遍历字符串,取出字符
for (int i = 0; i < str.length(); i++) {
                           //得到字符串中的每个字符
char c = str.charAt(i);
Integer num = map.get(c);

// //如果map中出现过这个字符,表示该字符已经在前面被统计过了
// if(map.containsKey(c)){
// int count = map.get(c);
// count++;
// map.put(c, count);
// }else{
// //如果没有出现,表示是第一次统计到
// map.put(c, 1);
// }
                         
                           //方法二
num = null == num ? 1 : ++num;
map.put(c, num);

}
return map;
}

}
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics