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;
}
相关推荐
程序媛学姐6 分钟前
SpringKafka错误处理:重试机制与死信队列
java·开发语言·spring·kafka
向阳25623 分钟前
SpringBoot+vue前后端分离整合sa-token(无cookie登录态 & 详细的登录流程)
java·vue.js·spring boot·后端·sa-token·springboot·登录流程
梅子酱~32 分钟前
Vue 学习随笔系列二十二 —— 表格高度自适应
javascript·vue.js·学习
s_little_monster36 分钟前
【Linux】进程信号的捕捉处理
linux·运维·服务器·经验分享·笔记·学习·学习方法
XiaoLeisj40 分钟前
【MyBatis】深入解析 MyBatis XML 开发:增删改查操作和方法命名规范、@Param 重命名参数、XML 返回自增主键方法
xml·java·数据库·spring boot·sql·intellij-idea·mybatis
风象南40 分钟前
SpringBoot实现数据库读写分离的3种方案
java·spring boot·后端
振鹏Dong1 小时前
策略模式——本质是通过Context类来作为中心控制单元,对不同的策略进行调度分配。
java·策略模式
ChinaRainbowSea1 小时前
3. RabbitMQ 的(Hello World) 和 RabbitMQ 的(Work Queues)工作队列
java·分布式·后端·rabbitmq·ruby·java-rabbitmq
雾月551 小时前
LeetCode 914 卡牌分组
java·开发语言·算法·leetcode·职场和发展
JackmoodCC1 小时前
Java学习总结-递归-递归寻找文件绝对路径
学习