Skip to content

Latest commit

 

History

History

2496

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 

The value of an alphanumeric string can be defined as:

  • The numeric representation of the string in base 10, if it comprises of digits only.
  • The length of the string, otherwise.

Given an array strs of alphanumeric strings, return the maximum value of any string in strs.

 

Example 1:

Input: strs = ["alic3","bob","3","4","00000"]
Output: 5
Explanation: 
- "alic3" consists of both letters and digits, so its value is its length, i.e. 5.
- "bob" consists only of letters, so its value is also its length, i.e. 3.
- "3" consists only of digits, so its value is its numeric equivalent, i.e. 3.
- "4" also consists only of digits, so its value is 4.
- "00000" consists only of digits, so its value is 0.
Hence, the maximum value is 5, of "alic3".

Example 2:

Input: strs = ["1","01","001","0001"]
Output: 1
Explanation: 
Each string in the array has value 1. Hence, we return 1.

 

Constraints:

  • 1 <= strs.length <= 100
  • 1 <= strs[i].length <= 9
  • strs[i] consists of only lowercase English letters and digits.

Related Topics:
Array, String

Similar Questions:

Solution 1.

// OJ: https://leetcode.com/problems/maximum-value-of-a-string-in-an-array
// Author: github.com/lzl124631x
// Time: O(NS)
// Space: O(1)
class Solution {
public:
    int maximumValue(vector<string>& A) {
        int ans = 0;
        for (auto &s : A) {
            int i = 0, num = 0;
            for (; i < s.size() && isdigit(s[i]); ++i) num = num * 10 + s[i] - '0';
            ans = max(ans, i == s.size() ? num : (int)s.size());
        }
        return ans;
    }
};