大致翻译:

对于电子邮件应用程序,您需要描述发生在成对mta之间的基于smtp的通信。发送方

的用户代理向发送消息传输代理(MTA)提供格式化的消息。发送MTA使用SimpleMail

传输协议(SMTP)与接收MTA通信。接收MTA将邮件发送到接收方的用户代理。初始化

通信链路后,发送MTA将命令行(每次一行)传输到接收MTA,接收MTA在处理每个命令

后返回一个三位数编码的响应。下面按每个消息的发送顺序显示这些发送命令。当

同一消息发送到同一MTA的多个用户时,会有多个RCPTTO行。给不同mta的用户的消

息需要单独的SMTP会话。
输入
输入包含mta的描述以及任意数量的消息。每个MTA的描述以MTA目的地及其名称(1到

15个字母数字字符)开始。在MTA名称后面是在该MTA接收邮件的用户数量和用户列表

(每个用户1到15个字母数字字符)。MTA描述以第1列中的星号结束。每条消息都以发

送用户的姓名开始,然后是收件人标识符列表。每个标识符的表单是user@mtaname

。消息(每行包含不超过72个字符)以第1列中的星号开始和结束。第1列中带有星号

而不是发送方和接收方列表的行表示整个输入的结束。
输出
对于每个消息,显示发送和接收mta之间的通信。消息中提到的每个MTA都是有效的

MTA;但是,目的地MTA可能不存在消息接收者。接收MTA通过使用550代码响应RCPT

to命令拒绝这些用户的邮件。拒绝将不影响在同一MTA向授权用户交付。如果在特定

的MTA上没有至少一个授权的收件人,则数据不会被发送。只有一个SMTP会话用于向

特定MTA的用户发送消息。例如,发送给同一MTA的5个用户的消息将只有一个SMTP会

话。同样,一条消息只针对同一用户一次。发送方联系接收mta的顺序与输入文件中

的顺序相同。如示例输出所示,在通信前加上正在通信的MTA名称,并缩进每个非空

通信行。不应打印不必要的空格。

样例输入:

MTA London 4 Fiona Paul Heather Nevil
MTA SanFrancisco 3 Mario Luigi Shariff
MTA Paris 3 Jacque Suzanne Maurice
MTA HongKong 3 Chen Jeng Hee
MTA MexicoCity 4 Conrado Estella Eva Raul
MTA Cairo 3 Hamdy Tarik Misa
*
Hamdy@Cairo Conrado@MexicoCity Shariff@SanFrancisco Lisa@MexicoCity
*
Congratulations on your efforts !!
--Hamdy
*
Fiona@London Chen@HongKong Natasha@Paris
*
Thanks for the report!  
--Fiona
*
*

样例输出:(中间没有空行,是截图的锅)

 #include<iostream>
#include<string>
#include<vector>
#include<set>
#include<map>
using namespace std; void parse_address(const string &s,string & user,string &mta)
{
int pos = s.find('@');//从0开始
user = s.substr(, pos);//左闭右开,复制0~pos-1;
mta = s.substr(pos + );
}
int main()
{
set<string> addr;
string s,s2,user1,mta1,user2,mta2;
int n;
while (cin >> s&&s != "*")//MTA,第一个*
{
cin >> s >> n;
while (n--)
{
cin >> s2;
addr.insert(s2 + "@" + s);//Hamdy@Cairo这样存
}
}
while (cin>>s&&s!="*")//发件人收件人,数据,第五个*
{
parse_address(s, user1, mta1);//分割Hamdy@Cairo发件人 vector<string> mta;//所有需要连接的MTA(按输入顺序)
map<string, vector<string> > dest;//每个MTA需要发送的用户
//<MTA名称,用户名列表>
set<string> vis;//收件人去重 while (cin>>s2&&s2!="*")//处理收件人,第二个*
{
parse_address(s2, user2, mta2);//分割收件人
if (vis.count(s2))//重复的收件人
continue;
vis.insert(s2); if (!dest.count(mta2))
{
mta.push_back(mta2);
dest[mta2] = vector<string>();
}
dest[mta2].push_back(s2);
}
getline(cin, s2);//取数据前面的*的回车,第三个* string data;//正文数据
while (getline(cin, s2) && s2[] != '*')//第四个*
data += " " + s2 + "\n"; for (int i = ; i < mta.size(); i++)
{
string mta2;
mta2 = mta[i];
vector<string> users = dest[mta2];
cout << "Connection between " <<mta1 << " and " <<mta2 << endl;
cout << " HELO " << mta1 << "\n";
cout << "" << endl;
cout <<" MAIL FROM:<" <<s<< ">"<<endl;
cout << "" << endl; bool ok = false;
for (int j = ; j < users.size(); j++)
{
cout << " RCPT TO:<" << users[j] <<">"<< endl;
if (addr.count(users[j]))
{
ok = true;
cout << "" << endl;
}
else
cout << "" << endl;
}
if (ok)
{
cout << " DATA" << endl;
cout << "" << endl;
cout << data;
cout << " ."<<endl;
cout << "" << endl;
}
cout << " QUIT" << endl;
cout << "" << endl;
} } return ;
}

