LeetCode 3110.字符串的分数:模拟(注意一个小细节)

【LetMeFly】3110.字符串的分数:模拟(注意一个小细节)

力扣题目链接:https://leetcode.cn/problems/score-of-a-string/

给你一个字符串 s 。一个字符串的 分数 定义为相邻字符 ASCII 码差值绝对值的和。

请你返回 s分数

示例 1:
**输入:**s = "hello"

**输出:**13

解释:

s 中字符的 ASCII 码分别为:'h' = 104'e' = 101'l' = 108'o' = 111 。所以 s 的分数为 |104 - 101| + |101 - 108| + |108 - 108| + |108 - 111| = 3 + 7 + 0 + 3 = 13

示例 2:
**输入:**s = "zaz"

**输出:**50

解释:

s 中字符的 ASCII 码分别为:'z' = 122'a' = 97 。所以 s 的分数为 |122 - 97| + |97 - 122| = 25 + 25 = 50

提示:

  • 2 <= s.length <= 100
  • s 只包含小写英文字母。

解题方法:模拟

直接从第二个字符开始遍历字符串,将这个字符减去前一个字符的绝对值累加到答案中,最终返回即可。

注意:请谨慎使用8比特数减8比特数(如char - char或byte - byte),因为有的编程语言中8比特数相减不会类型提升转为int相减。

如下代码的运行结果为255和255:

go 复制代码
package main

import "fmt"

func main() {
	a := byte(1)
	b := byte(2)
	c := a - b
	fmt.Println(c)  // 255
	d := int(c)
	fmt.Println(d)  // 255
}
  • 时间复杂度 O ( l e n ( s ) ) O(len(s)) O(len(s))
  • 空间复杂度 O ( 1 ) O(1) O(1)

AC代码

C++
cpp 复制代码
/*
 * @Author: LetMeFly
 * @Date: 2025-03-15 10:26:54
 * @LastEditors: LetMeFly.xyz
 * @LastEditTime: 2025-03-15 10:27:59
 */
#ifdef _WIN32
#include "_[1,2]toVector.h"
#endif

class Solution {
public:
    int scoreOfString(string s) {
        int ans = 0;
        for (int i = 1; i < s.size(); i++) {
            ans += abs(s[i] - s[i - 1]);
        }
        return ans;
    }
};
Python
python 复制代码
'''
Author: LetMeFly
Date: 2025-03-15 10:28:26
LastEditors: LetMeFly.xyz
LastEditTime: 2025-03-15 10:28:50
'''
class Solution:
    def scoreOfString(self, s: str) -> int:
        return sum(abs(ord(s[i]) - ord(s[i - 1])) for i in range(1, len(s)))
Java
java 复制代码
/*
 * @Author: LetMeFly
 * @Date: 2025-03-15 10:36:15
 * @LastEditors: LetMeFly.xyz
 * @LastEditTime: 2025-03-15 10:36:23
 */
class Solution {
    public int scoreOfString(String s) {
        int ans = 0;
        for (int i = 1; i < s.length(); i++) {
            ans += Math.abs(s.charAt(i) - s.charAt(i - 1));
        }
        return ans;
    }
}
Go
go 复制代码
/*
 * @Author: LetMeFly
 * @Date: 2025-03-15 10:29:29
 * @LastEditors: LetMeFly.xyz
 * @LastEditTime: 2025-03-15 10:32:20
 */
package main

func abs3110(a int) int {
    if a < 0 {
        return -a
    }
    return a
}

func scoreOfString(s string) (ans int) {
    for i := 1; i < len(s); i++ {
        ans += abs3110(int(s[i]) - int(s[i - 1]))
    }
    return
}

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

千篇源码题解已开源

相关推荐
IT大白鼠11 分钟前
AIGC性能的关键瓶颈:算力、数据、算法三者如何互相制约?
算法·aigc
白雪茫茫1 小时前
监督学习、半监督学习、无监督学习算法详解
python·学习·算法·ai
FengyunSky1 小时前
浅析 空间频率响应 SFR 计算
算法
树下水月1 小时前
PHP 一种改良版的雪花算法
算法·php·dreamweaver
一只数据集2 小时前
全尺寸人形机器人灵巧手力觉触觉数据集-2908条ROSbag数据覆盖14大应用场景深度解析
大数据·人工智能·算法·机器人
罗西的思考3 小时前
【GUI-Agent】阿里通义MAI-UI 代码阅读(2)--- 实现
人工智能·算法·机器学习
刀法如飞4 小时前
TypeScript 数组去重的 20 种实现方式,哪一种你还不知道?
前端·javascript·算法
sali-tec5 小时前
C# 基于OpenCv的视觉工作流-章66-直线夹角
图像处理·人工智能·opencv·算法·计算机视觉
AC赳赳老秦5 小时前
接口测试自动化:用 OpenClaw 对接 Postman,实现批量回归测试、测试报告自动生成与推送
java·人工智能·python·算法·elasticsearch·deepseek·openclaw
_风满楼5 小时前
TDD实战-会议室冲突检测的红绿重构循环
前端·javascript·算法