JAVA CCF-201612-3 权限查询

欢迎访问我的CCF认证解题目录


题目描述

在这里插入图片描述


思路过程

由于后面的查询需要知道权限是否分等级,所以我们要把前面的权限存储起来,-1表示不分等级,可以使用map进行存储,方便查询。
那么后面的用户和角色也差不多,也是用map进行存储,其他就按照题目要求来就行了,比较简单的模拟题,直接看代码即可。

注意:出现重复权限的话只存储等级大的权限


代码

import java.util.HashMap;
import java.util.Scanner;

public class Main {

    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        HashMap<String, Integer> dic = new HashMap<>();//权限库,-1表示该权限不分等级
        HashMap<String, HashMap<String, Integer>> roles = new HashMap<>(), user = new HashMap<>();//角色库和用户库

        //存储权限
        int p = in.nextInt();//权限数量
        for ( int i = 0; i < p; i++ ) {
            String[] temp = in.next().split(":");
            if ( temp.length > 1 ) {//有等级
                dic.put(temp[0], Integer.parseInt(temp[1]));
            } else dic.put(temp[0], -1);
        }

        //存储角色
        int r = in.nextInt();//角色数量
        for ( int i = 0; i < r; i++ ) {
            String role = in.next();//角色名
            int num = in.nextInt();//权限数量
            roles.put(role, new HashMap<>());
            for ( int j = 0; j < num; j++ ) {
                String[] temp = in.next().split(":");
                if ( temp.length > 1 ) {
                    if ( roles.get(role).containsKey(temp[0]) ) {//如果已经有该权限,则选择较大的权限
                        roles.get(role).put(temp[0], Math.max(Integer.parseInt(temp[1]), roles.get(role).get(temp[0])));
                    } else {
                        roles.get(role).put(temp[0], Integer.parseInt(temp[1]));
                    }
                } else roles.get(role).put(temp[0], -1);
            }
        }

        //存储用户
        int u = in.nextInt();
        for ( int i = 0; i < u; i++ ) {
            String username = in.next();//用户名
            int num = in.nextInt();//角色数量
            user.put(username, new HashMap<>());
            for ( int j = 0; j < num; j++ ) {
                String role = in.next();//角色名
                for ( String key: roles.get(role).keySet() ) {//遍历角色的权限
                    int step = roles.get(role).get(key);//角色的权限等级
                    if ( user.get(username).containsKey(key) ) {//如果有该权限了
                        int temp = user.get(username).get(key);//该用户当前的权限等级
                        user.get(username).put(key, Math.max(temp, step));//存储较高的权限
                    } else {
                        user.get(username).put(key, step);
                    }
                }
            }
        }

        //查询处理
        int q = in.nextInt();
        for ( int i = 0; i < q; i++ ) {
            String username = in.next();//用户名
            String[] temp = in.next().split(":");

            //如果不存在该用户
            if ( !user.containsKey(username) ) {
                System.out.println("false");
                continue;
            }
            if ( temp.length > 1 ) {//如果查询带等级
                if ( user.get(username).containsKey(temp[0]) && user.get(username).get(temp[0]) >= Integer.parseInt(temp[1]) ) {//如果有该权限且大于查询的等级
                    System.out.println("true");
                } else {
                    System.out.println("false");
                }
            } else {
                if ( user.get(username).containsKey(temp[0]) ) {//如果有该权限
                    if ( dic.get(temp[0]) != -1 ) {//如果该权限分等级
                        System.out.println(user.get(username).get(temp[0]));
                    } else {
                        System.out.println("true");
                    }
                } else {
                    System.out.println(false);
                }
            }
        }
    }

}


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值