c语言编写程序输入两行字符串s和t(s和t最长含50个字符,可以含有空格),将s串中首次与t匹配的子串逆置,并将结果输出。 【输入文件】输入文件为invertsub.in,含有两行字符串s和t,分别以#作为串结束符。 【输出文件】输出文件invertsub.out只有一行,包含一个串,是要求的输出结果。在行末也要有一个回车符。 【输入样例】helloworld# llowor# 【输出样例】herowollld 【样例说明】helloworld和llowor中重复的子串为llowor,逆置后结果为herowollld
时间: 2024-02-25 11:54:56 浏览: 75
好的,根据您的要求,我已经理解了您的问题。这是一个字符串反转的问题。可以使用C语言的字符串库函数来实现。以下是代码示例:
```c
#include <stdio.h>
#include <string.h>
int main() {
char s[51], t[51];
scanf("%[^#]#%[^#]#", s, t); // 读入字符串s和t
char *p = strstr(s, t); // 在s中查找t
if (p != NULL) { // 如果找到了t
char sub[51];
strncpy(sub, s, p - s); // 将t之前的子串拷贝到sub中
sub[p - s] = '\0'; // 确保sub以'\0'结尾
int len = strlen(t);
char *q = p + len; // q指向t之后的子串
char temp;
for (int i = 0; i < len / 2; i++) { // 反转t
temp = t[i];
t[i] = t[len - i - 1];
t[len - i - 1] = temp;
}
printf("%s%s%s\n", sub, t, q); // 输出结果
}
return 0;
}
```
这段代码首先读入两个字符串s和t,然后在s中查找t,如果找到了t,就将t之前的子串拷贝到sub中,然后反转t,最后输出结果。注意,这里使用了scanf函数的格式化输入,可以读入包含空格的字符串。同时,为了确保字符串以'\0'结尾,可以使用strncpy函数将子串拷贝到sub中,并手动添加'\0'。
阅读全文