ccf-201509-3 模板生成系统 试题编号: 201509-3 试题名称: 模板生成系统 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 成成最近在搭建一个网站,其中一些页面的部分内容来自数据库中不同的数据记录,但是页面的基本结构是相同的。例如,对于展示用户信息的页面,当用户为 Tom 时,网页的源代码是
而当用户为 Jerry 时,网页的源代码是
这样的例子在包含动态内容的网站中还有很多。为了简化生成网页的工作,成成觉得他需要引入一套模板生成系统。
模板是包含特殊标记的文本。成成用到的模板只包含一种特殊标记,格式为 {{ VAR }},其中 VAR 是一个变量。该标记在模板生成时会被变量 VAR 的值所替代。例如,如果变量 name = “Tom”,则 {{ name }} 会生成 Tom。具体的规则如下:
·变量名由大小写字母、数字和下划线 (_) 构成,且第一个字符不是数字,长度不超过 16 个字符。
·变量名是大小写敏感的,Name 和 name 是两个不同的变量。
·变量的值是字符串。
·如果标记中的变量没有定义,则生成空串,相当于把标记从模板中删除。
·模板不递归生成。也就是说,如果变量的值中包含形如 {{ VAR }} 的内容,不再做进一步的替换。
输入格式
输入的第一行包含两个整数 m, n,分别表示模板的行数和模板生成时给出的变量个数。
接下来 m 行,每行是一个字符串,表示模板。
接下来 n 行,每行表示一个变量和它的值,中间用一个空格分隔。值是字符串,用双引号 (“) 括起来,内容可包含除双引号以外的任意可打印 ASCII 字符(ASCII 码范围 32, 33, 35-126)。
输出格式
输出包含若干行,表示模板生成的结果。
样例输入
11 2
<!DOCTYPE html>
<html>
<head>
<title>User {{ name }}</title>
</head>
<body>
<h1>{{ name }}</h1>
<p>Email: <a href="mailto:{{ email }}">{{ email }}</a></p>
<p>Address: {{ address }}</p>
</body>
</html>
样例输出
样例输出
<!DOCTYPE html>
<html>
<head>
<title>User David Beckham</title>
</head>
<body>
<h1>David Beckham</h1>
<p>Email: <a href="mailto:david@beckham.com">david@beckham.com</a></p>
<p>Address: </p>
</body>
</html>
思路:ccf一般第三题的位置是题大模拟,这次也不例外,字符串大模拟,找到就修改替换,map存一对对映射
// luogu-judger-enable-o2 #include<bits/stdc++.h> #include<unordered_set> #define rg register ll #define inf 2147483647 #define min(a,b) (a<b?a:b) #define max(a,b) (a>b?a:b) #define ll long long #define maxn 200005 const double eps = 1e-8; using namespace std; inline ll read() { char ch = getchar(); ll s = 0, w = 1; while (ch < 48 || ch>57) { if (ch == '-')w = -1; ch = getchar(); } while (ch >= 48 && ch <= 57) { s = (s << 1) + (s << 3) + (ch ^ 48); ch = getchar(); } return s * w; } inline void write(ll x) { if (x < 0)putchar('-'), x = -x; if (x > 9)write(x / 10); putchar(x % 10 + 48); } ll n,m; string s[105]; map<string,string>p; int main() { n=read(),m=read(); //getchar(); for(rg i=1;i<=n;i++) { getline(cin,s[i]); //cout<<s[i]<<endl; } for(rg i=1;i<=m;i++) { string a,b; a.clear(),b.clear(); cin>>a; getchar(); getline(cin,b); //cout<<b[0]<<endl; b.erase(0,1),b.erase(b.size()-1,1); //cout<<a<<endl<<b<<endl; p[a]=b; } for(rg i=1;i<=n;i++) { for(rg j=0;j<s[i].size();j++) { if(s[i][j]=='{'&&s[i][j+1]=='{'&&s[i][j+2]==' ') { string temp; temp.clear(); rg k=j; while(s[i][k]!='}') { k++; /* if(s[i][k]=='{'&&k!=j+1) { for(rg h=j;h<k;h++)cout<<s[i][h]; j=k; }*/ } temp=s[i].substr(j,k+2-j); temp.erase(0,3); temp.erase(temp.size()-3,3); //cout<<temp<<endl; j=k+1; for(auto it:p) { if(it.first==temp) { cout<<p[temp]; break; } }
continue; } cout<<s[i][j]; } cout<<endl; } return 0;
}