亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

ccf試題 權限查詢

2019-11-14 12:50:55
字體:
來源:轉載
供稿:網友

問題描述   授權 (authorization) 是各類業務系統不可缺少的組成部分,系統用戶通過授權機制獲得系統中各個模塊的操作權限。   本題中的授權機制是這樣設計的:每位用戶具有若干角色,每種角色具有若干權限。例如,用戶 david 具有 manager 角色,manager 角色有 crm:2 權限,則用戶 david 具有 crm:2 權限,也就是 crm 類權限的第 2 等級的權限。   具體地,用戶名和角色名稱都是由小寫字母組成的字符串,長度不超過 32。權限分為分等級權限和不分等級權限兩大類。分等級權限由權限類名和權限等級構成,中間用冒號“:”分隔。其中權限類名也是由小寫字母組成的字符串,長度不超過 32。權限等級是一位數字,從 0 到 9,數字越大表示權限等級越高。系統規定如果用戶具有某類某一等級的權限,那么他也將自動具有該類更低等級的權限。例如在上面的例子中,除 crm:2 外,用戶 david 也具有 crm:1 和 crm:0 權限。不分等級權限在描述權限時只有權限類名,沒有權限等級(也沒有用于分隔的冒號)。   給出系統中用戶、角色和權限的描述信息,你的程序需要回答多個關于用戶和權限的查詢。查詢可分為以下幾類:   * 不分等級權限的查詢:如果權限本身是不分等級的,則查詢時不指定等級,返回是否具有該權限;   * 分等級權限的帶等級查詢:如果權限本身分等級,查詢也帶等級,則返回是否具有該類的該等級權限;   * 分等級權限的不帶等級查詢:如果權限本身分等級,查詢不帶等級,則返回具有該類權限的等級;如果不具有該類的任何等級權限,則返回“否”。 輸入格式   輸入第一行是一個正整數 p,表示不同的權限類別的數量。緊接著的 p 行被稱為 P 段,每行一個字符串,描述各個權限。對于分等級權限,格式為 < category>:< level>,其中 < category> 是權限類名,< level> 是該類權限的最高等級。對于不分等級權限,字符串只包含權限類名。   接下來一行是一個正整數 r,表示不同的角色數量。緊接著的 r 行被稱為 R 段,每行描述一種角色,格式為   < role> < s> < PRivilege 1> < privilege 2> … < privilege s>   其中 < role> 是角色名稱,< s> 表示該角色具有多少種權限。后面 < s> 個字符串描述該角色具有的權限,格式同 P 段。   接下來一行是一個正整數 u,表示用戶數量。緊接著的 u 行被稱為 U 段,每行描述一個用戶,格式為   < user> < t> < role 1> < role 2> … < role t>   其中 < user> 是用戶名,< t> 表示該用戶具有多少種角色。后面 < t> 個字符串描述該用戶具有的角色。   接下來一行是一個正整數 q,表示權限查詢的數量。緊接著的 q 行被稱為 Q 段,每行描述一個授權查詢,格式為 < user> < privilege>,表示查詢用戶 < user> 是否具有 < privilege> 權限。如果查詢的權限是分等級權限,則查詢中的 < privilege> 可指定等級,表示查詢該用戶是否具有該等級的權限;也可以不指定等級,表示查詢該用戶具有該權限的等級。對于不分等級權限,只能查詢該用戶是否具有該權限,查詢中不能指定等級。 輸出格式   輸出共 q 行,每行為 false、true,或者一個數字。false 表示相應的用戶不具有相應的權限,true 表示相應的用戶具有相應的權限。對于分等級權限的不帶等級查詢,如果具有權限,則結果是一個數字,表示該用戶具有該權限的(最高)等級。如果用戶不存在,或者查詢的權限沒有定義,則應該返回 false。 樣例輸入 3 crm:2 git:3 game 4 hr 1 crm:2 it 3 crm:1 git:1 game dev 2 git:3 game qa 1 git:2 3 alice 1 hr bob 2 it qa charlie 1 dev 9 alice game alice crm:2 alice git:0 bob git bob poweroff charlie game charlie crm charlie git:3 malice game 樣例輸出 false true false 2 false true false true false 樣例說明   樣例輸入描述的場景中,各個用戶實際的權限如下:   * 用戶 alice 具有 crm:2 權限   * 用戶 bob 具有 crm:1、git:2 和 game 權限   * 用戶 charlie 具有 git:3 和 game 權限   * 用戶 malice 未描述,因此不具有任何權限 評測用例規模與約定   評測用例規模:   * 1 ≤ p, r, u ≤ 100   * 1 ≤ q ≤ 10?000   * 每個用戶具有的角色數不超過 10,每種角色具有的權限種類不超過 10   約定:   * 輸入保證合法性,包括:   1) 角色對應的權限列表(R 段)中的權限都是之前(P 段)出現過的,權限可以重復出現,如果帶等級的權限重復出現,以等級最高的為準   2) 用戶對應的角色列表(U 段)中的角色都是之前(R 段)出現過的,如果多個角色都具有某一分等級權限,以等級最高的為準   3) 查詢(Q 段)中的用戶名和權限類名不保證在之前(U 段和 P 段)出現過   * 前 20% 的評測用例只有一種角色   * 前 50% 的評測用例權限都是不分等級的,查詢也都不帶等級

