Solve roman-to-integer.
This commit is contained in:
		
							parent
							
								
									bb5741755e
								
							
						
					
					
						commit
						83bb499e03
					
				| 
						 | 
					@ -2,5 +2,6 @@ pub mod implement_strstr;
 | 
				
			||||||
pub mod longest_common_prefix;
 | 
					pub mod longest_common_prefix;
 | 
				
			||||||
pub mod palindrome_number;
 | 
					pub mod palindrome_number;
 | 
				
			||||||
pub mod reverse_integer;
 | 
					pub mod reverse_integer;
 | 
				
			||||||
 | 
					pub mod roman_to_integer;
 | 
				
			||||||
pub mod two_sum;
 | 
					pub mod two_sum;
 | 
				
			||||||
pub mod valid_parenthesis;
 | 
					pub mod valid_parenthesis;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,44 @@
 | 
				
			||||||
 | 
					pub fn roman_to_int(string: String) -> i32 {
 | 
				
			||||||
 | 
					  let mut characters = string.chars().peekable();
 | 
				
			||||||
 | 
					  let mut number = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  while let Some(character) = characters.next() {
 | 
				
			||||||
 | 
					    let value = match character {
 | 
				
			||||||
 | 
					      'I' => 1,
 | 
				
			||||||
 | 
					      'V' => 5,
 | 
				
			||||||
 | 
					      'X' => 10,
 | 
				
			||||||
 | 
					      'L' => 50,
 | 
				
			||||||
 | 
					      'C' => 100,
 | 
				
			||||||
 | 
					      'D' => 500,
 | 
				
			||||||
 | 
					      'M' => 1000,
 | 
				
			||||||
 | 
					      _ => panic!("Unknown character: {character}"),
 | 
				
			||||||
 | 
					    };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if let Some(next) = characters.peek() {
 | 
				
			||||||
 | 
					      let subtract = match next {
 | 
				
			||||||
 | 
					        'V' | 'X' if character == 'I' => true,
 | 
				
			||||||
 | 
					        'L' | 'C' if character == 'X' => true,
 | 
				
			||||||
 | 
					        'D' | 'M' if character == 'C' => true,
 | 
				
			||||||
 | 
					        _ => false,
 | 
				
			||||||
 | 
					      };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      if subtract {
 | 
				
			||||||
 | 
					        number -= value;
 | 
				
			||||||
 | 
					        continue;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    number += value;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  number
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#[test]
 | 
				
			||||||
 | 
					fn test_roman_to_integer() {
 | 
				
			||||||
 | 
					  assert_eq!(roman_to_int("III".to_string()), 3);
 | 
				
			||||||
 | 
					  assert_eq!(roman_to_int("LVIII".to_string()), 58);
 | 
				
			||||||
 | 
					  assert_eq!(roman_to_int("MCMXCIV".to_string()), 1994);
 | 
				
			||||||
 | 
					  assert_eq!(roman_to_int("XX".to_string()), 20);
 | 
				
			||||||
 | 
					  assert_eq!(roman_to_int("DCXXI".to_string()), 621);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
		Loading…
	
		Reference in New Issue