zoukankan      html  css  js  c++  java
  • The Seven Percent Solution

    Problem Description
    Uniform Resource Identifiers (or URIs) are strings like http://icpc.baylor.edu/icpc/, mailto:foo@bar.org, ftp://127.0.0.1/pub/linux, or even just readme.txt that are used to identify a resource, usually on the Internet or a local computer. Certain characters are reserved within URIs, and if a reserved character is part of an identifier then it must be percent-encoded by replacing it with a percent sign followed by two hexadecimal digits representing the ASCII code of the character. A table of seven reserved characters and their encodings is shown below. Your job is to write a program that can percent-encode a string of characters.

    Character  Encoding
    " " (space)  %20
    "!" (exclamation point)  %21
    "$" (dollar sign)  %24
    "%" (percent sign)  %25
    "(" (left parenthesis)  %28
    ")" (right parenthesis)  %29
    "*" (asterisk)  %2a
     

    Input
    The input consists of one or more strings, each 1–79 characters long and on a line by itself, followed by a line containing only "#" that signals the end of the input. The character "#" is used only as an end-of-input marker and will not appear anywhere else in the input. A string may contain spaces, but not at the beginning or end of the string, and there will never be two or more consecutive spaces.
     

    Output
    For each input string, replace every occurrence of a reserved character in the table above by its percent-encoding, exactly as shown, and output the resulting string on a line by itself. Note that the percent-encoding for an asterisk is %2a (with a lowercase "a") rather than %2A (with an uppercase "A").
     

    Sample Input
    Happy Joy Joy!
    http://icpc.baylor.edu/icpc/
    plain_vanilla
    (**)
    ?
    the 7% solution
    #
     

    Sample Output
    Happy%20Joy%20Joy%21
    http://icpc.baylor.edu/icpc/
    plain_vanilla
    %28%2a%2a%29
    ?
    the%207%25%20solution
     

    #include<stdio.h>
    void main()
    {
        char a[1000];
        int n;
        while(1)
        {
            gets(a);
            //getchar();
            if(a[0]=='#')
                return;
            for(int j=0;a[j]!='';j++);
            j++; n=j;
            for(int i=0;a[i]!='';i++)
            {
                switch(a[i])
                {
                    case ' ' :
                        for(;j>i;j--)
                            a[j+2]=a[j];
                        a[i]='%';
                        a[i+1]='2';
                        a[i+2]='0';
                        i=i+2;
                        j=n=n+2;
                        break;
                    case '!':
                        for(;j>i;j--)
                            a[j+2]=a[j];
                        a[i]='%';
                        a[i+1]='2';
                        a[i+2]='1';
                        i=i+2;
                        j=n=n+2;
                        break;
                    case '$':
                        for(;j>i;j--)
                            a[j+2]=a[j];
                        a[i]='%';
                        a[i+1]='2';
                        a[i+2]='4';
                        i=i+2;
                        j=n=n+2;
                        break;
                    case '%':
                        for(;j>i;j--)
                            a[j+2]=a[j];
                        a[i]='%';
                        a[i+1]='2';
                        a[i+2]='5';
                        i=i+2;
                        j=n=n+2;
                        break;
                    case '(':
                        for(;j>i;j--)
                            a[j+2]=a[j];
                        a[i]='%';
                        a[i+1]='2';
                        a[i+2]='8';
                        i=i+2;
                        j=n=n+2;
                        break;
                    case ')':
                        for(;j>i;j--)
                            a[j+2]=a[j];
                        a[i]='%';
                        a[i+1]='2';
                        a[i+2]='9';
                        i=i+2;
                        j=n=n+2;
                        break;
                    case '*':
                        for(;j>i;j--)
                            a[j+2]=a[j];
                        a[i]='%';
                        a[i+1]='2';
                        a[i+2]='a';
                        i=i+2;
                        j=n=n+2;
                        break;
                }
            }
            printf("%s ",a);
        }
    }

  • 相关阅读:
    学习笔记1:性能问题在于你想不到的任何地方!
    React Native控件之PullToRefreshViewAndroid下拉刷新组件解说(20)
    CSDN-markdown编辑器之导入导出文档功能
    无名管道与有名管道通讯编程
    LeetCode Remove Nth Node From End of List
    libpcap出错信息调试函数pcap_geterr, pcap_perror
    工作流学习——Activiti流程实例、任务管理四步曲
    B
    oracle学习笔记 oracle软件安装和数据库的创建
    路由器逆向分析------MIPS系统网络的配置(QEMU)
  • 原文地址:https://www.cnblogs.com/zhaoxinshanwei/p/3500142.html
Copyright © 2011-2022 走看看