练习:ROT13

在此示例中,您将实现经典的 “ROT13”加密。将此代码复制到 Playground,并实现缺失的位。请仅旋转 ASCII 字母字符,以确保结果仍为有效的 UTF-8 编码字符。

  1. use std::io::Read;
  2. struct RotDecoder<R: Read> {
  3. input: R,
  4. rot: u8,
  5. }
  6. // Implement the `Read` trait for `RotDecoder`.
  7. fn main() {
  8. let mut rot =
  9. RotDecoder { input: "Gb trg gb gur bgure fvqr!".as_bytes(), rot: 13 };
  10. let mut result = String::new();
  11. rot.read_to_string(&mut result).unwrap();
  12. println!("{}", result);
  13. }
  14. #[cfg(test)]
  15. mod test {
  16. use super::*;
  17. #[test]
  18. fn joke() {
  19. let mut rot =
  20. RotDecoder { input: "Gb trg gb gur bgure fvqr!".as_bytes(), rot: 13 };
  21. let mut result = String::new();
  22. rot.read_to_string(&mut result).unwrap();
  23. assert_eq!(&result, "To get to the other side!");
  24. }
  25. #[test]
  26. fn binary() {
  27. let input: Vec<u8> = (0..=255u8).collect();
  28. let mut rot = RotDecoder::<&[u8]> { input: input.as_ref(), rot: 13 };
  29. let mut buf = [0u8; 256];
  30. assert_eq!(rot.read(&mut buf).unwrap(), 256);
  31. for i in 0..=255 {
  32. if input[i] != buf[i] {
  33. assert!(input[i].is_ascii_alphabetic());
  34. assert!(buf[i].is_ascii_alphabetic());
  35. }
  36. }
  37. }
  38. }

如果将两个 RotDecoder 实例链接在一起,每个实例旋转 13 个字符,会发生什么情况?