设s1和s2是用结点大小为1的单链表表示的 串,试用C语言写出找出s2中第一个不在s1中出现的字符的算法。
时间: 2024-10-25 15:12:25 浏览: 39
在C语言中,我们可以创建一个简单的算法来找到两个字符串(这里假设它们是一维字符数组或单链表)s2中第一个在s1中未出现的字符。以下是一种基于遍历的方式:
```c
#include <stdio.h>
#include <stdbool.h>
typedef struct Node {
char data;
struct Node* next;
} Node;
void printList(Node* list) {
while (list != NULL) {
printf("%c", list->data);
list = list->next;
}
}
// 查找s2中第一个在s1中不存在的字符
char findMissingChar(char* s1, char* s2) {
Node* s1_head = createLinkedList(s1);
Node* s2_head = createLinkedList(s2);
// 遍历s1
for (Node* s1_iter = s1_head; s1_iter != NULL; s1_iter = s1_iter->next) {
// 检查s2是否还有剩余元素
if (s2_head == NULL) {
return *s1_iter;
}
// 如果当前s1字符在s2中,则移动s2指针
while (*s2_head != *s1_iter && s2_head != NULL) {
s2_head = s2_head->next;
}
// 如果s2头到达了NULL,说明找到了一个不在s1中的字符
if (s2_head == NULL) {
break;
}
}
// 返回剩下的s2中的第一个字符,如果s1已经覆盖完s2则返回第一个字符
return *s2_head;
}
// 将字符串转换为单链表
Node* createLinkedList(char* str) {
Node* head = NULL;
for (char* ptr = str; *ptr != '\0'; ptr++) {
Node* newNode = (Node*)malloc(sizeof(Node));
newNode->data = *ptr;
newNode->next = head;
head = newNode;
}
return head;
}
int main() {
char s1[] = "hello";
char s2[] = "world!";
char missing_char = findMissingChar(s1, s2);
printf("The first character not in s1 is: %c\n", missing_char);
return 0;
}
```
在这个示例中,我们首先将两个输入字符串s1和s2转换成单链表,然后遍历s1,并检查每个字符是否也在s2中。如果在s2中找不到对应字符,我们就找到了第一个缺失的字符。
阅读全文