返回介绍

solution / 1800-1899 / 1876.Substrings of Size Three with Distinct Characters / README

发布于 2024-06-17 01:03:13 字数 2635 浏览 0 评论 0 收藏 0

1876. 长度为三且各字符不同的子字符串

English Version

题目描述

如果一个字符串不含有任何重复字符,我们称这个字符串为  字符串。

给你一个字符串 s ,请你返回 s 中长度为 3 的 好子字符串 的数量。

注意,如果相同的好子字符串出现多次,每一次都应该被记入答案之中。

子字符串 是一个字符串中连续的字符序列。

 

示例 1:

输入:s = "xyzzaz"
输出:1
解释:总共有 4 个长度为 3 的子字符串:"xyz","yzz","zza" 和 "zaz" 。
唯一的长度为 3 的好子字符串是 "xyz" 。

示例 2:

输入:s = "aababcabc"
输出:4
解释:总共有 7 个长度为 3 的子字符串:"aab","aba","bab","abc","bca","cab" 和 "abc" 。
好子字符串包括 "abc","bca","cab" 和 "abc" 。

 

提示:

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

解法

方法一

class Solution:
  def countGoodSubstrings(self, s: str) -> int:
    count, n = 0, len(s)
    for i in range(n - 2):
      count += s[i] != s[i + 1] and s[i] != s[i + 2] and s[i + 1] != s[i + 2]
    return count
class Solution {
  public int countGoodSubstrings(String s) {
    int count = 0, n = s.length();
    for (int i = 0; i < n - 2; ++i) {
      char a = s.charAt(i), b = s.charAt(i + 1), c = s.charAt(i + 2);
      if (a != b && a != c && b != c) {
        ++count;
      }
    }
    return count;
  }
}
function countGoodSubstrings(s: string): number {
  const n: number = s.length;
  let count: number = 0;
  for (let i: number = 0; i < n - 2; ++i) {
    let a: string = s.charAt(i),
      b: string = s.charAt(i + 1),
      c: string = s.charAt(i + 2);
    if (a != b && a != c && b != c) {
      ++count;
    }
  }
  return count;
}
class Solution {
  /**
   * @param String $s
   * @return Integer
   */
  function countGoodSubstrings($s) {
    $cnt = 0;
    for ($i = 0; $i < strlen($s) - 2; $i++) {
      if ($s[$i] != $s[$i + 1] && $s[$i] != $s[$i + 2] && $s[$i + 1] != $s[$i + 2]) {
        $cnt++;
      }
    }
    return $cnt++;
  }
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文