[Java]刷题中的Java基础

数组

  • 取数组长度是属性length
  • 排序 Arrays.sort(arr,1,n+1);
  • 数组的拷贝
 int a[] = {4, 3, 6, 5, 1, 2};
 9         int b[] = Arrays.copyOf(a, 4);
10         int c[] = Arrays.copyOfRange(a, 2, 4 + 1);
  • 初始化为同一值,以二维数组为例:
int[][] dp=new int[cntLong+1][cntShort+1];//
		for(int i=0;i<=cntLong;++i) {//
			Arrays.fill(dp[i], Integer.MAX_VALUE);//
		}

ArrayList

ArrayList<Integer> maxRootHeap = new ArrayList<Integer>();
maxRootHeap.add(input[i]);
maxRootHeap.get(0);
maxRootHeap.set(0, input[i]);
maxRootHeap.size()
arraylist.remove(idx)

LinkedList

只有LinkedList实现了removeLast()接口,所以使用该接口,则声明集合的时候要直接为LinkedList 而不是 List
在list的首部插入元素:ansList.add(0,list);

Queue

Queue是一个接口。
Queue<Integer> rQ=new LinkedList<>();

Stack

s.push()
s.pop()
s.peek()

由于Stack继承Vector数组,而不是链表实现,有时需要扩容,所以效率低,推荐使用实现了Deque接口的LinkedList,Deque接口为双端队列,保留了pop()和push方法。

Deque<Character> stack=new LinkedList<>();
stack.push('a');
stack.pop

HashSet

HashSet<Integer> set =new HashSet<Integer>();
set.contains(elm);
set.add(elm);

HashMap

map value累加:map.put(subStr,map.getOrDefault(subStr,0)+1);
遍历mapfor(String str: map.keySet()){}

String与char[]

String

str1.charAt(pos)
遍历String的元素也可以先转成字符数组 :str1.toCharArray()
str1.trim().toCharArray()
s2.substring(begPos,endPos);
s2.length();
String[] strs=s1.split("\\.");
String转int:
Integer num=Integer.valueOf(s1);
int num=Integer.parseInt(s1);

indexOf作用:用于检索一个字符串在另一个字符串中的位置。

indexOf的几个重载方法如下:

int indexOf(String str)  意思为在字符串中检索str第一次出现的位置,如果找不到返回-1。

       eg: String str = "I can because i think i can";

                int index = str.indexOf("can");

                System.out.println(index); // 2  从0开始,空格也算一位

int indexOf(String str,int fromIndex) 意思为  从字符串的fromIndex位置开始检索。

 eg: String str = "I can because i think i can";           

          index = str.indexOf("can", 6);

          System.out.println(index); // 24
char[]

char[] subStr=new char[subStrLen];

将 char 变量 c 转换成字符串

String.valueOf(char c) :

对象相等比较

要用obj1.equals(obj2),而不能用====比较的是对象地址。

输入

Scanner in=new Scanner(System.in);
		while(in.hasNext()) {
			int N=in.nextInt();
                }

取最小值

public static int getMin(int... vals) {
        int min=Integer.MAX_VALUE;
        for(int val:vals) {
            if(val<min) {
                min=val;
            }
        }
        return min;
    }

Java.lang包

取两数较小值 min=Math.min(min,arr[i]);

排序

数组排序Arrays.sort(arr);
Collections.sort(list, new Comparator<Student>(){  

            /*  
             * int compare(Student o1, Student o2) 返回一个基本类型的整型,  
             * 返回负数表示:o1 小于o2,  
             * 返回0 表示:o1和o2相等,  
             * 返回正数表示:o1大于o2。  
             */  
            public int compare(Student o1, Student o2) {  

                //按照学生的年龄进行升序排列  
                if(o1.getAge() > o2.getAge()){  
                    return 1;  
                }  
                if(o1.getAge() == o2.getAge()){  
                    return 0;  
                }  
                return -1;  
            }  
        });   
        System.out.println("排序后:"+list);  
    }  
}  

StringBuilder

有大量的字符拼接等操作用StringBuilder
https://baijiahao.baidu.com/s?id=1629804867201303563&wfr=spider&for=pc
StringBuilder是一个类,可以用来处理字符串,最简单的用法:

StringBuilder sb=new StringBuilder();
sb.append("123");
sb.append("456");
string str=sb.toString();

String

str.substring(i, j);

关于new数组

Java与C++中创建数组

JAVA 里面的数组名是一个引用变量,引用变量是放在是放在一个栈里面,而JAVA数组本身就是对象,Java中对象是在堆中的,因此数组无论保存原始类型还是其他对象类型,数组对象本身是在堆中的。所以如果不new一下,就无法得到这个数组,即引用变量没有引用的对象。而在C++中,数组名实际上是数组的首地址,是一个指针,数组在声明之后就已经生成了这个数组对象。就不用new了

Java中new String类型与数组类型

不同于String类,String由于实现了常量池 所以new 和不new 有区别:new的话,引用变量指向堆区。不new的话,引用变量指向常量池。
对于数组的定义,初始化时用new与不用new 没区别,只是两种方式罢了,因为数组是引用数据类型,建立对象时,无论用不用new,数组实体都是放在堆内存中,引用变量放在栈内存。

posted on 2019-04-07 21:35  coding_gaga  阅读(1175)  评论(0编辑  收藏  举报

导航