1. list中添加,获取,删除元素;
  2. list中是否包含某个元素;
  3. list中根据索引将元素数值改变(替换);
  4. list中查看(判断)元素的索引;
  5. 根据元素索引位置进行的判断;
  6. 利用list中索引位置重新生成一个新的list(截取集合);
  7. 对比两个list中的所有元素;
  8. 判断list是否为空;
  9. 返回Iterator集合对象;
  10. 将集合转换为字符串;
  11. 将集合转换为数组;
  12. 集合类型转换;

转载自http://hovertree.com/h/bjaf/pk4rwg78.htm

1.list中添加,获取,删除元素;

添加方法是:.add(e);  

获取方法是:.get(index);  

删除方法是:

.remove(index);按照索引删除;

.remove(Object o); 按照元素内容删除;

List<String> person=new ArrayList<>();person.add("jackie");    //索引为0  //.add(e)person.add("peter"); //索引为1person.add("annie");    //索引为2person.add("martin");   //索引为3person.add("marry");    //索引为4person.remove(3); //.remove(index)person.remove("marry");       //.remove(Object o)String per="";per=person.get(1);System.out.println(per);     .get(index)for (int i = 0; i < person.size(); i++) {System.out.println(person.get(i));    //.get(index)}

2.list中是否包含某个元素;

  方法:.contains(Object o); 返回true或者false

List<String> fruits=new ArrayList<>();fruits.add("苹果");fruits.add("香蕉");fruits.add("桃子");//for循环遍历listfor (int i = 0; i < fruits.size(); i++) {System.out.println(fruits.get(i));}String appleString="苹果";//true or falseSystem.out.println("fruits中是否包含苹果:"+fruits.contains(appleString));if (fruits.contains(appleString)) {System.out.println("我喜欢吃苹果");}else {System.out.println("我不开心");}

3.list中根据索引将元素数值改变(替换);

  注意 .set(index, element); 和 .add(index, element); 的不同;

String a="白龙马", b="沙和尚", c="八戒", d="唐僧", e="悟空";List<String> people=new ArrayList<>();people.add(a);people.add(b);people.add(c);people.set(0, d);   //.set(index, element);     //将d唐僧放到list中索引为0的位置,替换a白龙马people.add(1, e); //.add(index, element);     //将e悟空放到list中索引为1的位置,原来位置的b沙和尚后移一位//增强for循环遍历listfor(String str:people){System.out.println(str);}

4.list中查看(判断)元素的索引;  

  注意:.indexOf(); 和  lastIndexOf()的不同;

List<String> names=new ArrayList<>();names.add("刘备");    //索引为0names.add("关羽");    //索引为1names.add("张飞");    //索引为2names.add("刘备");    //索引为3names.add("张飞");    //索引为4System.out.println(names.indexOf("刘备"));System.out.println(names.lastIndexOf("刘备"));System.out.println(names.indexOf("张飞"));System.out.println(names.lastIndexOf("张飞"));

5.根据元素索引位置进行的判断;

if (names.indexOf("刘备")==0) {System.out.println("刘备在这里");
}else if (names.lastIndexOf("刘备")==3) {System.out.println("刘备在那里");
}else {System.out.println("刘备到底在哪里?");
}

6.利用list中索引位置重新生成一个新的list(截取集合);

  方法: .subList(fromIndex, toIndex);  .size() ; 该方法得到list中的元素数的和

List<String> phone=new ArrayList<>();phone.add("三星");   //索引为0phone.add("苹果");    //索引为1phone.add("锤子");    //索引为2phone.add("华为");    //索引为3phone.add("小米");    //索引为4//原list进行遍历for(String pho:phone){System.out.println(pho);}//生成新listphone=phone.subList(1, 4);    //.subList(fromIndex, toIndex)      //利用索引1-4的对象重新生成一个list,但是不包含索引为4的元素,4-1=3for (int i = 0; i < phone.size(); i++) {  // phone.size() 该方法得到list中的元素数的和 System.out.println("新的list包含的元素是"+phone.get(i));}

7.对比两个list中的所有元素;

  //两个相等对象的equals方法一定为true, 但两个hashcode相等的对象不一定是相等的对象

//1.if (person.equals(fruits)) {System.out.println("两个list中的所有元素相同");
}else {System.out.println("两个list中的所有元素不一样");
}
//2.
if (person.hashCode()==fruits.hashCode()) {System.out.println("我们相同");
}else {System.out.println("我们不一样");
}

8.判断list是否为空;

  //空则返回true,非空则返回false

if (person.isEmpty()) {System.out.println("空的");
}else {System.out.println("不是空的");
}

9.返回Iterator集合对象;

System.out.println("返回Iterator集合对象:"+person.iterator());

1+0.将集合转换为字符串;

String liString="";
liString=person.toString();
System.out.println("将集合转换为字符串:"+liString);

11.将集合转换为数组;

System.out.println("将集合转换为数组:"+person.toArray());

