當前位置:首頁 » 編程語言 » c語言編程s1和s2
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

c語言編程s1和s2

發布時間: 2023-02-21 10:15:39

c語言:編寫程序,將兩個字元串s1和s2連接起來。(求大神解答,麻煩請按提問中的格式回答,謝謝)

#include<stdio.h>

voidconj(char*p1,char*p2)
{
while(*p1)p1++;
while(*p2){*p1=*p2;p1++;p2++;}
*p1=0;
}

voidmain()
{
chars1[80],s2[80];
printf(" Inputastring:");gets(s1);
printf(" Inputastring:");gets(s2);
conj(s1,s2);
puts(s1);
}

Ⅱ C語言編程,有兩個字元串s1和s2,編寫程序判斷s1是否是s2的子串,是的話輸出s1在s2的起始位置,否則輸出-1

看代碼:

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

intis_sub_str(char*s1,char*s2)
{
intlen1=strlen(s1);
intlen2=strlen(s2);
if(len1>len2)
{
return-1;
}
inti=0,j=0;//i是s1的位置,j是s2的位置
while(j<len2-len1+1)
{
while(i<len1&&s1[i]==s2[j])
{
++i;
++j;
}
if(i==len1)
{
returnj-len1;
}
else
{
j=j-i+1;//到上次開始判斷字元的下一個字元
i=0;
}
}
return-1;
}
intmain(intargc,char**argv)
{
intr=is_sub_str("23","234567");
printf("%d ",r);

r=is_sub_str("23","abc123bc");
printf("%d ",r);

r=is_sub_str("223","22abc223");
printf("%d ",r);

r=is_sub_str("1234","23");
printf("%d ",r);

return0;
}

運行:

這是暴力法,但是從經驗來看一般情況下效率也不會很低。至於更高效的KMP 演算法,很難懂,可以自己找資料了解。

Ⅲ c語言編程輸入兩個字元串S1,S2,用指針實現將字元串S2的內容連接到S1的末尾.

這樣簡單解釋一下吧,前面都沒問題吧,就mystrcat函數裡面,你看它有兩個參數對吧,然後又定義了一個str,先讓str指向str1,用while循環輸出str1,輸出完後進入第二個while循環str繼續++ ,不過就把str2地址賦給它了,等於第二個while循環就輸出了str2。 思路夠清晰了吧。不懂再追問。

Ⅳ C語言:從鍵盤輸入兩個字元串s1與s2,並在s1串中的最大字元後邊插s2

//#include "stdafx.h"//vc++6.0加上這一行.
#include "stdio.h"
#include "string.h"
void main(void){
char s1[400]="",s2[400]="",mch;
int i,j,k,sub;
printf("Type a string...\ns1=");
gets(s1);
printf("Type another...\ns2=");
gets(s2);
for(mch=i=0;s1[i];i++)
if(mch<s1[i]){
sub=i;
mch=s1[i];
}
strcats2,s1+sub+1);
s1[sub+1]='\0';
strcat(s1,s2);
printf("The result is %s\n",s1);//Look at it.
}

Ⅳ C語言,比較兩個字元串S1和S2的大小

intmain()
{
chara1[100],a2[100];
inti;
printf("請輸入第一個字元串:");
gets(a1);
printf("請輸入第二個字元串:");
gets(a2);
for(i=0;a1[i]!=''||a2[i]!='';i++)
if(a1[i]!=a2[i])
break;
printf("比較結果:%d ",a1[i]-a2[i]);
getch();
return0;
}

祝你成功!

Ⅵ 用C語言編寫程序,輸入字元串s1和s2以及插入位置f,在字元串s1中的指定位置f處插入字元串s2

#include<stdio.h>
#include <string.h>
int main(void)
{

int i,a,b,f;
char s1[100],s2[100];
gets(s1);
gets(s2);
scanf("%d",&f);
a=strlen(s1);
b=strlen(s2);
for(i=0;i<f;i++)
printf("%c",s1[i]);
printf("%s",s2);
for(i=f;i<a;i++)
printf("%c",s1[i]);

return 0;
}