Ⅰ 一道c語言中關於字元串替換的題目,請大家幫忙看看
#include <stdio.h>
#include <前旅鍵string.h>
main()
{
int i,k=0;
char a[81],b[6]="input",*p,*q;
printf("input string:\n");
gets(a);
p=strstr(a,b);
while(*p!='\慧巧0')
{
q=a;
k=p-q;
a[k]='s';
a[k+1]='h';
a[k+2]='u'鎮猛;
a[k+3]='r';
a[k+4]='u';
p=strstr(a,b);
}
printf("%s \n",a);
}
Ⅱ 簡單的C語言字元串替換問題——
void
Substitute(char
*pInput,
char
*pOutput,
char
*pSrc,
char
*pDst)
{
char
*pi,
*po,
*p;
int
nSrcLen,
nDstLen,
nLen;
//
指向輸入字元串的游動指針.
pi
=
pInput;
//
指向輸出字元串的游動指針.
po
=
pOutput;
//
計算被替茄伏換串和替換串的長度.
nSrcLen
=
strlen(pSrc);
nDstLen
=
strlen(pDst);
//
查找pi指向字元串中第一次出現替換串的位置,並返回指針(找不慶李到則返回null).
p
=
strstr(pi,
pSrc);
if(p)
{
//
找到.
while(p)
{
//
計算被替換串前邊字元串的長度.
nLen
=
(int)(p
-
pi);
//
復制到輸出字元串.
memcpy(po,
pi,
nLen);
memcpy(po
+
nLen,
pDst,
nDstLen);
//
跳過被替換串.
pi
=
p
+
nSrcLen;
//
調整指向輸出串的指針位置.
po
=
po
+
nLen
+
nDstLen;
//
繼續查找.
p
=
strstr(pi,
pSrc);
}
//
復制剩餘字元串.
strcpy(po,
pi);
}
else
{
//
沒有找到則原樣復制.
strcpy(po,
pi);
}
}
其它地方自己譽納遲編吧
Ⅲ C語言字元串替換
C語言實現字元串替換函數:
#include <stdio.h>
#include <stdlib.h>
#include <ctype.h>
#include <string.h>
//字元串替換函數
/********************************************************************
* Function: my_strstr()
* Description: 在一個字元串中查找一個子串;
* Input: ps: 源; pd:子串
* Return : 0:源字元串中沒有子串; 1:源字元串中有子串;
*********************************************************************/
char * my_strstr(char * ps,char *pd)
{
char *pt = pd;
int c = 0;
while(*ps != '\0')
{
if(*ps == *pd)
{
while(*ps == *pd && *pd!='\0')
{
ps++;
pd++;
c++;
}
}else
{
ps++;
}
if(*pd == '\0')
{
return (ps - c);
}
c = 0;
pd = pt;
}
return 0;
}
/********************************************************************
* Function: memcpy()
* Description: 復制一個內存區域到另一個區域;
* Input: src: 源;
count: 復制位元組數.
* Output: dest: 復制目的地;
* Return : dest;
*********************************************************************/
void * memcpy(void * dest,const void *src,size_t count)
{
char *tmp = (char *) dest, *s = (char *) src;
while (count--)
*tmp++ = *s++;
return dest;
}
/********************************************************************
* Function: str_replace()
* Description: 在一個字元串中查找一個子串,並且把所有符合的子串用
另一個替換字元串替換。
* Input: p_source:要查找的母字元串; p_seach要查找的子字元串;
p_repstr:替換的字元串;
* Output: p_result:存放結果;
* Return : 返回替換成功的子串數量;
* Others: p_result要足夠大的空間存放結果,所以輸入參數都要以\0結束;
*********************************************************************/
int str_replace(char *p_result,char* p_source,char* p_seach,char *p_repstr)
{
int c = 0;
int repstr_leng = 0;
int searchstr_leng = 0;
char *p1;
char *presult = p_result;
char *psource = p_source;
char *prep = p_repstr;
char *pseach = p_seach;
int nLen = 0;
repstr_leng = strlen(prep);
searchstr_leng = strlen(pseach);
do{
p1 = my_strstr(psource,p_seach);
if (p1 == 0)
{
strcpy(presult,psource);
return c;
}
c++; //匹配子串計數加1;
printf("結果:%s\r\n",p_result);
printf("源字元:%s\r\n",p_source);
// 拷貝上一個替換點和下一個替換點中間的字元串
nLen = p1 - psource;
memcpy(presult, psource, nLen);
// 拷貝需要替換的字元串
memcpy(presult + nLen,p_repstr,repstr_leng);
psource = p1 + searchstr_leng;
presult = presult + nLen + repstr_leng;
}while(p1);
return c;
}
#define MAX 200
int main(void)
{
int i = 0;
char s[MAX] ={0}; //存放源字串
char s1[MAX]={0}; //存放子字串
char s2[MAX]={0}; //存放替換字串
char result_a[2000] = {0};//存放替換結果;
char *p,*ptm,*pr;
puts("Please input the string for s:");
scanf("%s",s);
puts("Please input the string for s1:");
scanf("%s",s1);
puts("Please input the string for s2:");
scanf("%s",s2);
ptm = s;
pr = result_a;
i = str_replace(pr,ptm,s1,s2);
printf("替換%d個子字元串;\r\n",i);
printf("替換後結果:%s\r\n",result_a);
system("pause");
}
Ⅳ c語言:如何將字元串中指定的字元替換為另一個指定字元
需要陪升吵准備的材料分別有:電腦、C語言編譯器笑洞。
1、首先,打開C語言編譯器,新建一個初始.cpp文件,例如:test.cpp。
Ⅳ c語言編程替換文件中字元串
方法和詳細的操作步驟如下:
1、第一步,依次單擊visual C ++ 6.0的「文件」-->「新建」-->「文件」-->「C++ Source File」選項,見下圖,轉到下面的步驟。
Ⅵ C語言字元串替換
效果圖:
#include<stdio.h>
intgetLen(chara[]){
intlen=0;
while(a[len]!='