#include<iostream>
#include<memory.h>
#include<stack>
#include<string>
#include<cmath>
#include<map>
#include<algorithm>
#include<sstream>
#include<set>
#include<queue>

using namespace std;

//处理超链接部分
string processA(string text)
{
    int begin,end;
    for(int i=0;i<text.length();i++)
    {
        if(text[i]=='[')
        {
            string ch,link;
            bool chend=false;
            bool linkend=true;;
            begin=i;
            for(int j=i+1;j<text.length();j++)
            {
                if(text[j]==']')
                {
                    chend=true;
                    continue;
                }
                if(text[j]=='(')
                {
                    linkend=false;
                    continue;
                }
                if(text[j]==')')
                {
                    end=j;
                    break;
                }

                if(!chend)
                    ch+=text[j];
                if(!linkend)
                    link+=text[j];
            }
            string newstr="<a href=\""+link+"\">"+ch+"</a>";
            text.replace(begin,end-begin+1,newstr);
        }
    }
    return text;
}

//处理着重号部分
string processK(string text)
{
    int begin,end;
    for(int i=0;i<text.length();i++)
    {
        if(text[i]=='_')
        {
            begin=i;
            string k="";
            for(int j=i+1;j<text.length();j++)
            {
                if(text[j]=='_')
                {
                    end=j;
                    break;
                }
                k+=text[j];
            }
        string newstr="<em>"+k+"</em>";
        text.replace(begin,end-begin+1,newstr);
        }
    }
    return text;
}

//处理三种区块部分
void processQ(queue<string> &q,queue<string> &r)
{
    string front=q.front();
    if(front[0]=='*')
    {
        string newstr="<ul>\n";
        while(!q.empty())
        {
            string t=q.front();
            q.pop();
            int count=0;
            for(int i=0;i<t.length();i++)
            {
                if(t[i]==' '||t[i]=='*')
                    count++;
                else
                    break;
            }
            t.erase(0,count);
            t=processA(t);
            t=processK(t);
            t="<li>"+t+"</li>\n";
            newstr+=t;
        }
        newstr+="</ul>";
        r.push(newstr);
    }
    else if(front[0]=='#')
    {
        while(!q.empty())
        {
            string head=q.front();
        q.pop();
        head=processA(head);
        head=processK(head);
        int h=0;
        int space=0;
        for(int i=0;i<head.length();i++)
        {
            if(head[i]=='#')
                h++;
            else if(head[i]==' ')
                space++;
            else
                break;
        }
        head.erase(0,h+space);
        ostringstream s;
        s<<h;
        string H=s.str();
        head="<h"+H+">"+head+"</h"+H+">";
        r.push(head);
        }

    }
    else
    {
        string newstr="<p>";
        while(!q.empty())
        {
            string p = q.front();
            q.pop();
            p = processA(p);
            p = processK(p);
            if(!q.empty())
                p+="\n";
            newstr+=p;
        }
        newstr=newstr+"</p>";
        r.push(newstr);
    }
}

//读取和输出
int main()
{
    string line;
    queue<string> q;
    queue<string> r;
    while(getline(cin,line))
    {
        if(line=="")
        {
            if(q.empty())
                continue;
            else
                processQ(q,r);
            continue;
        }
        q.push(line);
    }
    if(!q.empty())
        processQ(q,r);
    while(!r.empty())
    {
        cout<<r.front()<<endl;;
        r.pop();
    }
    return 0;
}
     

