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