100399. 哈希分割字符串 显示英文描述

  1. 哈希分割字符串 显示英文描述
    通过的用户数1343
    尝试过的用户数1347
    用户总通过次数1359
    用户总提交次数1564
    题目难度Medium
    给你一个长度为 n 的字符串 s 和一个整数 k ,n 是 k 的 倍数 。你的任务是将字符串 s 哈希为一个长度为 n / k 的新字符串 result 。

首先,将 s 分割成 n / k 个 子字符串 ,每个子字符串的长度都为 k 。然后,将 result 初始化为一个 空 字符串。

我们依次从前往后处理每一个 子字符串 :

一个字符的 哈希值 是它在 字母表 中的下标(也就是 'a' → 0 ,'b' → 1 ,... ,'z' → 25)。

将子字符串中字幕的 哈希值 求和。

将和对 26 取余,将结果记为 hashedChar 。

找到小写字母表中 hashedChar 对应的字符。

将该字符添加到 result 的末尾。

返回 result 。

示例 1:

输入:s = "abcd", k = 2

输出:"bf"

解释:

第一个字符串为 "ab" ,0 + 1 = 1 ,1 % 26 = 1 ,result[0] = 'b' 。

第二个字符串为: "cd" ,2 + 3 = 5 ,5 % 26 = 5 ,result[1] = 'f' 。

示例 2:

输入:s = "mxz", k = 3

输出:"i"

解释:

唯一的子字符串为 "mxz" ,12 + 23 + 25 = 60 ,60 % 26 = 8 ,result[0] = 'i' 。

提示:

1 <= k <= 100

k <= s.length <= 1000

s.length 能被 k 整除。

s 只含有小写英文字母。

java 复制代码
class Solution {
    public String stringHash(String s, int k) {
        
        int n = s.length();
        StringBuilder re = new StringBuilder();
        for(int i = 0; i < n; i+=k){
            int sum = 0;
            String ss = s.substring(i,i+k);
            for(char c : ss.toCharArray()){
                sum += c - 'a';
            }
            re.append((char)('a' + (sum % 26)));
        }
        
        return re.toString();
    }
}
相关推荐
能工智人小辰几秒前
Codeforces Round 509 (Div. 2) C. Coffee Break
c语言·c++·算法
kingmax542120081 分钟前
CCF GESP202503 Grade4-B4263 [GESP202503 四级] 荒地开垦
数据结构·算法
岁忧6 分钟前
LeetCode 高频 SQL 50 题(基础版)之 【高级字符串函数 / 正则表达式 / 子句】· 上
sql·算法·leetcode
eachin_z1 小时前
力扣刷题(第四十九天)
算法·leetcode·职场和发展
闻缺陷则喜何志丹1 小时前
【强连通分量 缩点 拓扑排序】P3387 【模板】缩点|普及+
c++·算法·拓扑排序·洛谷·强连通分量·缩点
钮钴禄·爱因斯晨1 小时前
Java 面向对象进阶之多态:从概念到实践的深度解析
java·开发语言·数据结构
机器学习之心2 小时前
机器学习用于算法交易(Matlab实现)
算法·机器学习·matlab
AL流云。2 小时前
【优选算法】C++滑动窗口
数据结构·c++·算法
qq_429879673 小时前
省略号和可变参数模板
开发语言·c++·算法
飞川撸码4 小时前
【LeetCode 热题100】网格路径类 DP 系列题:不同路径 & 最小路径和(力扣62 / 64 )(Go语言版)
算法·leetcode·golang·动态规划