試題編號:
201403-3
試題名稱:
命令列選項
時間限制:
1.0s
記憶體限制:
256.0mb
問題描述:
問題描述
請你寫乙個命令列分析程式,用以分析給定的命令列裡包含哪些選項。每個命令列由若干個字串組成,它們之間恰好由乙個空格分隔。這些字串中的第乙個為該命令列工具的名字,由小寫字母組成,你的程式不用對它進行處理。在工具名字之後可能會包含若干選項,然後可能會包含一 些不是選項的引數。
選項有兩類:帶引數的選項和不帶引數的選項。乙個合法的無引數選項的形式是乙個減號後面跟單個小寫字母,如"-a" 或"-b"。而帶引數選項則由兩個由空格分隔的字串構成,前者的格式要求與無引數選項相同,後者則是該選項的引數,是由小寫字母,數字和減號組成的非空字串。
該命令列工具的作者提供給你乙個格式字串以指定他的命令列工具需要接受哪些選項。這個字串由若干小寫字母和冒號組成,其中的每個小寫字母表示乙個該程式接受的選項。如果該小寫字母後面緊跟了乙個冒號,它就表示乙個帶引數的選項,否則則為不帶引數的選項。例如, "ab:m:" 表示該程式接受三種選項,即"-a"(不帶引數),"-b"(帶引數), 以及"-m"(帶引數)。
命令列工具的作者準備了若干條命令列用以測試你的程式。對於每個命令列,你的工具應當一直向後分析。當你的工具遇到某個字串既不是合法的選項,又不是某個合法選項的引數時,分析就停止。命令列剩餘的未分析部分不構成該命令的選項,因此你的程式應當忽略它們。
輸入格式
輸入的第一行是乙個格式字串,它至少包含乙個字元,且長度不超過 52。格式字串只包含小寫字母和冒號,保證每個小寫字母至多出現一次,不會有兩個相鄰的冒號,也不會以冒號開頭。
輸入的第二行是乙個正整數 n(1 ≤ n ≤ 20),表示你需要處理的命令列的個數。
接下來有 n 行,每行是乙個待處理的命令列,它包括不超過 256 個字元。該命令列一定是若干個由單個空格分隔的字串構成,每個字串裡只包含小寫字母,數字和減號。
輸出格式
輸出有 n 行。其中第 i 行以"case i:" 開始,然後應當有恰好乙個空格,然後應當按照字母公升序輸出該命令列中用到的所有選項的名稱,對於帶引數的選項,在輸出它的名稱之後還要輸出它的引數。如果乙個選項在命令列**現了多次,只輸出一次。如果乙個帶引數的選項在命令列** 現了多次,只輸出最後一次出現時所帶的引數。
樣例輸入
albw:x
4ls -a -l -a documents -b
lsls -w 10 -x -w 15
ls -a -b -c -d -e -l
樣例輸出
case 1: -a -l
case 2:
case 3: -w 15 -x
case 4: -a -b
#includeusing namespace std;
typedef long long ll;
unordered_mapmp;
mapans;
string str;
vectorve;
void tostrtok(string line)
ve.push_back(line);
return;
}int main()
else if(ve[i][0]=='-'&&ve[i].size()==2&&(ve[i][1]<='z'&&ve[i][1]>='a')&&mp[ve[i][1]]==2)
else break;
} cout<<"case "
cout<} return 0;
}
命令列查詢亂碼
mysql會出現中文亂碼的原因不外乎下列幾點 1.server本身設定問題,例如還停留在latin1 2.table的語系設定問題 包含character與collation 3.客戶端程式 例如php 的連線語系設定問題 強烈建議使用utf8,utf8可以相容世界上所有字元 id iframe 0...
python命令列選項和引數分割
python中使用getopt處理命令列引數,本文主要對getopt進行介紹。getopt的呼叫主要分三步 1 匯入sys和getopt模組 2 分析命令列引數 3 處理結果 第一步很簡單,只需要 import sys import getopt 第二步處理方法如下 try opts,args ge...
linux history 歷史命令列查詢和使用
history命令 用於顯示歷史記錄和執行過的指令命令,可以使用符號 執行指定序號的歷史命令。例如,要執行第2個歷史命令,則輸入 2。history命令 是被儲存在記憶體中的,當退出或者登入shell時,會自動儲存或讀取。預設是不顯示命令的執行時間,命令的執行時間,history 已經記錄,只是沒有...