给定一组正整数,相邻的整数之间将会进行浮点除法操作。例如, [2,3,4] -> 2 / 3 / 4 。
但是,你可以在任意位置添加任意数目的括号,来改变算数的优先级。你需要找出怎么添加括号,才能得到最大的结果,并且返回相应的字符串格式的表达式。你的表达式不应该含有冗余的括号。
示例:
输入: [1000,100,10,2] 输出: "1000/(100/10/2)" 解释: 1000/(100/10/2) = 1000/((100/10)/2) = 200 但是,以下加粗的括号 "1000/((100/10)/2)" 是冗余的, 因为他们并不影响操作的优先级,所以你需要返回 "1000/(100/10/2)"。 其他用例: 1000/(100/10)/2 = 50 1000/(100/(10/2)) = 50 1000/100/10/2 = 0.5 1000/100/(10/2) = 2
说明:
- 输入数组的长度在 [1, 10] 之间。
- 数组中每个元素的大小都在 [2, 1000] 之间。
- 每个测试用例只有一个最优除法解。
贪心。
要使得除法的结果最大,分子应该尽可能大,而分母应该尽可能小。
分子最大应该是 nums[0]
,而分母最大是 nums[1] / nums[2] / ... / nums[n - 1]
,此时的除法结果最大。
class Solution:
def optimalDivision(self, nums: List[int]) -> str:
n = len(nums)
if n == 1:
return str(nums[0])
if n == 2:
return f'{nums[0]}/{nums[1]}'
return f'{nums[0]}/({"/".join(map(str, nums[1:]))})'
class Solution {
public String optimalDivision(int[] nums) {
int n = nums.length;
if (n == 1) {
return nums[0] + "";
}
if (n == 2) {
return nums[0] + "/" + nums[1];
}
StringBuilder ans = new StringBuilder(nums[0] + "/(");
for (int i = 1; i < n - 1; ++i) {
ans.append(nums[i] + "/");
}
ans.append(nums[n - 1] + ")");
return ans.toString();
}
}
class Solution {
public:
string optimalDivision(vector<int>& nums) {
int n = nums.size();
if (n == 1) return to_string(nums[0]);
if (n == 2) return to_string(nums[0]) + "/" + to_string(nums[1]);
string ans = to_string(nums[0]) + "/(";
for (int i = 1; i < n - 1; i++) ans.append(to_string(nums[i]) + "/");
ans.append(to_string(nums[n - 1]) + ")");
return ans;
}
};
func optimalDivision(nums []int) string {
n := len(nums)
if n == 1 {
return strconv.Itoa(nums[0])
}
if n == 2 {
return fmt.Sprintf("%d/%d", nums[0], nums[1])
}
ans := &strings.Builder{}
ans.WriteString(fmt.Sprintf("%d/(", nums[0]))
for _, num := range nums[1 : n-1] {
ans.WriteString(strconv.Itoa(num))
ans.WriteByte('/')
}
ans.WriteString(fmt.Sprintf("%d)", nums[n-1]))
return ans.String()
}
function optimalDivision(nums: number[]): string {
const n = nums.length;
const res = nums.join('/');
if (n > 2) {
const index = res.indexOf('/') + 1;
return `${res.slice(0, index)}(${res.slice(index)})`;
}
return res;
}
impl Solution {
pub fn optimal_division(nums: Vec<i32>) -> String {
let n = nums.len();
match n {
1 => nums[0].to_string(),
2 => nums[0].to_string() + "/" + &nums[1].to_string(),
_ => {
let mut res = nums[0].to_string();
res.push_str("/(");
for i in 1..n {
res.push_str(&nums[i].to_string());
res.push('/');
}
res.pop();
res.push(')');
res
}
}
}
}