Post

1448 Maximum 69 Number

1448 Maximum 69 Number

Maximum 69 Number image

You are given a positive integer num consisting only of digits 6 and 9.

Return the maximum number you can get by changing at most one digit (6* becomes 9, and 9 becomes 6)*.

 

Example 1:

1
2
3
4
5
6
7
8
9
10
**Input:** num = 9669
**Output:** 9969
**Explanation:** 
Changing the first digit results in 6669.
Changing the second digit results in 9969.
Changing the third digit results in 9699.
Changing the fourth digit results in 9666.
The maximum number is 9969.

Example 2:

1
2
3
4
5
**Input:** num = 9996
**Output:** 9999
**Explanation:** Changing the last digit 6 to 9 results in the maximum number.

Example 3:

1
2
3
4
5
**Input:** num = 9999
**Output:** 9999
**Explanation:** It is better not to apply any change.

 

Constraints:

1
2
1 <= num <= 104
num consists of only 6 and 9 digits.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23

impl Solution {
    pub fn maximum69_number (num: i32) -> i32 {
        // maybe change first 6 to 9
        let mut a = 0;
        for (i,k) in (num.to_string()).chars().enumerate() {
            if k == '6' {
                a = i;
                break;
            }
        }
        let mut owned_string: String = "".to_owned();
        owned_string.push_str(&(num.to_string())[..a]);
        owned_string.push_str("9");
        owned_string.push_str(&(num.to_string())[a+1..]);
        return (owned_string).parse::<i32>().unwrap();

    }
}



This post is licensed under CC BY 4.0 by the author.