权限查询(2016-12)

该程序读取用户输入,构建一个基于字符串的角色和人员权限系统。它使用结构体存储角色名和权限等级,通过哈希映射组织数据。程序比较角色,更新权限等级,并检查人员是否具有特定级别的权限。
摘要由CSDN通过智能技术生成

 

 

#include<bits/stdc++.h>
using namespace std;
struct P{
	string name;
	mutable int level;
	P(string str){
		int k=str.find(':');
		if(k==-1){
			name=str;
			level=-1;
		}else{
			name=str.substr(0,k);
			level=stoi(str.substr(k+1));
		}
	}
	bool operator<(const P& t)const
	{
		return name<t.name;
	}
};
unordered_map<string,set<P> >role,person;
int main(){
	int n;
	string str;
	cin>>n;
	while(n--)cin>>str;
	cin>>n;
	while(n--){
		string name;
		int cnt;
		cin>>name>>cnt;
		auto& r =role[name];
		while(cnt--){
			cin>>str;
			P t(str);
			if(t.level==-1)r.insert(t);
			else{
				if(!r.count(t))r.insert(t);
				else{
					auto it =r.find(t);
					it->level = max(it->level,t.level);
				}
			}
		}
	}
	cin>>n;
	while(n--){
		string name;
		int cnt;
		cin>>name>>cnt;
		auto&p =person[name];
		while(cnt--){
			string str;
			cin>>str;
			for(auto& t:role[str]){
				if(t.level==-1)p.insert(t);
			else{
				if(!p.count(t))p.insert(t);
				else{
					auto it =p.find(t);
					it->level = max(it->level,t.level);
				}
			}
			}
		}
	}
	cin>>n;
	while(n--){
		string user,pr;
		cin>>user>>pr;
		P t(pr);
		auto& p=person[user];
		if(!p.count(t))puts("false");
		else{
			auto it=p.find(t);
			if(t.level!=-1){
				if(it->level>=t.level)puts("true");
				else puts("false");
			}
			else{
				if(it->level==-1)puts("true");
				else cout<< it->level <<endl;
			}
		}
	}
	return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值