2015 09CCF计算机软件能力认证试题第三题

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)。

输出格式
  输出包含若干行,表示模板生成的结果。

样例输入

代码语言:javascript
复制
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>

样例输出

代码语言:javascript
复制
样例输出
<!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存一对对映射

代码语言:javascript
复制
// 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&lt;&lt;s[i][j];
    }
    cout&lt;&lt;endl;
}
return 0;

}