UVA 814 The Letter Carrier's Rounds的更多相关文章

  1. UVA 814 The Letter Carrier's Rounds(JAVA基础map)

    题解:就是按照题目模拟就好 但是这个题目让我发现了我Java里面许多问题 具体看代码,但是还是分为这几个方面 属性的作用域问题,缓冲区问题,map与list映射的问题,输出多个空格不一定是/t,反转思 ...

  2. The Letter Carrier's Rounds(摘)

    Description For an electronic mail application you are to describe the SMTP-based communication that ...

  3. UVa 814邮件传输代理的交互

    好吧,终于知道原来string有这么多用法,map可以通过vector来映射多个数 #include <iostream> #include <string> #include ...

  4. 紫书第5章 C++STL

    例题 例题5-1 大理石在哪儿(Where is the Marble?,Uva 10474) 主要是熟悉一下sort和lower_bound的用法 关于lower_bound: http://blo ...

  5. JAVA经典算法40题

    1: JAVA经典算法40题 2: [程序1] 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第四个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? 3 ...

  6. 紫书 习题8-14 UVa 1616(二分+小数化分数+精度)

    参考了https://www.cnblogs.com/dwtfukgv/p/5645446.html (1)直接二分答案.说实话我没有想到, 一开始以为是贪心, 以某种策略能得到最优解. 但是想了很久 ...

  7. 紫书 例题8-14 UVa 1607 (二分)

    题意非常难理解-- #include<cstdio> #define REP(i, a, b) for(int i = (a); i < (b); i++) using namesp ...

  8. 【习题 8-14 UVA - 1616】Caravan Robbers

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 二分长度. 显然长度越长.就越不可能. 二分的时候.可以不用管精度. 直接指定一个二分次数的上限就好. 判断长度是否可行.直接用贪心 ...

  9. uva 11520 - Fill the Square

    http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&p ...

随机推荐

  1. 【python】查找函数定义

    help(函数名) 举例:想知道gevnet.Timeout这个函数是怎么用的.help(gevent.Timeout). 之前不知道这样查,每次遇到新函数想知道有哪些参数我都要到网上疯狂查阅文档.现 ...

  2. XSS-HTML&javaSkcript&CSS&jQuery&ajax

    1.设置不同的样式列表 <style> ul.a{list-style-tyrp:circle;}    ul.b{list-style-type:square;}   ul.c{list ...

  3. 小学生都看得懂的C语言入门(3): 数组与函数

    #include <stdio.h> int main() { int x; ; ; scanf("%d",&x){ sum+=x; cnt++; scanf( ...

  4. CF979E

    非常好的dp,非常考dp的能力 很显然是个计数问题,那么很显然要么是排列组合,要么是递推,这道题很显然递推的面更大一些. 那么我们来设计一下状态: 设状态f[i][j][k][p]表示目前到了第i个点 ...

  5. axure--轮播图

    1.使用动态面板的循环实现图片轮播的要点:1)当鼠标移出动态面板的范围时才显示左右两边的方向按钮,否则该两个按钮都是隐藏的.则思路如下:且四个条件之间是“or”的关系,不是“and”[[Cursor. ...

  6. 饮冰三年-人工智能-linux-09 服务

    1:SSH服务(提供远程连接服务) 客户端使用Xshell 链接成功 加快连接速度 关闭防火墙 2:apache 服务(提供网页服务) 2.0 准备环境 关闭防火墙:service iptables ...

  7. SqlServer2012清除日志文件

    SqlServer在使用中会产生大量的日志文件,当不需要的时候可以进行删除. 删除方式: 右键数据库-->任务-->收缩-->文件 进入收缩文件页面,按照如下配置就可以了 有时候收缩 ...

  8. ssh-keygen -t rsa 生成密钥对后如何校验

    ssh-keygen -t rsa 生成密钥对后如何校验一下呢ssh-keygen -y -f id_rsa > id_rsa.pub.tobecompared 然后对比一下id_rsa.pub ...

  9. Angularjs 学习笔记-2017-02-05-初识Angular及app、model、controller、repeat指令和fileter、orderBy

    ng-app   定义作用域,从作用域处开始执行ng命令指令 ng-model 数据绑定字符,用于双向数据绑定 ng-controller ng控制台,定义function name($scope)来 ...

  10. 1.RN环境搭建,创建项目,使用夜神模拟调试

    1.环境搭建(Yarn.React Native 的命令行工具(react-native-cli)) npm install -g yarn react-native-cli 具体参考 参见官方(中文 ...