5.27-權限查詢-字符串操作

授權 (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 段,每行一個字符串,描述各個權限。對於分等級權限,格式爲 :,其中 是權限類名, 是該類權限的最高等級。對於不分等級權限,字符串只包含權限類名。
  接下來一行是一個正整數 r,表示不同的角色數量。緊接着的 r 行被稱爲 R 段,每行描述一種角色,格式爲
  
  其中 是角色名稱, 表示該角色具有多少種權限。後面 個字符串描述該角色具有的權限,格式同 P 段。
  接下來一行是一個正整數 u,表示用戶數量。緊接着的 u 行被稱爲 U 段,每行描述一個用戶,格式爲
   …
  其中 是用戶名, 表示該用戶具有多少種角色。後面 個字符串描述該用戶具有的角色。
  接下來一行是一個正整數 q,表示權限查詢的數量。緊接着的 q 行被稱爲 Q 段,每行描述一個授權查詢,格式爲 ,表示查詢用戶 是否具有 權限。如果查詢的權限是分等級權限,則查詢中的 可指定等級,表示查詢該用戶是否具有該等級的權限;也可以不指定等級,表示查詢該用戶具有該權限的等級。對於不分等級權限,只能查詢該用戶是否具有該權限,查詢中不能指定等級。
輸出格式
  輸出共 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% 的評測用例權限都是不分等級的,查詢也都不帶等級

注意的地方:
1、字符串的拆分
2、vector的使用

#include<iostream>
#include<vector>
#include<string>
#include<algorithm>
using namespace std;
struct priviledge
{
    string name;
    int num;
};
struct role
{
    string name;
    vector<priviledge> pri;
};
vector<role> r;
struct user
{
    string name;
    vector<string> role;
};
vector<user> u;
string getname(string a)
{
    int pos = a.find(":");
    if (a.find(":") == -1)
    {
        return a;
    }
    else
    {
        return a.substr(0, pos);
    }
}
int getnum(string a)
{
    int pos = a.find(":");
    if (pos == -1)
    {
        return -1;
    }
    else
    {
        return atoi(a.substr(pos + 1, a.length() - 1).c_str());//這裏需要注意substr的第二個參數可以多
    }

}
int main()
{

    int num1;
    cin >> num1;
    for (int i = 1; i <= num1; i++)
    {
        string tem;
        cin >> tem;

    }
    int num2;
    cin >> num2;
    role temr;
    for (int i = 1; i <= num2; i++)
    {
        string temname;
        cin >> temname;
        temr.name = temname;
        int num21;
        cin >> num21;
        for (int j = 1; j <= num21; j++)
        {
            string s;
            cin >> s;
            priviledge p;
            p.name = getname(s);
            p.num = getnum(s);
            temr.pri.push_back(p);
        }
        r.push_back(temr);
    }
    int num3;
    cin >> num3;

    for (int i = 1; i <= num3; i++)
    {
        user temu;//注意,原本把這行放到for循環之外了,但是結果尤其是role的部分會疊加造成出錯!!!!!!!!
        string s1;
        cin >> s1;
        temu.name = s1;
        int num31;
        cin >> num31;
        for (int j = 1; j <= num31; j++)
        {
            string s32;
            cin >> s32;
            temu.role.push_back(s32);
        }
        u.push_back(temu);
    }
    for (int i = 0; i < u.size(); i++)
    {
        cout << u[i].name << "  :  ";
        for (int j = 0; j < u[i].role.size(); j++)
        {
            cout << u[i].role[j] << " ";
        }
        cout << endl;
    }

    int num4;
    cin >> num4;
    for (int i = 1; i <= num4; i++)
    {
        string tn;
        cin >> tn;
        string tt;
        cin >> tt;
        string cname = getname(tt);
        int cno = getnum(tt);
        int minus = -2;
        int j;
        for (j = 0; j<u.size(); j++)
        {
            if (u[j].name == tn)
            {
                for (int k = 0; k < u[j].role.size(); k++)
                {
                    //cout << u[j].role[k] << endl;
                    for (int kk = 0; kk < r.size(); kk++)
                    {
                        if (r[kk].name == u[j].role[k])
                        {
                            for (int mm = 0; mm < r[kk].pri.size(); mm++)
                            {
                                //cout << r[kk].pri[mm].name << " + "<<r[kk].pri[mm].num<<"   ";
                                if (r[kk].pri[mm].name == cname)
                                {
                                    minus = max(minus, r[kk].pri[mm].num);
                                }
                            }
                            //cout << endl;
                        }
                    }
                }



                break;
            }
        }

        if (j == u.size())
        {
            cout << "false" << endl;
            continue;
        }
        if (cno >= 0)
        {
            if (minus >= cno)
            {
                cout << "true" << endl;
            }
            else
            {
                cout << "false" << endl;
            }
        }
        if (cno == -1)
        {
            if (minus >= 0)
            {
                cout << minus << endl;
            }
            else if (minus == -1)
            {
                cout << "true" << endl;
            }
            else
            {
                cout << "false" << endl;
            }
        }

    }


    return 0;
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章