當前位置:首頁 » 編程語言 » 字元串替換題目c語言
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

字元串替換題目c語言

發布時間: 2023-03-22 02:08:14

Ⅰ 一道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]!='')len++;
returnlen;
}

intfind(chara[],charb[],intidx){
intla=getLen(a),lb=getLen(b),t=la-lb,i,f;
for(;idx<=t;idx++){
f=0;
for(i=0;i<lb;i++){
if(a[idx+i]!=b[i]){f=1;break;}
}
if(f==0)returnidx;
}
return-1;
}

intmain(){
chara[1024],b[1024],cmp[1025];
inti=0,j,la,lc;
scanf("%s",a);
scanf("%s",cmp);
scanf("%s",b);

la=getLen(a);
lc=getLen(cmp);

j=0-lc;
while(1){
j=find(a,cmp,j+lc);
if(j==-1){
while(i<la){
printf("%c",a[i++]);
}
break;
}
for(;i<j;i++)printf("%c",a[i]);
i+=lc;
printf("%s",b);
}
printf(" ");
}

答題不易,如無疑問,覺得可以的話,採納一下

Ⅶ C語言問題 字元(串)替換

主要是for循環有問題,修改後的代碼:
#include <stdio.h>

#include <string.h>

int main()

{

char src[250], pattern[250], replace[250], dst[250];

int i, j, k, l, m=0;

int pattern_len, match_len;

gets( src );

gets( pattern );

gets( replace );

pattern_len = strlen( pattern );

// strcpy( dst, src );

for ( i = 0; src[i]; i++ )

{

for ( j = 0, k = i, match_len = 0; pattern[j]; j++, k++ )

{

if ( pattern[j] == src[k] )

{

match_len++;

}

else

{

match_len=0;

break;

}

}

if ( match_len == pattern_len )

{

// for ( k = 0; k < i; k++ )

// dst[k] = src[k];

for ( l = 0; replace[l]; m++, l++ )

dst[m] = replace[l];

// for ( l = i + match_len; src[l]; k++, l++ )

// dst[k] = src[l];

// dst[k] = '\0';

// break;

i+=match_len-1;

}

else

{

dst[m] = src[i];

m++;

}

}

dst[m]='\0';

puts( dst );

return 0;

}

Ⅷ c語言字元串替換題求助

著樣弄可以,茄升含只是你的fun函數有點小問題,導致使用了字元串中沒初始化的部分。
把fun稍微改了下,可以運行了:
void fun( char *a)
{
int m,n,i,j=0,t;
char b[81];
for(m=0;a[m]!='\0';m++); //求出字元串長度m
for(n=0;a[n]=='*';n++); //求出開頭星號數量n
for(i=n;i<m;i++) //從第一個非*字元開始,把a賦給b
b[j++]=a[i];
for(i=j;i<n+j;i++) //從b的末尾開始,添加n個*
b[i]='*';
for(t=0;t<i;t++) /笑橘/把處理好的字元串還給a
a[t]=b[t];
a[t]='\0'; //弄顫笑個結束符
}

Ⅸ C語言 字元替換問題

#include<stdlib.h>禪雀搜
#include<stdio.h>
#include<string.h>
int main()
{ int i,j,m,n;
int length;
char a[80];
gets(a);
length=strlen(a);

for(m=0;m<length;m++){
if(a[m]>='A' && a[m]<'Z')
a[m]=a[m]+1;
else if(a[m]=='Z'賀歷歲明)
a[m]='A';
}
for(n=0;n<m;n++)
{printf("%c",a[n]);
}
system("pause");
return 0;
}

Ⅹ c語言運用函數替換字元串中的數字求助大佬

#include <stdio.h>

#define N 80


/* 請在這里填寫答案 */

void f(char *c,char a)

{

for(;*c;c++)

if(*c>='0'&&*c<='9')

*c=a;

}


int main(void)

{

char c[N], a;

gets(c);

scanf("%c", &a);

f(c, a);

printf("%s", c);

return 0;

}