Ⅰ 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]!='