12.集合类型转换;

//1.默认类型
List<Object> listsStrings=new ArrayList<>();for (int i = 0; i < person.size(); i++) {listsStrings.add(person.get(i));
}
//2.指定类型
List<StringBuffer> lst=new ArrayList<>();for(String string:person){lst.add(StringBuffer(string));
}

附完整代码:

package MyTest01;import java.util.ArrayList;
import java.util.List;public class ListTest01 {public static void main(String[] args) {//list中添加,获取,删除元素List<String> person=new ArrayList<>();person.add("jackie");    //索引为0  //.add(e)person.add("peter"); //索引为1person.add("annie");    //索引为2person.add("martin");   //索引为3person.add("marry");    //索引为4person.remove(3); //.remove(index)person.remove("marry");       //.remove(Object o)String per="";per=person.get(1);System.out.println(per);     .get(index)for (int i = 0; i < person.size(); i++) {System.out.println(person.get(i));    //.get(index)}//list总是否包含某个元素List<String> fruits=new ArrayList<>();fruits.add("苹果");fruits.add("香蕉");fruits.add("桃子");//for循环遍历listfor (int i = 0; i < fruits.size(); i++) {System.out.println(fruits.get(i));}String appleString="苹果";//true or falseSystem.out.println("fruits中是否包含苹果:"+fruits.contains(appleString));if (fruits.contains(appleString)) {System.out.println("我喜欢吃苹果");}else {System.out.println("我不开心");}//list中根据索引将元素数值改变(替换)String a="白龙马", b="沙和尚", c="八戒", d="唐僧", e="悟空";List<String> people=new ArrayList<>();people.add(a);people.add(b);people.add(c);people.set(0, d);    //.set(index, element)      //将d唐僧放到list中索引为0的位置,替换a白龙马people.add(1, e); //.add(index, element);     //将e悟空放到list中索引为1的位置,原来位置的b沙和尚后移一位//增强for循环遍历listfor(String str:people){System.out.println(str);}//list中查看(判断)元素的索引List<String> names=new ArrayList<>();names.add("刘备");   //索引为0names.add("关羽");    //索引为1names.add("张飞");    //索引为2names.add("刘备");    //索引为3names.add("张飞");    //索引为4System.out.println(names.indexOf("刘备"));System.out.println(names.lastIndexOf("刘备"));System.out.println(names.indexOf("张飞"));System.out.println(names.lastIndexOf("张飞"));//根据元素索引位置进行的判断if (names.indexOf("刘备")==0) {System.out.println("刘备在这里");}else if (names.lastIndexOf("刘备")==3) {System.out.println("刘备在那里");}else {System.out.println("刘备到底在哪里?");}//利用list中索引位置重新生成一个新的list(截取集合)List<String> phone=new ArrayList<>();phone.add("三星");  //索引为0phone.add("苹果");    //索引为1phone.add("锤子");    //索引为2phone.add("华为");    //索引为3phone.add("小米");    //索引为4//原list进行遍历for(String pho:phone){System.out.println(pho);}//生成新listphone=phone.subList(1, 4);    //.subList(fromIndex, toIndex)      //利用索引1-4的对象重新生成一个list,但是不包含索引为4的元素,4-1=3for (int i = 0; i < phone.size(); i++) {  // phone.size() 该方法得到list中的元素数的和 System.out.println("新的list包含的元素是"+phone.get(i));}//对比两个list中的所有元素//两个相等对象的equals方法一定为true, 但两个hashcode相等的对象不一定是相等的对象if (person.equals(fruits)) {System.out.println("两个list中的所有元素相同");}else {System.out.println("两个list中的所有元素不一样");}if (person.hashCode()==fruits.hashCode()) {System.out.println("我们相同");}else {System.out.println("我们不一样");}//判断list是否为空//空则返回true,非空则返回falseif (person.isEmpty()) {System.out.println("空的");}else {System.out.println("不是空的");}//返回Iterator集合对象System.out.println("返回Iterator集合对象:"+person.iterator());//将集合转换为字符串String liString="";liString=person.toString();System.out.println("将集合转换为字符串:"+liString);//将集合转换为数组,默认类型System.out.println("将集合转换为数组:"+person.toArray());将集合转换为指定类型(友好的处理)//1.默认类型List<Object> listsStrings=new ArrayList<>();for (int i = 0; i < person.size(); i++) {listsStrings.add(person.get(i));}//2.指定类型List<StringBuffer> lst=new ArrayList<>();for(String string:person){lst.add(StringBuffer(string));}}private static StringBuffer StringBuffer(String string) {return null;}}

转载于:https://www.cnblogs.com/SkyeAngel/p/9308715.html

ArrayList刷题总结相关推荐

  1. 牛客网Java刷题知识点之ArrayList 、LinkedList 、Vector 的底层实现和区别

    不多说,直接上干货! 这篇我是从整体出发去写的. 牛客网Java刷题知识点之Java 集合框架的构成.集合框架中的迭代器Iterator.集合框架中的集合接口Collection(List和Set). ...

  2. LeetCode刷题感想

    断断续续用了半年的时间把LeetCode刷完了,之前复习了数据结构与算法.将刷题与复习数据结构结合起来会更有效果.总之不是为了刷题而刷题,而是为了巩固和补充一部分知识. LeetCode真的是一个很好 ...

  3. c语言贪心算法合并箭,LeetCode刷题题库:贪心算法

    LeetCode刷题笔记:贪心算法 自大学开始,我便陆陆续续的学习一些 算法和数据结构 方面的内容,同时也开始在一些平台刷题,也会参加一些大大小小的算法竞赛.但是平时刷题缺少目的性.系统性,最终导致算 ...

  4. 《编程能力基础》刷题笔记(41 题)

    <编程能力基础>刷题笔记 1. 单调数列 题解:递归.模拟.API 2. 实现 strStr() 题解:API.暴力.滑动窗口 3. 平衡二叉树 题解:迭代 4. 重复的子字符串 题解:模 ...

  5. 《剑指 Offer I》刷题笔记 51 ~ 61 题

    <剑指 Offer I>刷题笔记 51_60 位运算(简单) 51. 二进制中 1 的个数 _解法1:逐伟判断 解法2:巧用 n&(n-1) 52. 不用加减乘除做加法(背题) 解 ...

  6. 《剑指 Offer I》刷题笔记 41 ~ 50 题

    <剑指 Offer I>刷题笔记 41_50 排序(中等) 41. 最小的k个数# _解法1:排序 API + 数组复制 API 42. 数据流中的中位数 _解法1:暴力 搜索和回溯算法( ...

  7. 《剑指 Offer I》刷题笔记 11 ~ 19 题

    <剑指 Offer I>刷题笔记 11 ~ 19 题 查找算法(中等) 11. 二维数组中的查找 _解法 1:暴力迭代 解法 2:标志数 解法 3:逐行二分 12. 旋转数组的最小数字 _ ...

  8. 《剑指 Offer I》刷题笔记 1 ~10 题

    <剑指 Offer I>刷题笔记 1 ~10 题 栈与队列(简单) 1. 用两个栈实现队列 _解法 1:暴力做法 解法 2:优化解法 1 2. 包含 min 函数的栈 _解法 1:pop( ...

  9. 牛客网Java刷题知识点之Java 集合框架的构成、集合框架中的迭代器Iterator、集合框架中的集合接口Collection(List和Set)、集合框架中的Map集合...

    不多说,直接上干货! 集合框架中包含了大量集合接口.这些接口的实现类和操作它们的算法. 集合容器因为内部的数据结构不同,有多种具体容器. 不断的向上抽取,就形成了集合框架. Map是一次添加一对元素. ...

最新文章

  1. 20个超高效的Linux命令与技巧
  2. 微电网日前优化调度 。算例有代码(3)
  3. Angular开发模式下的setNgReflectProperties函数
  4. 无法连接上 cn.archive.ubuntu.com:80 (123.129.214.98)。 - connect (111: 拒绝连接)
  5. c# mysql 封装_C#简单通用的数据库连接封装
  6. java.sql.SQLException: The server time zone value ‘???ú±ê×??±??‘ is unrecognized or represents more
  7. 答题闯关php,成语答题闯关红包流量主小程序源码
  8. 爬虫-古试词网验证码手工打码访问登陆后页面
  9. 树的最长路径详解(C++)
  10. 软件测试文档测试用例,软件测试用例文档模板(带实例)
  11. matlab线性规划--简单入门
  12. 转发:一个总经理的11个经典面试问题
  13. 【好文】敏捷中国十八年目睹之怪现状
  14. ylinux系统找到软件_你的 linux 上都有什么值得推荐的软件?
  15. 用Excel自带图表插入带分类变量的箱形图(单坐标轴并列箱)
  16. 【软件工程】02组软件工程组队项目15周工作进度汇报——课程管理小助手
  17. hdu 6411 带劲的and和(并查集、位运算)
  18. 步步精心,打造高德 AR 实景步行导航(设计篇)
  19. 小白如何从零开始打造一台DIY脑控智能机器人
  20. iOS CAAnimation 详解

热门文章

  1. P3128 [USACO15DEC]最大流Max Flow
  2. SSL:Ubuntu证书配置
  3. 将EditText的光标定位到字符的最后面
  4. consul 自动发现与自动注册
  5. GFS 分布式文件系统从入门到实践
  6. ubuntu如何修改php文件夹权限,Linux命令chmod:修改文件或文件夹权限
  7. 通达信波段王指标公式主图_通达信波段线主图指标公式
  8. 精彩回顾 | Apache Flink x Iceberg Meetup · 上海站
  9. Ask Me Anything #1 我是新晋CNCF TOC张磊,你有什么想问我的?
  10. 进入“高画质手游时代”?《天谕》手游首次采用的这项技术有多强大