设s、t 为两个字符串,两个字符串分为两行输出,判断t 是否为s 的子串。如果是,输出子串所在位置(第一个字符,字符串的起始位置从0开始),否则输出-1用c语言实现
时间: 2023-11-20 14:57:58 浏览: 81
以下是使用C语言实现判断t是否为s的子串的代码:
```c
#include <stdio.h>
#include <string.h>
int main() {
char s[1000], t[1000];
fgets(s, 1000, stdin);
fgets(t, 1000, stdin);
int s_len = strlen(s);
int t_len = strlen(t);
// 去除字符串s和t中的换行符
if (s[s_len - 1] == '\n') {
s[s_len - 1] = '\0';
s_len--;
}
if (t[t_len - 1] == '\n') {
t[t_len - 1] = '\0';
t_len--;
}
int i, j;
for (i = 0; i <= s_len - t_len; i++) {
for (j = 0; j < t_len; j++) {
if (s[i + j] != t[j]) {
break;
}
}
if (j == t_len) {
printf("%d\n", i);
return 0;
}
}
printf("-1\n");
return 0;
}
```
该程序使用 `fgets` 函数读取两个字符串,然后使用双重循环判断字符串t是否为字符串s的子串。如果是子串,就输出子串所在位置;否则输出-1。
阅读全文