在此递归最长回文查找器中,我的逻辑错误在哪里?

问题描述 投票:0回答:1

我的目标是返回字节数组中最长的回文。我的算法是:

  • 分支A

    • 从第一个字符到最后一个字符,该字符串是回文吗?如果是这样,则将其返回。
    • 如果不是,从第一个字符到第二个字符,该字符串是回文吗? ...
    • 如果不是,从第一个字符到最后一个字符,该字符串是回文吗? ...
    • ..
    • 剩下的字符数还不到2个吗?如果是这样,请转到分支A,但不要从第一个字符开始读取,而要从第二个字符开始检查。
    • ..
    • 剩下的字符数还不到2个吗?如果是这样,请转到分支A,但不要从第一个字符开始读取,而要从第三个字符开始检查。
    • ..
    • 剩下的字符数还不到2个吗?不返回`。

这个问题本质上是迭代的,但是该算法似乎不适用于我的迭代或递归解决方案。到目前为止,我已经明白了:

// slices are upper-bound exclusive
// return expressions are optionally implicit

fn is_palindrome(bytes: &[u8]) -> bool {
    if bytes.len() == 1 {
        true
    } else if bytes.len() == 2 {
        bytes[0] == bytes[1]
    } else if bytes[0] == bytes[bytes.len() - 1] {
        is_palindrome(&bytes[1..bytes.len() - 1])
    } else {
        false
    }
}

fn recurse_palindrome<'a>(s: &'a [u8], start: usize, end: usize) -> Option<&'a [u8]> {
    if start == end {
        if start == s.len() {
            None
        } else {
            // if start < s.len() - 1
            recurse_palindrome(&s, start + 1, s.len() - 1)
        }
    } else if is_palindrome(&s[start..end + 1]) {
        Some(&s[start..end + 1])
    } else {
        recurse_palindrome(&s, start, end - 1)
    }
}

pub fn longest_palindrome<'a>(s: &'a [u8]) -> Option<&'a [u8]> {
    recurse_palindrome(&s, 0, s.len() - 1)
}

// expected answers and tests
#[cfg(test)]
mod test {
    #[test]
    fn is_palindrome() {
        assert_eq!(super::is_palindrome(b"saas"), true); // ok
        assert_eq!(super::is_palindrome(b"ss"), true); // ok
    }

    #[test]
    fn longest_palindrome1() {
        assert_eq!(
            super::longest_palindrome(b"saasdbc").unwrap_or(b""),
            b"saas"
        ); // passes
    }

    #[test]
    fn longest_palindrome() {
        assert_eq!(
            super::longest_palindrome(b"ssaasdbc").unwrap_or(b""),
            b"saas"
        ); // fails; returns b"ss" instead of b"saas"
    }
}
algorithm recursion rust palindrome
1个回答
0
投票

此算法不起作用,因为它从左侧找到第一个回文,而不是最长的一个。

© www.soinside.com 2019 - 2024. All rights reserved.