4.2学习总结 Java:list系列集合

list系列集合:

++特点:++

++特有方法:++

示例代码:

java 复制代码
import java.util.List;
import java.util.ArrayList;
public class test {
    public static void main(String[] args) {
        List<String> list = new ArrayList<>();
        list.add("aaa");
        list.add("bbb");
        list.add("ccc");
        System.out.println(list);//[aaa, bbb, ccc]
        list.add(1,"ddd");
        //1为想要插入的索引位置。
        //原来索引上的元素后移
        System.out.println(list);//[aaa, ddd, bbb, ccc]
        list.remove(1);
        System.out.println(list);//[aaa, bbb, ccc]
    }
}

list集合的五种遍历方式:

迭代器遍历:能删除元素

增强for遍历

Lambda表达式遍历

普通for循环遍历

++列表迭代器遍历:能添加元素(list集合系列独有)++

示例代码:

java 复制代码
import java.util.*;
public class test {
    public static void main(String[] args) {
        List<String> list = new ArrayList<>();
        list.add("aaa");
        list.add("bbb");
        list.add("ccc");
        list.add("ddd");
        ListIterator<String> it = list.listIterator();
        while (it.hasNext()) {
            String str = it.next();
            if (str.equals("bbb")) {
                it.add("qqq");
            }
        }
        System.out.println(list);
    }
}

++Arraylist集合:++

右移运算符:

++泛型类:++

检查数据类型。

Integer类型不能强转为String类型。

泛型的继承和通配符:

泛型不具备继承性,但数据具有继承性。

泛型内写什么类型,就只能传递什么类型的数据值。

泛型的通配符:?就是一个问号。

洛谷p1223排队接水

源码:

java 复制代码
#include <stdio.h>
typedef struct {
    int time; 
    int index;
} Person;
void bubbleSort(Person arr[], int n) {
    for (int i = 0; i < n - 1; i++) {
        for (int j = 0; j < n - i - 1; j++) {
            if (arr[j].time > arr[j + 1].time) {
                Person temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
}
int main() {
    int n;
    scanf("%d", &n);

    Person people[n];
    for (int i = 0; i < n; i++) {
        scanf("%d", &people[i].time);
        people[i].index = i + 1; 
    }
   
    bubbleSort(people, n);
   
    for (int i = 0; i < n; i++) {
        printf("%d", people[i].index);
        if (i != n - 1) {
            printf(" ");
        }
    }
    printf("\n");
    
    double total_wait_time = 0;
    double current_time = 0;
    for (int i = 0; i < n; i++) {
        total_wait_time += current_time;
        current_time += people[i].time;
    }
    double average_wait_time = total_wait_time / n;
   
    printf("%.2f\n", average_wait_time);
    return 0;
}
相关推荐
再睡一夏就好14 小时前
【C++闯关笔记】详解多态
c语言·c++·笔记·学习·语法·1024程序员节
与己斗其乐无穷14 小时前
C++学习记录(22)异常
学习·1024程序员节
青云交15 小时前
Java 大视界 -- 基于 Java 的大数据机器学习模型在图像识别中的迁移学习与模型优化
java·大数据·迁移学习·图像识别·模型优化·deeplearning4j·机器学习模型
2501_9098008116 小时前
Java 集合框架之 Set 接口
java·set接口
断剑zou天涯16 小时前
【算法笔记】暴力递归尝试
java·笔记·算法
Nobody_Cares17 小时前
JWT令牌
java
沐浴露z17 小时前
Kafka入门:基础架构讲解,安装与使用
java·分布式·kafka
神秘的土鸡17 小时前
从数据仓库到数据中台再到数据飞轮:我的数据技术成长之路
java·服务器·aigc·数据库架构·1024程序员节
vir0217 小时前
P1928 外星密码(dfs)
java·数据结构·算法·深度优先·1024程序员节
摇滚侠17 小时前
全面掌握PostgreSQL关系型数据库,备份和恢复,笔记46和笔记47
java·数据库·笔记·postgresql·1024程序员节