Часто на всяких сайтах, где предлагается решить разные задачи, встречается задача по определению, являются ли две строки изоморфными.
Две строки являются изоморфными, если они имеют одинаковую длину, символы одной строки можно заменить символами другой строки, каждый символ одной строки заменяется уникальным символом другой строки, и никакие два различных символа одной строки не заменяются одним и тем же символом другой строки.
Примеры изоморфных строк
egg и
add paper и
title.
Вот пример двух строк, которые не являются изоморфными
foo и
bar Для начала попробуйте написать самостоятельно соответствующую функцию на C, которая определяет, являются ли две строки изоморфными.
Я сам написал такую функцию, так как мне попался в поле зрения вопрос на сайте Stackoverflow, касающийся написания такой функции
Copying a character from one string argument to another in C Здесь я продублирую свое решение
#include <stdio.h>
#include <string.h>
#include <stdbool.h>
bool isIsomorphic( const char *s, const char *t )
{
size_t n = strlen( s );
bool isomorphic = n == strlen( t );
while ( isomorphic && n--)
{
const char *p1 = strchr( s + n + 1, s[n] );
const char *p2 = strchr( t + n + 1, t[n] );
isomorphic = ( !p1 && !p2 ) || ( p1 && p2 && p1 - s == p2 - t );
}
return isomorphic;
}
int main(void)
{
const char *s = "egg";
const char *t = "add";
printf( "\"%s\" is isomorphic with \"%s\" is %s\n",
s, t, isIsomorphic( s, t ) ? "true" : "false" );
s = "foo";
t = "bar";
printf( "\"%s\" is isomorphic with \"%s\" is %s\n",
s, t, isIsomorphic( s, t ) ? "true" : "false" );
s = "paper";
t = "title";
printf( "\"%s\" is isomorphic with \"%s\" is %s\n",
s, t, isIsomorphic( s, t ) ? "true" : "false" );
return 0;
}
Вывод программы на консоль
"egg" is isomorphic with "add" is true
"foo" is isomorphic with "bar" is false
"paper" is isomorphic with "title" is true