• 1410. HTML 实体解析器-力扣双百代码-简洁做法


    1410. HTML 实体解析器-力扣双百代码

    HTML 实体解析器」 是一种特殊的解析器,它将 HTML 代码作为输入,并用字符本身替换掉所有这些特殊的字符实体。

    HTML 里这些特殊字符和它们对应的字符实体包括:

    双引号:字符实体为 " ,对应的字符是 " 。
    单引号:字符实体为 ' ,对应的字符是 ' 。
    与符号:字符实体为 & ,对应对的字符是 & 。
    大于号:字符实体为 > ,对应的字符是 > 。
    小于号:字符实体为 < ,对应的字符是 < 。
    斜线号:字符实体为 ⁄ ,对应的字符是 / 。
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    给你输入字符串 text ,请你实现一个 HTML 实体解析器,返回解析器解析后的结果。

    示例 1:

    输入:text = “& is an HTML entity but &ambassador; is not.”
    输出:“& is an HTML entity but &ambassador; is not.”
    解释:解析器把字符实体 & 用 & 替换

    示例 2:

    输入:text = “and I quote: “…””
    输出:“and I quote: “…””

    示例 3:

    输入:text = “Stay home! Practice on Leetcode 😃”
    输出:“Stay home! Practice on Leetcode 😃”

    示例 4:

    输入:text = “x > y && x < y is always false”
    输出:“x > y && x < y is always false”

    示例 5:

    输入:text = “leetcode.com⁄problemset⁄all”
    输出:“leetcode.com/problemset/all”

    解题代码如下,正常去做就可以啦:

    char * entityParser(char * text){
        char a[6][8]={""","&apos","&",">","<","&frasl"};
        char b[6]={'"','\'','&','>','<','/'};
        int arr[6]={5,5,4,3,3,6};
        int i;
        // for(i=0;i<6;i++){
        //     printf("%s %c ",a[i],b[i]);
        // }
        int size=0;
        for(i=0;text[i]!='\0';i++){
            if(text[i]=='&'){
                int index=i;
                int j;
                for( j=0;j<6;j++){
                    int length=arr[j];
                    int k=0;
                    for( k=0;k<length;k++){
                        if(a[j][k]!=text[index+k]){
                            break;
                        }
                    }
                  //  printf("%d ",k);
                    if(k==length&&text[index+k]!='&'){
                        text[size++]=b[j];
                        i=i+length;
                        break;
    
                    }
                }
                if(j==6){
                    text[size++]=text[i];
    
                }
    
            }
            else{
                text[size++]=text[i];
            }
        }
        text[size]='\0';
       // printf("text --%s ",text);
    
    
        return text;
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
  • 相关阅读:
    蒙特卡洛树搜索(MCTS)详解
    学习Ant Design Charts的使用——修改案例
    还在封装 xxxForm,xxxTable 残害你的同事?试试这个工具
    从9.10拼多多笔试第四题产生的01背包感悟
    【渝偲】ICG-HSA,吲哚菁绿标记人血清白蛋白;ICG标记各种蛋白
    算法设计_综合练习_编程题
    小乌龟操作Git
    基于Python实现的合同管理系统设计
    Ubuntu上安装Anaconda
    2024 年天津专升本招生实施办法(天津专升本文化报名考试时间)
  • 原文地址:https://blog.csdn.net/weixin_43327597/article/details/125998519