分析: 这道题不是很难 用了一个split()函数
核心是: 对命令选项的判断 不要一个字符字符的判断 要一项一项的判断
比如ab:m:
分析步骤 (1) 读取一个字符(2)判断下一步是否有字符,下一个字符是否是':', 若是':",前进两位,标为带参数 否则前进一位,不带参数
对于命令的分析也是
不带参数 读取一项
带参数 读取两项
即--------整体分析,这样的循环结构是清晰简洁的
缺点 :用了好多if-else结构 不好看
#include <bits/stdc++.h>
using namespace std;
const int N=;
int is_c[N]; // 是否带参数
bool flag[N]; // 是否出现
string w[N]; // 记录参数
int n;
vector <string> split (string str,const char flag=' ') {
istringstream iss(str);
vector <string> ans;
while (getline(iss,str,flag))
if (str.size())
ans.push_back(str);
return ans;
}
void get_ord (string str) {
int i=;
while (i<str.size()) {
if (i<str.size()&&str[i+]==':') {
is_c[str[i]-'a']=;
i+=;
}
else { is_c[str[i]-'a']=; i+=; }
}
}
int main ()
{
string ord; cin>>ord; get_ord(ord);
cin>>n; getchar();
int T=;
while (++T<=n) {
string str; getline(cin,str);
vector <string> sv=split(str);
memset (flag,,sizeof(flag));
cout<<"Case "<<T<<":";
for (int i=;i<sv.size();i++) {
if (sv[i].size()==&&sv[i][]=='-') {
int id=sv[i][]-'a';
if (is_c[id]) {
flag[id]=;
if (is_c[id]==) {
if (i+<sv.size()) w[id]=sv[++i]; // 这个不判断的话只有90
else break;
}
}
else break;
}
else break;
}
for (int i=;i<N;i++)
if (flag[i]) {
char ch='a'+i; cout<<" -"<<ch;
if (is_c[i]==) cout<<" "<<w[i];
}
cout<<"\n";
}
return ;
}