zoukankan      html  css  js  c++  java
  • 字符串拷贝问题

    问题:把源字符串拷贝到目的字符串,如果指定关键字,则以该关键字结束(不包括关键字本身),如果拷贝失败,则得到空串。
    具体要求:实现如下函数原型SafeStrcpy2KeyWord(),并在代码中调用该函数实现上述功能。该函数的实现要考虑各种可能的参数取值,以确保程序不出现崩溃。

    int SafeStrcpy2KeyWord(char* pDestBuffer,    //拷贝的目的地地址

                   char* pSourceString,    //拷贝的源地址

                   int nDestBufferSize,    //拷贝的目的地缓冲区长度

                   char* szKeyWord);    //指定关键字符串


    返回值:所拷贝的字符串长度。如果拷贝失败,则返回0。

    Input
    输入包含多组数据,以EOF结束
    每组数据第一行为不含空格的源字符串,长度小于256;接下来的一行或多行都是关键字串(长度小于16),一直到END结束。“NULL”表示关键字串为空,此时输出的拷贝后的长度应为0,拷贝后的字符串为空串(也用”NULL”表示,见下文)。

    Output
    对于每组数据输出拷贝的长度和拷贝后的目的字符串,以空格分隔。如果该目的字符串为空,则用”NULL”表示。

    Sample Input
    /home/tony/work_server/1/rtest/relayer.out
    /
    /t
    /1/r
    .
    NULL
    END

    Sample Output
    0 NULL
    5 /home
    22 /home/tony/work_server
    38 /home/tony/work_server/1/rtest/relayer
    0 NULL

    回答:

    #include <iostream>
    #include <string>
    using namespace std;
    int SafeStrcpy2KeyWord(char* pDestBuffer, //拷贝的目的地地址
             char* pSourceString, //拷贝的源地址
             int nDestBufferSize, //拷贝的目的地缓冲区长度
             char* szKeyWord); //指定关键字符串

    int main() {
     freopen("in","r",stdin);
     char s1[300],s2[300],s3[300];
     int len;
     while(scanf("%s",s1) !=EOF)
     {
      while(scanf("%s",s2) && strcmp(s2,"END") != 0)
      {
       len = SafeStrcpy2KeyWord(s3,s1,300,s2);
       if(len == 0)
        printf("0 NULL/n");
       else
        printf("%d %s/n",len,s3);
      }
     }
     return 0;
    }


    int SafeStrcpy2KeyWord(char* pDestBuffer, //拷贝的目的地地址
             char* pSourceString, //拷贝的源地址
             int nDestBufferSize, //拷贝的目的地缓冲区长度
             char* szKeyWord) //指定关键字符串

    {
     if(nDestBufferSize == 0 || strcmp(szKeyWord,"NULL") == 0)
     {
      return 0;
     }
     char *k = strstr(pSourceString,szKeyWord);
     if(k == NULL)
     {
      strcpy(pDestBuffer,pSourceString);
      return strlen(pSourceString);
     }
     if(k-pSourceString==0|| k-pSourceString > nDestBufferSize)
     {
      return 0;
     }
     int i;
     for(i = 0;i < k-pSourceString; i++)
     {
      pDestBuffer[i] = pSourceString[i];
     }
     pDestBuffer[i] = 0;
     return i ;
    }

  • 相关阅读:
    tyvj1117 拯救ice-cream
    codevs3410 别墅房间
    codevs1099 字串变换
    codevs1226 倒水问题
    codevs2449 骑士精神
    codevs1225 八数码难题
    Wikioi 3776 生活大爆炸版石头剪子布
    codevs1197 Vigenère密码
    枚举 + exgcd
    C++ 排序引用的优化
  • 原文地址:https://www.cnblogs.com/benchao/p/4513571.html
Copyright © 2011-2022 走看看