ccf-20170303--Markdown
我的想法如下图:

代码和题目如下:
问题描述
| 试题编号: | 201703-3 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| 试题名称: | Markdown | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| 时间限制: | 1.0s | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| 内存限制: | 256.0MB | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| 问题描述: |
问题描述
Markdown 是一种很流行的轻量级标记语言(lightweight markup language),广泛用于撰写带格式的文档。例如以下这段文本就是用 Markdown 的语法写成的:
这些用 Markdown 写成的文本,尽管本身是纯文本格式,然而读者可以很容易地看出它的文档结构。同时,还有很多工具可以自动把 Markdown 文本转换成 HTML 甚至 Word、PDF 等格式,取得更好的排版效果。例如上面这段文本通过转化得到的 HTML 代码如下所示: 本题要求由你来编写一个 Markdown 的转换工具,完成 Markdown 文本到 HTML 代码的转换工作。简化起见,本题定义的 Markdown 语法规则和转换规则描述如下: 输入格式
输入由若干行组成,表示一个用本题规定的 Markdown 语法撰写的文档。
输出格式
输出由若干行组成,表示输入的 Markdown 文档转换成产生的 HTML 代码。
样例输入
# Hello
Hello, world! 样例输出
<h1>Hello</h1>
<p>Hello, world!</p> 评测用例规模与约定
本题的测试点满足以下条件:
●本题每个测试点的输入数据所包含的行数都不超过100,每行字符的个数(包括行末换行符)都不超过100。 ●除了换行符之外,所有字符都是 ASCII 码 32 至 126 的可打印字符。 ●每行行首和行末都不会出现空格字符。 ●输入数据除了 Markdown 语法所需,内容中不会出现 `#`、`*`、`_`、`[`、`]`、`(`、`)`、`<`、`>`、`&` 这些字符。 ●所有测试点均符合题目所规定的 Markdown 语法,你的程序不需要考虑语法错误的情况。 每个测试点包含的语法规则如下表所示,其中“√”表示包含,“×”表示不包含。
提示
由于本题要将输入数据当做一个文本文件来处理,要逐行读取直到文件结束,C/C++、Java 语言的用户可以参考以下代码片段来读取输入内容。
|
#include<bits/stdc++.h>
using namespace std;
string Int_to_String(int n){
stringstream ss;
ss<<n;
return ss.str();
}
void Operator_Spec(string & s){
int flagEm=0;
int index;
while((index=s.find('_'))!=string::npos){
if(flagEm==0){
s.replace(index,1,"<em>");
flagEm=1;
}else{
s.replace(index,1,"</em>");
flagEm=0;
}
}
while(s.find("[")!=string::npos&&s.find("]")!=string::npos&&s.find("(")!=string::npos&&s.find(")")!=string::npos){
string text="",link="";
text=s.substr(s.find("[")+1,s.find("]")-s.find("[")-1);
link=s.substr(s.find("(")+1,s.find(")")-s.find("(")-1);
//<a href="Link">Text</a>
string href="<a href=\""+link+"\">"+text+"</a>";
s.replace(s.find("["),s.find(")")-s.find("[")+1,href);
}
}
int main(){
string temps="";
int flagUl=0;//标记是否出现ul例如列表
int flagP=0;//用于标记p段落
string result="";
string Total_Result="";
while(getline(cin,temps)){
if(temps!=""){
if(temps[0]=='#'){
int headerCount=0;
int i=0;
while(temps[i]=='#'){
i++;
}
headerCount=i;
result="<h"+Int_to_String(headerCount)+">";
while(temps[i]==' '){
i++;
}
result=result+temps.substr(i,temps.length()-i);
result+="</h"+Int_to_String(headerCount)+">";
}else if(temps[0]=='*'){
if(flagUl==0){
result+="<ul>\n";
flagUl=1;
}
int i=1;
while(temps[i]==' '){
i++;
}
result=result+"<li>"+temps.substr(i,temps.length()-i)+"</li>"+"\n";
}else{
//cout<<"flagP:"<<flagP<<endl;
if(flagP==0){
result+="<p>";
flagP=1;
}
result+=temps+"\n";
}
}else{
if(flagUl==0&&flagP==0){
Operator_Spec(result);
//Total_Result+=result;
cout<<result<<endl;
result="";
}else{
if(flagUl==1){
Operator_Spec(result);
//Total_Result=Total_Result+result+"</ul>";
cout<<result<<"</ul>"<<endl;
flagUl=0;
result="";
}
if(flagP==1){
result=result.substr(0,result.length()-1);
Operator_Spec(result);
//Total_Result=Total_Result+result+"</p>";
cout<<result+"</p>"<<endl;
flagP=0;
result="";
}
}
}
// temps="";
}
if(temps!=""){//最后还会遗留一个区块,不能忽略这种情况
if(temps[0]=='#'){
int headerCount=0;
int i=0;
while(temps[i]=='#'){
i++;
}
headerCount=i;
result="<h"+Int_to_String(headerCount)+">";
while(temps[i]==' '){
i++;
}
result=result+temps.substr(i,temps.length()-i);
result+="</h"+Int_to_String(headerCount)+">";
}else if(temps[0]=='*'){
if(flagUl==0){
result+="<ul>\n";
flagUl=1;
}
int i=1;
while(temps[i]==' '){
i++;
}
result=result+"<li>"+temps.substr(i,temps.length()-i)+"</li>"+"\n";
}else{
//cout<<"flagP:"<<flagP<<endl;
if(flagP==0){
result+="<p>";
flagP=1;
}
result+=temps+"\n";
}
}else{
if(flagUl==0&&flagP==0){
Operator_Spec(result);
//Total_Result+=result;
cout<<result<<endl;
result="";
}else{
if(flagUl==1){
Operator_Spec(result);
//Total_Result=Total_Result+result+"</ul>";
cout<<result<<"</ul>"<<endl;
flagUl=0;
result="";
}
if(flagP==1){
result=result.substr(0,result.length()-1);
Operator_Spec(result);
//Total_Result=Total_Result+result+"</p>";
cout<<result+"</p>"<<endl;
flagP=0;
result="";
}
}
}
//cin.get();
//cout<<Total_Result<<endl;
return 0;
}
ccf-20170303--Markdown的更多相关文章
- CCF 201703-3 Markdown
问题描述 试题编号: 201703-3 试题名称: Markdown 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 Markdown 是一种很流行的轻量级标记语言(lig ...
- 【CCF】 Markdown 模拟
#include<iostream> #include<cstdio> #include<string> #include<cstring> #incl ...
- CCF CSP 201703-3 Markdown
CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201703-3 Markdown 问题描述 Markdown 是一种很流行的轻量级标记语言(l ...
- markdown绘图插件----mermaid简介
作者:黄永刚 mermaid简介 当撰写文档的时候,对于流程图的生成大多使用Visio等繁重的工具,没有一种轻便的工具能够画图从而简化文档的编写,就像markdown那样. mermaid解决这个痛点 ...
- CCF计算机职业资格认证考试题解
CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF计算机职业资格认证考试题解 CCF计算机软件能力认证(简称CCF CSP认证)是CCF计算机职业资格认证系 ...
- CCF CSP 201703
CCF CSP 2017·03 做了一段时间的CCF CSP试题,个人感觉是这样分布的 A.B题基本纯暴力可满分 B题留心数据范围 C题是个大模拟,留心即可 D题更倾向于图论?(个人做到的D题基本都是 ...
- Markdown教程<2> mermaid图形绘制(1)
Markdown教程<2> mermaid图形绘制(1) 博客园中的markdown编辑器同时支持mermaid图表引擎与tex公式引擎,可以使用mermaid直接画出流程图,时序图,甘特 ...
- Markdown插入图表
链接:https://www.jianshu.com/p/3cf83d22dd3d Markdown图表语法 本文介绍如何用Markdown的mermaid等语法插入时序图.流程图.甘特图 如果是想学 ...
- CSDN中Markdown编辑器使用方法
Markdown编辑器 如果想学习如何使用Markdown编辑器, 可以仔细阅读这篇文章,了解一下Markdown的基本语法知识. 新的改变 CSDN中Markdown编辑器进行了一些功能拓展与语法支 ...
- 关于『进击的Markdown』:第四弹
关于『进击的Markdown』:第四弹 建议缩放90%食用 美人鱼(Mermaid)悄悄的来,又悄悄的走,挥一挥匕首,不留一个活口 又是漫漫画图路... 女士们先生们,大家好! 我们要接受Markd ...
随机推荐
- Shell脚本 | 健壮性测试之空指针检查
通过 "adb shell am start" 遍历安卓应用所有的 Activity,可以检查是否存在空指针的情况. 以下为梳理后的测试流程: 通过 apktool 反编译 apk ...
- U盘上安装Ubuntu系统 便捷式系统 - 赖大大
简单介绍: U盘可以作为电脑的磁盘使用,在U盘上安装Ubuntu系统,只要有电脑,就可以轻松打开自己的系统, 方便又快捷,非常适合出差工作,学习使用. 另外,插入U盘后,需要我们就入电脑的Blos模式 ...
- CSS兼容性(IE和Firefox)技巧
CSS对浏览器的兼容性有时让人很头疼,或许当你了解当中的技巧跟原理,就会觉得也不是难事,从网上收集了IE7,6与Fireofx的兼容性处理技巧并整理了一下.对于web2.0的过度,请尽量用xhtml格 ...
- Django 学习笔记(三) --- HTML 模版加载 css、js、img 静态文件
人生苦短 ~ Tips:仅适用于 Python 3+(反正差别不大,py2 改改也能用).因为据 Python 之父 Guido van Rossum 说会在 2020 年停止对 Python 2 的 ...
- Jquery闪烁提示特效
样式:.red{ border:1px solid #d00; background:#ffe9e8; color:#d00;} function shake(ele,cls,times){ var ...
- RBAC 权限设计(转载)
来源 :https://blog.csdn.net/rocher88/article/details/43190743 这是我在网上找的一些设计比较好的RBAC权限管理 不知道,像新浪.搜狐.网易.百 ...
- HDU2196(SummerTrainingDay13-D tree dp)
Computer Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Su ...
- canvas-2arcTo.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- html5新特性学习笔记
1.语义化标签兼容问题(语义化标签只支持ie8以上,不包括ie8) 解决方法一:该标签的css中加上display:block; 通过DOM的方式创建这个标签 document.createEleme ...
- JqGrid: paging int asp.net
https://www.codeproject.com/Articles/1118363/GridView-with-Server-Side-Filtering-Sorting-and-Pa http ...