在一个字符串中找到一个回文词,然后在 C 中重写它们

Find a palindrome words in a string and then rewrite them, in C

嗨,我如何用 C 编写代码来检查字符串中的回文,然后重写它们? 例如:string> "awbiue abdba aebto leoel", 应该 return "abdba leoel".

我写了这段代码,但是只能发现字符串是不是回文:

#include<stdlib.h>
#include<string.h>

int main()
{
char str[100];

printf("Enter string: ");
gets(str);
 int f=1;

{

for(int i=0;i<strlen(str); i++)
{
    if(str[i]!=str[strlen(str)-i-1])
    {
        f=0;  break;
    }
}
if(f==1)
    printf("Palindrom");
else
    printf("Not Palindrom");}
return 0;
}

你只需要一个字符串一个字符串地读取,确定它们是否是回文,如果是,则将它们打印出来——这就是我在以下代码中所做的:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int main()
{
    char str[100];
    printf("Enter string: ");
    while(scanf("%s", str) == 1) { // read strings one by one in the str variable
        //your code part
        int f=1;

        for(int i=0;i<strlen(str); i++)
        {
            if(str[i]!=str[strlen(str)-i-1])
            {
                f=0;  break;
            }
        }
        if(f==1) // that means that string is palindrome
            printf("%s ", str); // print the string and a space

    }
    return 0;
}