列表

详情


2268. 最少按键次数

你有一个 9 键键盘,按键按 1 到 9 编号,每个按键对应着几个英文小写字母。你可以决定每个按键对应哪些英文字母,但要满足如下条件:

如果想打出按键上的第一个字母,只需要按一次。如果想打出按键上的第二个字母,则需要按两次,依次类推。

给你一个字符串 s ,返回基于你设计的键盘打出 s 需要的 最少 按键次数。

注意:字母映射到每个按键上,映射的顺序无法进行更改。

 

示例 1 :

输入:s = "apple"
输出:5
解释:上图所示为设置键盘的最佳方法之一。
按按键 1 一次输入 'a' 。
按按键 6 一次输入 'p' 。
按按键 6 一次输入 'p' 。
按按键 5 一次输入 'l' 。
按按键 3 一次输入 'e' 。
总共按按键 5 次,所以返回 5 。

示例 2 :

输入:s = "abcdefghijkl"
输出:15
解释:上图所示为设置键盘的最佳方法之一。
字母 'a' 到 'i' 每个只需要按一次按键。
按按键 1 两次输入 'j' 。
按按键 2 两次输入 'k' 。
按按键 3 两次输入 'l' 。
总共按按键 15 次,所以返回 15 。

 

提示:

原站题解

去查看

上次编辑到这里,代码来自缓存 点击恢复默认模板
class Solution { public: int minimumKeypresses(string s) { } };

golang 解法, 执行用时: 4 ms, 内存消耗: 3.9 MB, 提交时间: 2023-10-21 20:12:35

func minimumKeypresses(s string) int {
	alp := make([]int, 26)
	for i := 0; i < len(s); i++ {
		alp[s[i]-'a']++
	}
	sort.Ints(alp)
	ans := 0
	for i := 25; i >= 0; i-- {
		if alp[i] == '0' {
			break
		}
		if (26-i)%9 == 0 {
			ans += alp[i] * ((26 - i) / 9)
		} else {
			ans += alp[i] * ((26-i)/9 + 1)
		}
	}
	return ans
}

rust 解法, 执行用时: 0 ms, 内存消耗: 2 MB, 提交时间: 2023-10-21 20:12:08

impl Solution {
    pub fn minimum_keypresses(s: String) -> i32 {
        let mut cnt = s
            .bytes()
            .fold([0;26], |mut mp, c| {
                mp[c as usize - 'a' as usize] += 1;
                mp
            });

        cnt.sort_by(|a, b| b.cmp(&a));

        cnt 
            .into_iter()   
            .enumerate()
            .fold(0, |acc, (i, v)| {
                if i < 9 {
                    acc + v
                } else if i < 18 {
                    acc + 2 * v
                } else {
                    acc + 3 * v
                }
            })
    }
}

cpp 解法, 执行用时: 16 ms, 内存消耗: 9 MB, 提交时间: 2023-10-21 20:11:45

class Solution {
public:
    int minimumKeypresses(string s) {
        vector<int> vec(26);
        for(char c: s) vec[c - 'a']++; // 计数
        sort(vec.rbegin(), vec.rend()); // 从大到小排序
        partial_sum(vec.begin(), vec.end(), vec.begin()); // 做前缀和方便计算
        return vec[8] + (vec[17] - vec[8]) * 2 + (vec[25] - vec[17]) * 3;
    }
};

python3 解法, 执行用时: 64 ms, 内存消耗: 16.6 MB, 提交时间: 2023-10-21 20:11:22

class Solution:
    def minimumKeypresses(self, s: str) -> int:
        counter=collections.Counter(s)
        sorted_counter = sorted(counter.items(), key=lambda kv: kv[1], reverse=True)
        #print(sorted_counter)
        res=0

        for i, ele in enumerate(sorted_counter):
            res+=(i//9+1)*ele[1]

        return res

上一题