嵌套用法list+map

 

List<Map<String ,List<Stu>>>list=new ArrayList<>();

 

package kgc_byme.day17.newtest_hash.tee;

import java.util.*;

/**
 * @Description:
 * @author:myh
 * @date: 2021/6/2  17:23
 */
public class test {
    public static void main(String[] args) {


        Scanner sc=new Scanner(System.in);

        List<Map<String ,List<Stu>>>list=new ArrayList<>();
        System.out.println("输入年级个数");
        int gradeNums=sc.nextInt();
        for (int i = 1; i <= gradeNums; i++) {
            System.out.println("输入第"+i+"个年级信息");
            Map<String,List<Stu>> mm=new HashMap<>();
            System.out.println("输入班级数");
            int classNums=sc.nextInt();

            //这个处理每个班级 要构建Map<String,List<Stu>>
            for (int j = 1; j <=classNums; j++) {
                List<Stu>  everyClassStuList=new ArrayList<>();

                System.out.println("班级编号:");
                String classNo=sc.next();
                //处理value即List<Stu>
                System.out.println("输入第"+j+"个班级人数");
                int everyClassNums=sc.nextInt();
                for (int k = 1; k <=everyClassNums; k++) {
                    everyClassStuList.add(new Stu("yyoo"+k,"zss"+k,20));

                }
                mm.put(classNo,everyClassStuList);

            }

            list.add(mm);
        }

        System.out.println(list);









    }



}


class Stu{
    String  id;
    String name;
    int score;

    public Stu(String id, String name, int score) {
        this.id = id;
        this.name = name;
        this.score = score;
    }

    @Override
    public String toString() {
        return "Stu{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", score=" + score +
                '}';
    }
}

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: c++ 中的 map 是一种关联式容器,它保存了一组关键字/值对,关键字是唯一的,而值则可以重复出现。 您可以通过使用下标运算符 [] 来访问 map 中的元素,如下所示: ``` map<string, int> m; m["apple"] = 0; m["banana"] = 1; cout << m["apple"] << endl; // 输出 0 ``` 您还可以使用迭代器来遍历 map 中的元素: ``` map<string, int>::iterator it; for (it = m.begin(); it != m.end(); it++) { cout << it->first << " " << it->second << endl; } ``` 如果要在 map嵌套 map,您可以这样声明: ``` map<string, map<string, int> > m; ``` 然后,您就可以像访问普通 map 一样访问嵌套map,如下所示: ``` m["apple"]["red"] = 0; m["apple"]["green"] = 1; m["banana"]["yellow"] = 2; cout << m["apple"]["red"] << endl; // 输出 0 ``` 希望这能帮到您! ### 回答2: 在C语言中,本身是没有提供map数据结构的,因此也没有直接的map嵌套的语法或库函数可供使用。但我们可以通过其他的方式来实现map嵌套的功能,例如使用结构体和链表的组合。 首先,我们可以定义一个结构体来表示map的每个元素,该结构体包含一个键和一个值,例如: ```c typedef struct { int key; int value; } MapElement; ``` 然后,我们可以使用链表来存储多个键值对,从而实现类似于map的功能。例如,我们可以定义一个节点结构体来表示链表的每个节点,其中包含指向下一个节点的指针和一个MapElement类型的指针,例如: ```c typedef struct Node { MapElement *element; struct Node *next; } Node; ``` 然后,我们可以定义一个链表结构体,其中包含头节点和尾节点的指针,用于存储整个map的键值对,例如: ```c typedef struct { Node *head; Node *tail; } LinkedList; ``` 接下来,我们可以定义一个函数来向map中添加键值对,例如: ```c void addKeyValue(LinkedList *list, int key, int value) { MapElement *element = malloc(sizeof(MapElement)); element->key = key; element->value = value; Node *newNode = malloc(sizeof(Node)); newNode->element = element; newNode->next = NULL; if (list->head == NULL) { list->head = newNode; list->tail = newNode; } else { list->tail->next = newNode; list->tail = newNode; } } ``` 最后,我们可以定义一个函数来根据键查找map中的值,例如: ```c int findValueByKey(LinkedList *list, int key) { Node *current = list->head; while (current != NULL) { if (current->element->key == key) { return current->element->value; } current = current->next; } return -1; // 如果找不到指定的键,可以返回-1或其他合适的值 } ``` 使用以上所定义的结构体和函数,我们可以创建并使用一个map嵌套。例如: ```c int main() { LinkedList map; map.head = NULL; map.tail = NULL; // 添加键值对 addKeyValue(&map, 1, 10); addKeyValue(&map, 2, 20); addKeyValue(&map, 3, 30); // 查找值 int value = findValueByKey(&map, 2); printf("Value: %d\n", value); // 输出:Value: 20 return 0; } ``` 总结来说,虽然C语言本身没有提供map嵌套的直接实现方式,但通过结构体和链表的组合,我们可以实现类似map嵌套的功能。 ### 回答3: 在C语言中,要实现map嵌套,可以使用结构体与指针的方式来进行。首先,我们需要定义一个结构体作为map的元素,该结构体包含两个成员,代表键(key)和值(value)。 ```c typedef struct { int key; int value; } MapElement; ``` 然后,我们可以声明一个指向这个结构体的二维数组,作为嵌套map。 ```c MapElement map[row][col]; ``` 其中,`row`和`col`可以是任意的正整数,代表map的行数和列数。 接下来,我们可以通过循环来初始化map的元素,以及对map进行赋值和访问。 ```c int i, j; // 初始化map for (i = 0; i < row; i++) { for (j = 0; j < col; j++) { map[i][j].key = i; map[i][j].value = j; } } // 访问map元素 for (i = 0; i < row; i++) { for (j = 0; j < col; j++) { printf("map[%d][%d]: key=%d, value=%d\n", i, j, map[i][j].key, map[i][j].value); } } ``` 通过上述代码,我们可以实现一个基本的map嵌套,并对其中的元素进行初始化和访问。你也可以根据需求进一步扩展和修改这个map,比如将键和值的类型改为其他类型,或者使用动态内存分配来实现更灵活的map嵌套
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值