生活随笔
收集整理的這篇文章主要介紹了
nyoj1307Linux的文件权限对不对
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
題目鏈接http://acm.nyist.net/JudgeOnline/problem.php?pid=1307
Linux的文件權限對不對?
時間限制:1000?ms ?|? 內存限制:65535?KB ? ??難度:2
描述 ?數字與權限表示的對應關系如下(注意沒有 --- = 0 的對應關系) r-- = 4 ?-w- = 2 ?--x = 1 ?rw- = 6 ?r-x = 5 ?-wx = 3 ?rwx = 7
輸入輸入文件的第一行是一個整數T,表示有T組數據。 接下來是T組數據,每個數據有兩行,第一行是命令(二)中的數字,第二行是表示文件權限的字符串。輸出數字和字符串表示含義一致,則輸出“Yes”(不帶雙引號),否則輸出“No”樣例輸入 4
666
-rw-rw-rw-
777
wrwxrwxrwx
888
-r--r--r--
111
-r--r--r-x 樣例輸出 Yes
No
No
No
AC代碼:
#include <stdio.h>
int main() {int t;char b[20], s[29] = " --x-w--wxr--r-xrw-rwx ";//1+3*9+1//s按1--x, 2-w-, 3-wx...順序存放 s[0]存放一個空格的目的是方便 標記1 處的操作; //后面放6個空格,8和9其實只是個幌子,8、9根本沒有可對應的符號 scanf("%d", &t);while(t--) {char a[4], flag = 1, t, ts;int i, j, k;scanf("%s%s", a, b);for(i = 0; i < 3; i++) {k = a[i]-'0'-1;//當a長度不達3時,如66 -rw-rw-, a[2]為0,k為負值,此題沒有此情況// 當a[0]='0'時也為負,題中也說了沒有此情況,故可不處理 for(j = 1; j <= 3; j++) {t = b[i*3+j];//j從1開始免去此處i*3+j+1的+1if(k<0) ts=' ';//k為負值時的處理,s[0]為空格 else ts=s[k*3+j];if(/*標記1*/ts != t || t == 0) break;//字符不匹配||長度小于1+9 則break }if(j <= 3) {flag = 0;break;}}if(b[0] != '-' || b[10] != 0) flag = 0;//輸入的字符串按規則b[0]應當是-,b[10]!=0說明超過規定長度 if(flag) printf("Yes\n");else printf("No\n");}return 0;
}
與50位技術專家面對面20年技術見證,附贈技術全景圖
總結
以上是生活随笔為你收集整理的nyoj1307Linux的文件权限对不对的全部內容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。