永利平台娱乐使用"zhong" 进行替换,由什么更加高

2020-01-05 19:23 来源:未知

#include <stdio.h>
//#include <string.h>
#include <string>

今天去面试,给了个题:
要求把字符串 “sdjaabcasdkk;3asd,abcadapabcadp” 中的 子串“abc”使用 “zhong” 替代得到一个新的字符串
看着这个好像挺简单的,竟然花了我好长时间!!真是郁闷

函数名: stpcpy
功  能: 拷贝一个字符串到另一个
用  法: char *stpcpy(char *destin, char *source);
程序例:

char* source = "sdabcs";

#include <stdio.h>
#include <string.h>

#include <stdio.h>
#include <string.h>

int main()
{
    std::string cc;
    char dec[100]={0};
    int i ;
    char *pstr = source,*pstr1=source;
    printf("%sn",source);

char *source = "sadaabcadadjalabcdd";

int main(void)
{
   char string[10];
   char *str1 = "abcdefghi";

    for (i=0;i<(strlen(source)-2);i++)
    {
        printf("%d,%sn",strncmp( pstr,"abc",3),pstr);
        if(!strncmp( pstr,"abc",3))
        {
            strcat(dec,"zhong");
            pstr += 2;
            pstr1 = pstr1+4;
        }
        else
        {
            dec[(pstr1-source)]=*pstr;
            dec[(pstr1-source)+1]=0;
        }
        pstr += 1;
        pstr1 = pstr1 + 1;
    }

int main()
{
    char dec[100] = {0};
    int i;
    char *pstr = source;
    char *pstr1 = dec;
    printf("%sn",source);

   stpcpy(string, str1);
   printf("%s/n", string);
   return 0;
}      

    
    printf("%sn",dec);
    return 0;
}

    for (i=0;i<(signed)strlen(source);i++)
    {
        if (0==strncmp(pstr,"abc",3))
        {
            strcat(dec,"zhong");
            pstr += strlen("abc");
            pstr1 += strlen("zhong");
        }
        else
        {
            dec[(pstr1-dec)] = *pstr;
            dec[(pstr1-dec)+1] = 0;
            pstr += 1;
            pstr1 += 1;
        }
    }

函数名: strcat
功  能: 字符串拼接函数
用  法: char *strcat(char *destin, char *source);
程序例:

 把字符串 中的子串 “abc” 使用"zhong" 进行替换

    printf("%sn",dec);
    return 0;

#include <string.h>
#include <stdio.h>

}
上面是我的答案,希望和大家一起探讨下,由什么更加高效的算法

int main(void)
{
   char destination[25];
   char *blank = " ", *c = "C++", *Borland = "Borland";

   strcpy(destination, Borland);
   strcat(destination, blank);
   strcat(destination, c);

   printf("%s/n", destination);
   return 0;
}      

函数名: strchr
功  能: 在一个串中查找给定字符的第一个匹配之处/
用  法: char *strchr(char *str, char c);
程序例:

#include <string.h>
#include <stdio.h>

int main(void)
 {
    char string[15];
    char *ptr, c = 'r';

    strcpy(string, "This is a string");
    ptr = strchr(string, c);
    if (ptr)
       printf("The character %c is at position: %d/n", c, ptr-string);
    else
       printf("The character was not found/n");
    return 0;
 }      

函数名: strcmp
功  能: 串比较
用  法: int strcmp(char *str1, char *str2);
看Asic码,str1>str2,返回值 > 0;两串相等,返回0
程序例:

#include <string.h>
#include <stdio.h>

int main(void)
 {
    char *buf1 = "aaa", *buf2 = "bbb", *buf3 = "ccc";
    int ptr;

    ptr = strcmp(buf2, buf1);
    if (ptr > 0)
       printf("buffer 2 is greater than buffer 1/n");
    else
       printf("buffer 2 is less than buffer 1/n");

    ptr = strcmp(buf2, buf3);
    if (ptr > 0)
       printf("buffer 2 is greater than buffer 3/n");
    else
       printf("buffer 2 is less than buffer 3/n");

    return 0;
 }      

函数名: strncmpi
功  能: 将一个串中的一部分与另一个串比较, 不管大小写
用  法: int strncmpi(char *str1, char *str2, unsigned maxlen);
程序例:

#include <string.h>
#include <stdio.h>

int main(void)
{
   char *buf1 = "BBB", *buf2 = "bbb";
永利平台娱乐,   int ptr;

   ptr = strcmpi(buf2, buf1);

   if (ptr > 0)
      printf("buffer 2 is greater than buffer 1/n");

   if (ptr < 0)
      printf("buffer 2 is less than buffer 1/n");

   if (ptr == 0)
      printf("buffer 2 equals buffer 1/n");

   return 0;
}      

函数名: strcpy
功  能: 串拷贝
用  法: char *strcpy(char *str1, char *str2);
程序例:

#include <stdio.h>
#include <string.h>

int main(void)
 {
    char string[10];
    char *str1 = "abcdefghi";

    strcpy(string, str1);
    printf("%s/n", string);
    return 0;
 }      

函数名: strcspn
功  能: 在串中查找第一个给定字符集内容的段
用  法: int strcspn(char *str1, char *str2);
程序例:

#include <stdio.h>
#include <string.h>
#include <alloc.h>

int main(void)
 {
    char *string1 = "1234567890";
    char *string2 = "747DC8";
    int length;

    length = strcspn(string1, string2);
    printf("Character where strings intersect is at position %d/n", length);

    return 0;
 }      

函数名: strdup
功  能: 将串拷贝到新建的位置处
用  法: char *strdup(char *str);
程序例:

#include <stdio.h>
#include <string.h>
#include <alloc.h>

int main(void)
 {
    char *dup_str, *string = "abcde";

    dup_str = strdup(string);
    printf("%s/n", dup_str);
    free(dup_str);

    return 0;
 }      

函数名: stricmp
功  能: 以大小写不敏感方式比较两个串
用  法: int stricmp(char *str1, char *str2);
程序例:

#include <string.h>
#include <stdio.h>

int main(void)
{
   char *buf1 = "BBB", *buf2 = "bbb";
   int ptr;

   ptr = stricmp(buf2, buf1);

   if (ptr > 0)
      printf("buffer 2 is greater than buffer 1/n");

   if (ptr < 0)
      printf("buffer 2 is less than buffer 1/n");

TAG标签:
版权声明:本文由永利平台娱乐发布于永利平台娱乐,转载请注明出处:永利平台娱乐使用"zhong" 进行替换,由什么更加高