(ccf)201703-3markdown的更多相关文章

  1. CCF CSP 201703

    CCF CSP 2017·03 做了一段时间的CCF CSP试题,个人感觉是这样分布的 A.B题基本纯暴力可满分 B题留心数据范围 C题是个大模拟,留心即可 D题更倾向于图论?(个人做到的D题基本都是 ...

  2. CCF考试

    第八次CCF考试记录 代码还不知道对不对,过两天出成绩. 成绩出来了,310分. 100+100+100+10+0: 考试13:27开始,17:30结束,提交第4题后不再答题,只是检查前四题的代码 第 ...

  3. CCF关于NOIP2014复赛报名的通知

    CCF关于NOIP2014复赛报名的通知   CCF NOIP2014复赛全部实行网上注册.报名.未通过网上报名的选手将不具备参赛和申诉资格. 系统注册须知: NOIP2014复赛注册时间:2014年 ...

  4. [CCF] Z字形扫描

    CCF Z字形扫描 感觉和LeetCode中的ZigZag还是有一些不一样的. 题目描述 在图像编码的算法中,需要将一个给定的方形矩阵进行Z字形扫描(Zigzag Scan).给定一个n×n的矩阵,Z ...

  5. [CCF] ISBN号码检测

    CCF ISBN号码检测 题目概述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如"x-xxx-xxxxx-x",其 ...

  6. CCF NOI系列活动

    NOI-全国青少年信息学奥林匹克竞赛全国青少年信息学奥林匹克竞赛(NOI)是国内信息学领域内面向中学生的最高水平的大赛,每省派经选拔产生的选手(其中一名是女选手)参加,NOI每年在不同的省市举行. N ...

  7. CCF考前注意几点

    1.数组最好保持初始化习惯,且检查数组初始化在循环内还是循环外,若在循环内需要对数组进行处理,则数组初始化必须放在for循环内. 2.for循环保持好习惯,用括号括起来,以免粗心. 3.if条件判断要 ...

  8. CCF真题之最优灌溉

    201412-4 问题描述 雷雷承包了很多片麦田,为了灌溉这些麦田,雷雷在第一个麦田挖了一口很深的水井,所有的麦田都从这口井来引水灌溉. 为了灌溉,雷雷需要建立一些水渠,以连接水井和麦田,雷雷也可以利 ...

  9. 《计算机问题求解》总结——2014年CCF计算机课程改革导教班(2014.07.11)

    一:引言     "心想事成".这是自己获得导教班学习机会的最佳概括.2013年年末学习李晓明老师的<人群与网络>课程:随后网络认识烟台大学贺利坚老师,了解到2013年 ...

  10. 2016年CCF第七次测试 俄罗斯方块

    //2016年CCF第七次测试 俄罗斯方块 // 这道小模拟题还是不错 // 思路:处理出输入矩阵中含1格子的行数和列数 // 再判是否有一个格子碰到底部,否则整体再往下移动一步,如果有一个格子不能移 ...

随机推荐

  1. Windows中的时区信息

    时区 Windows API 没有提供直接得到特定时区信息的功能,Windows 系统中的时区信息存储在注册表中下面的位置: HKEY_LOCAL_MACHINE     SOFTWARE      ...

  2. [Python] partial改变方法默认參数

    Python 标准库中 functools库中有非常多对方法非常有有操作的封装,partial Objects就是当中之中的一个,他是对方法參数默认值的改动. 以下就看下简单的应用測试. #!/usr ...

  3. had been doing 和had been done有什么差别

    had been doing 和had been done有什么差别 浏览 37114 次 1个回答 最佳答案 21Doreen 来自科学教育类芝麻团 推荐于2017-10-15   1.首先要区分h ...

  4. tiny4412 裸机程序 三、关闭看门狗和调用C程序【转】

    本文转载自:http://blog.csdn.net/eshing/article/details/37112779 一.原理说明 上是章中大家可能有会觉得奇怪,CPU不是有看门狗嘛?为什么CPU没有 ...

  5. 洛谷 P4149 [ IOI 2011 ] Race —— 点分治

    题目:https://www.luogu.org/problemnew/show/P4149 仍然是点分治: 不过因为是取 min ,所以不能用容斥,那么子树之间就必须分开算,记录桶时注意这个: 每次 ...

  6. JSP-Runoob:JSP 表单处理

    ylbtech-JSP-Runoob:JSP 表单处理 1.返回顶部 1. JSP 表单处理 我们在浏览网页的时候,经常需要向服务器提交信息,并让后台程序处理.浏览器中使用 GET 和 POST 方法 ...

  7. codeforces round #416 div2

    A:暴力模拟 #include<bits/stdc++.h> using namespace std; int a, b; int main() { scanf("%d%d&qu ...

  8. 使用js模拟ecshop元素挪移

    <!DOCTYPE html><html><head> <title>移动</title> <script src="jqu ...

  9. 阿拉伯数字1与英语字母l造成的代码bug

    <img src="./images/demo3/1a.png" /> <img src="./images/demo3/la.png" /& ...

  10. ZOJ3714JavaBeans

    #!/usr/bin/env python # encoding: utf-8 t = int(raw_input()) for i in range(t): n,k = [int(x) for x ...