題目看起來很復雜,一層一層的查詢,我以為需要樹之類特別的數據結構,看了別人的代碼原來用結構體和map就可以了,問題是思路要搞清楚,我看還有人用的并查集,沒有仔細看,下面的代碼感覺已經很清楚了,這次用的是別人代碼,加了個人理解的注釋,希望下次能自己試著做出來。

#include <iostream>#include <map>#include <cstring>#include <string>using namespace std;struct role{ int ccount; string cat[10];//每個角色最多有十個權限};struct user{ int rcount; string role[10];//每個用戶最多有十個角色};map<string,int> cats;//存儲權限名和對應等級map<string,role> roles;//存儲某角色名和對應權限map<string,user> users;map<string,int> temp;//存儲某用戶名下所有權限struct role role;struct user user;int main(){ int p,r,u,q; int i,j,k; int length; string power; cin>>p; for(i=0;i<p;i++) { cin>>power;//輸入權限 length=power.length(); k=power[length-1]-'0';//轉換權限的最后一個字符為數字 if(k>=0&&k<=9) { cats[power.substr(0,length-2)]=k; } else { cats[power]=-1; } } cin>>r; string rolename; for(i=0;i<r;i++) { for(j=0;j<10;j++) { role.cat[j]=""; } cin>>rolename; cin>>role.ccount; for(j=0;j<role.ccount;j++) { cin>>role.cat[j]; } roles[rolename]=role; } string username; cin>>u;//輸入用戶 for(i=0;i<u;i++) { for(j=0;j<10;j++) { user.role[j]=""; } cin>>username; cin>>user.rcount; for(j=0;j<user.rcount;j++) { cin>>user.role[j]; } users[username]=user; } cin>>q;//查詢的個數 string query; int level; for(i=0;i<q;i++) { cin>>username; cin>>query; temp.clear(); if(users.find(username)==users.end()) { cout<<"false"<<endl; continue; } else { user=users[username]; for(j=0;j<user.rcount;j++) { rolename=user.role[j]; role=roles[rolename]; for(k=0;k<role.ccount;k++) { string catname=role.cat[k]; length=catname.length(); if(catname[length-2]==':') { level=catname[length-1]-'0'; catname=catname.substr(0,length-2); if(temp.find(catname)==temp.end()) { temp[catname]=level; } else { if(temp[catname]<level)//只存儲該權限的最高等級 { temp[catname]=level; } } } else { temp[catname]=-1;//不區分等級的權限記為-1 } } } }//至此,該username所有權限存儲完畢 level=-1; length=query.length(); if(query[length-2]==':') { level=query[length-1]-'0'; query=query.substr(0,length-2); } if(temp.find(query)==temp.end()) { cout<<"false"<<endl; continue; } if(level==-1) //不確定是否是分等級的權限,查詢中沒有包括等級 { if(temp[query]==-1)//如果該權限不分等級 { cout<<"true"<<endl; } else//分等級權限的不帶等級查詢 { cout<<temp[query]<<endl; } } else { if(temp[query]>=level) { cout<<"true"<<endl; } else { cout<<"false"<<endl; } } }}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
97碰碰碰免费色视频| 亚洲影视九九影院在线观看| 中文字幕欧美日韩精品| 日韩在线中文视频| 亚洲精品动漫久久久久| 亚洲区中文字幕| 亚洲免费视频网站| 亚洲成**性毛茸茸| 欧美人与性动交a欧美精品| 国产成人综合亚洲| 国产精品欧美激情在线播放| 国产精品91在线观看| 91精品国产91久久久久久最新| 久久久国产精彩视频美女艺术照福利| 日本高清不卡在线| 欧美电影免费观看高清| 国产一区二区三区高清在线观看| 国产91在线播放| 久久视频免费观看| 国产偷国产偷亚洲清高网站| 欧美自拍视频在线| 国产精品久久一区主播| 久久久亚洲天堂| 欧美激情一级欧美精品| 精品电影在线观看| 亚洲午夜久久久影院| 91精品在线观看视频| 伊人亚洲福利一区二区三区| 91精品国产自产在线| 色噜噜狠狠狠综合曰曰曰88av| 97在线精品国自产拍中文| 欧美一区亚洲一区| 日韩av在线网站| 最近中文字幕mv在线一区二区三区四区| 97超级碰碰人国产在线观看| 欧美激情视频一区二区| 亚洲欧美日韩一区在线| 精品国偷自产在线视频99| 久久久久久久影视| 日本午夜人人精品| 欧美激情va永久在线播放| 亚洲激情在线视频| 国产suv精品一区二区三区88区| 伊人久久男人天堂| 国产欧美一区二区三区在线看| 国产亚洲福利一区| 欧美日韩国产精品专区| 久久精品视频一| 色哟哟入口国产精品| 亚洲一区二区中文| 国产精品女人久久久久久| 欧洲亚洲女同hd| 欧美高清视频在线观看| 欧美一区三区三区高中清蜜桃| 欧美激情在线有限公司| 欧美多人爱爱视频网站| 欧美乱人伦中文字幕在线| 亚洲国产精品嫩草影院久久| 亚洲一区亚洲二区亚洲三区| 日韩精品欧美国产精品忘忧草| 欧美视频在线观看 亚洲欧| 欧美多人爱爱视频网站| 久久精视频免费在线久久完整在线看| 亚洲欧美在线第一页| 日韩综合中文字幕| 国产女人18毛片水18精品| 久久亚洲国产精品| 国产欧美中文字幕| 国产精品久久久久久久久久久不卡| 国产亚洲美女久久| 欧美精品一本久久男人的天堂| 亚洲性日韩精品一区二区| 国产精品电影在线观看| 91九色在线视频| 成人欧美一区二区三区在线| 国产欧美一区二区三区在线| 在线日韩中文字幕| 国产99久久精品一区二区永久免费| 亚洲a一级视频| 亚洲人线精品午夜| 国产精品中文字幕在线观看| 久久久精品久久久久| 欧美精品一区二区免费| 欧美大片大片在线播放| 久久理论片午夜琪琪电影网| 久久综合电影一区| 国产一区二区三区免费视频| 91国内产香蕉| 国产精品久久久久免费a∨大胸| 91精品国产综合久久男男| 精品国产91久久久| 亚洲国产欧美精品| 欧美尺度大的性做爰视频| 欧美孕妇毛茸茸xxxx| 欧美在线观看网址综合| 亚洲欧美在线免费| 日韩美女av在线免费观看| 久久亚洲精品一区| 日韩视频永久免费观看| 国产一区二区三区在线免费观看| 国产精品自拍偷拍视频| 青青久久av北条麻妃黑人| 国产精品美女久久久久av超清| 午夜精品视频在线| 成人免费福利在线| 日韩在线观看高清| 中文字幕日韩免费视频| 国产精品成人一区二区| 免费91麻豆精品国产自产在线观看| 91日韩在线播放| 清纯唯美亚洲综合| 麻豆成人在线看| 大量国产精品视频| 91免费国产网站| 疯狂做受xxxx高潮欧美日本| 成人激情在线观看| 26uuu亚洲国产精品| 亚洲美女激情视频| 国产精品久久久久av| 亚洲女人天堂网| 国产一区二区黑人欧美xxxx| 国产精品午夜一区二区欲梦| 亚洲va欧美va国产综合剧情| 亚洲综合中文字幕在线| 91精品国产乱码久久久久久蜜臀| 日韩精品视频免费专区在线播放| 亚洲第一页在线| 欧美资源在线观看| 亚洲欧美一区二区激情| 亚洲自拍高清视频网站| 成人精品福利视频| 欧美黑人极品猛少妇色xxxxx| 欧美在线视频免费| 2019日本中文字幕| 欧美精品免费在线观看| 亚洲午夜未满十八勿入免费观看全集| 国产97在线视频| 欧美激情一区二区三区在线视频观看| 欧洲成人在线观看| 91精品在线播放| 亚洲免费视频观看| 日本19禁啪啪免费观看www| 91精品国产乱码久久久久久久久| 精品一区二区三区四区在线| 亚洲人成电影网站色…| 精品国产福利在线| 亚洲人成网7777777国产| 成人羞羞国产免费| 欧美成人黑人xx视频免费观看| 精品中文字幕久久久久久| 国产精品美女www| 91精品国产一区| 国模gogo一区二区大胆私拍| 亚洲成色777777女色窝| 亚洲xxxxx电影| 亚洲国产精品va在线看黑人动漫| 欧美日韩精品在线观看| 亚洲人永久免费| 日韩av免费看| 国产精品99久久99久久久二8| 欧美激情一区二区三级高清视频| 亚洲无线码在线一区观看| 午夜精品久久久久久久99热浪潮| 亚洲黄色www|