java中Set,Map,Stack一些简单用法

简介: 1 import java.util.Iterator; 2 import java.util.Stack; 3 import java.io.*; 4 import java.util.
 1 import java.util.Iterator;
 2 import java.util.Stack;
 3 import java.io.*;
 4 import java.util.Set;
 5 import java.util.Map;
 6 import java.util.HashMap;
 7 import java.util.TreeSet;
 8 public class StackUsing{
 9    public static void main(String args[]) throws IOException{
10       Stack<Integer> s = new Stack<Integer>();
11       int i;
12       for(i=0; i<10; ++i)
13          s.push(i); 
14    
15       //it.hasNext()如果还有元素可以继续进行迭代,返回true! it.next()返回当前迭代器所指向的元素,并指向下一个迭代的对象
16       for(Iterator<Integer>it = s.iterator(); it.hasNext(); ){//从栈底开始打印
17          System.out.println(it.next());
18       }
19    
20       for(Integer k:s){
21            System.out.println(k);
22       }
23     
24       while(!s.empty()){//从栈顶开始打印
25          System.out.println(s.pop());
26       }
27 
28      Set<Integer> st = new TreeSet<Integer>();
29      for(i=0; i<10; ++i)
30         st.add(i);
31      for(Integer k: st){//可以这样遍历一个集合对象
32         System.out.println(k);
33      }
34      
35      for(Iterator<Integer>it = st.iterator(); it.hasNext(); ){//也可以这样遍历一个集合对象
36          System.out.println(it.next());
37      }
38 
39      Set<myInteger> stp = new TreeSet<myInteger>();//实验一下自己定义的类的集合
40      for(i=0; i<10; ++i)
41        stp.add(new myInteger(i, i*2)); 
42     
43      for(myInteger x:stp){
44         System.out.println(x.first + " " + x.second);
45      }
46 
47      Map<String, Integer>mp = new HashMap<String, Integer>();
48      String str;
49      BufferedReader myInput = new BufferedReader(new InputStreamReader(System.in));
50 
51      str=myInput.readLine();
52      while(str.compareTo("#")!=0){
53          Integer cnt=mp.get(str);
54          if(cnt==null)
55             cnt=new Integer(0);
56          ++cnt;
57          mp.put(str, cnt);
58          str=myInput.readLine();
59      }
60      
61      ///3种遍历Map的方式
62      for(String ss : mp.keySet()){
63         System.out.println(ss + " " + mp.get(ss));
64      }
65      System.out.println("**********************");
66      
67      //静态内部类是属于类的,不是属于某一个实例的;静态内部类随着类加载而加载,非静态内部类是随着实例的加载而加载
68      for(Map.Entry<String, Integer>entry : mp.entrySet()){//返回此映射中包含的映射关系的 set 视图。返回的 set 中的每个元素都是一个 Map.Entry
69         System.out.println(entry.getKey() + " " + entry.getValue());
70      }
71      System.out.println("**********************");
72 
73      for(Iterator<Map.Entry<String, Integer> > it = mp.entrySet().iterator(); it.hasNext(); ){
74          Map.Entry<String, Integer>entry=it.next();
75          System.out.println(entry.getKey() + " " + entry.getValue());
76      }
77    }
78 }
79 
80 class myInteger implements Comparable{
81     int first;
82     int second;
83     public myInteger(int a, int b){
84          first=a;
85          second=b;
86     }
87     public myInteger(){
88         first=0;
89         second=0;
90     }
91     public int compareTo(Object x){
92         if(first>((myInteger)x).first) return -1;//在这里实现的是从大到小排序
93         else if(first==((myInteger)x).first) return 0;
94         else return 1;
95     }
96 }

 

目录
相关文章
|
4天前
|
存储 算法 Java
Java Set深度解析:为何它能成为“无重复”的代名词?
Java的集合框架中,Set接口以其“无重复”特性著称。本文解析了Set的实现原理,包括HashSet和TreeSet的不同数据结构和算法,以及如何通过示例代码实现最佳实践。选择合适的Set实现类和正确实现自定义对象的hashCode()和equals()方法是关键。
15 4
|
4天前
|
Java
那些与Java Set擦肩而过的重复元素,都经历了什么?
在Java的世界里,Set如同一位浪漫而坚定的恋人,只对独一无二的元素情有独钟。重复元素虽屡遭拒绝,但通过反思和成长,最终变得独特,赢得了Set的认可。示例代码展示了这一过程,揭示了成长与独特性的浪漫故事。
13 4
|
4天前
|
Java 开发者
Java Set:当“重复”遇见它,秒变“独宠”!
在Java编程中,Set接口确保集合中的元素不重复,每个元素都是独一无二的“独宠”。本文介绍了Set的两种常见实现:HashSet和TreeSet。HashSet基于哈希表实现,提供高效的添加、删除和查找操作;TreeSet基于红黑树实现,不仅去重还能对元素进行排序。通过示例代码,展示了这两种集合的具体应用,帮助开发者更好地理解和使用Set。
12 4
|
11天前
|
存储 Java
判断一个元素是否在 Java 中的 Set 集合中
【10月更文挑战第30天】使用`contains()`方法可以方便快捷地判断一个元素是否在Java中的`Set`集合中,但对于自定义对象,需要注意重写`equals()`方法以确保正确的判断结果,同时根据具体的性能需求选择合适的`Set`实现类。
|
11天前
|
存储 Java 开发者
Java 中 Set 类型的使用方法
【10月更文挑战第30天】Java中的`Set`类型提供了丰富的操作方法来处理不重复的元素集合,开发者可以根据具体的需求选择合适的`Set`实现类,并灵活运用各种方法来实现对集合的操作和处理。
|
9天前
|
存储 Java 开发者
Java Set:无序之美,不重复之魅!
在Java的集合框架中,Set接口以其“无序之美”和“不重复之魅”受到开发者青睐。Set不包含重复元素,不保证元素顺序,通过元素的hashCode()和equals()方法实现唯一性。示例代码展示了如何使用HashSet添加和遍历元素,体现了Set的高效性和简洁性。
21 4
|
9天前
|
存储 算法 Java
为什么Java Set如此“挑剔”,连重复元素都容不下?
在Java的集合框架中,Set是一个独特的接口,它严格要求元素不重复,适用于需要唯一性约束的场景。Set通过内部数据结构(如哈希表或红黑树)和算法(如哈希值和equals()方法)实现这一特性,自动过滤重复元素,简化处理逻辑。示例代码展示了Set如何自动忽略重复元素。
18 1
|
9天前
|
存储 算法 Java
Java中的Set,你真的了解它的“无重复”奥秘吗?
在Java的广阔天地里,Set以其独特的“无重复”特性,在众多数据结构中脱颖而出。本文将揭秘Set的“无重复”奥秘,带你领略其魅力。Set通过哈希算法和equals()方法协同工作,确保元素不重复。通过一个简单的案例,我们将展示HashSet如何实现这一特性。
20 1
|
11天前
|
存储 Java 开发者
在 Java 中,如何遍历一个 Set 集合?
【10月更文挑战第30天】开发者可以根据具体的需求和代码风格选择合适的遍历方式。增强for循环简洁直观,适用于大多数简单的遍历场景;迭代器则更加灵活,可在遍历过程中进行更多复杂的操作;而Lambda表达式和`forEach`方法则提供了一种更简洁的函数式编程风格的遍历方式。
|
11天前
|
Java 开发者