C#从字符串中提取固定步长的子字符串

这篇具有很好参考价值的文章主要介绍了C#从字符串中提取固定步长的子字符串。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

C#从字符串中提取固定步长的子字符串

C#的Substring方法只能提取固定长度的子字符串,不能直接提取固定步长的子字符串。因此,我们需要自己编写一个方法来实现这个功能。

这个方法可以用于从字符串中提取固定步长的子字符串。例如,如果 str 是 "HelloWorld",finger 是 2,step 是 3,那么返回的数组将是 ["llo", "rld"]。

注意:
最后的子字符串可能小于步长,这里是保留存入字符串数组中的。
例如,如果 str 是 "HelloWorld",finger 是 0,step 是 3,那么返回的数组将是 ["He", "loW","orl","d"]。

使用重载方法时,可以指定起始位置和结束位置来提取子字符串。例如,如果 str 是 "HelloWorld",startIndex 是 2,endIndex 是 9,step 是 3,那么返回的数组将是 ["llo", "rld"]。

这个方法非常灵活,可以根据需要提取字符串的任意部分。例如,如果 str 是 "HelloWorld",startIndex 是 1,endIndex 是 8,step 是 2,那么返回的数组将是 ["el", "oW", "r"]。

使用该方法时,需要注意以下几点:文章来源地址https://www.toymoban.com/news/detail-749283.html

  • 步长必须是正数,否则会抛出异常。
  • 结束位置不能超过字符串的长度,否则会抛出异常。
  • 起始位置必须小于结束位置,否则返回一个空数组。
// 定义一个静态方法,接受一个字符串 str、一个整数 finger 和一个整数 step 作为参数
public static string[] StepSubstring(string str, int finger, int step)
{  
    // 计算从 finger 到字符串末尾的长度
    int len = str.Length - finger;  

    // 计算要提取的子字符串的数量。如果 len 可以被 step 整除,则子字符串的数量是 len / step,否则是 len / step + 1。
    int length = len % step == 0 ? len / step : len / step + 1;  

    // 创建一个字符串数组,用于存储提取的子字符串
    string[] substrings = new string[length];  

    // 使用 for 循环来提取子字符串并存储在 substrings 数组中
    for (int i = 0; i < length; i++)  
    {  
        // 计算当前子字符串的长度。如果 i 小于 length - 1 并且 finger + step 不超过字符串的长度,则子字符串的长度为 step,否则为 str.Length - finger。
        int substringLength = (i < length - 1 && finger + step <= str.Length) ? step : str.Length - finger;  

        // 使用 Substring 方法提取子字符串,并将其存储在 substrings 数组中的当前位置
        substrings[i] = str.Substring(finger, substringLength);  

        // 更新 finger 的值,以便下次迭代时提取下一个子字符串
        finger += step;  
    }  

    // 返回存储了所有提取的子字符串的数组
    return substrings;  
}

// 可以指定结束位置的重载方法
public static string[] StepSubstring(string str, int startIndex, int endIndex, int step)
{
    // 检查步长是否为正数
    if (step <= 0)
        throw new ArgumentException("Step must be a positive integer.", nameof(step));

    // 检查结束位置是否超过字符串长度
    if (endIndex > str.Length - 1)
        throw new ArgumentException("EndIndex cannot exceed the string length.", nameof(endIndex));

    // 检查起始位置是否大于等于结束位置
    if (startIndex >= endIndex)
        return Array.Empty<string>();

    // 计算要提取的子字符串的数量。如果 len 可以被 step 整除,则子字符串的数量是 len / step,否则是 len / step + 1。
    int len = endIndex - startIndex;
    int length = len % step == 0 ? len / step : len / step + 1;

    // 创建一个字符串数组,用于存储提取的子字符串
    string[] substrings = new string[length];

    // 使用 for 循环来提取子字符串并存储在 substrings 数组中
    for (int i = 0; i < length; i++)
    {
        // 计算当前子字符串的长度。如果 i 小于 length - 1 并且 startIndex + step 不超过 endIndex,则子字符串的长度为 step,否则为 endIndex - startIndex。
        int substringLength = (i < length - 1 && startIndex + step <= endIndex) ? step : endIndex - startIndex;

        // 使用 Substring 方法提取子字符串,并将其存储在 substrings 数组中的当前位置
        substrings[i] = str.Substring(startIndex, substringLength);

        // 更新 startIndex 的值,以便下次迭代时提取下一个子字符串
        startIndex += step;
    }

    // 返回存储了所有提取的子字符串的数组
    return substrings;
}

到了这里,关于C#从字符串中提取固定步长的子字符串的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 算法刷题-字符串-重复的子字符串

    KMP算法还能干这个 力扣题目链接 给定一个非空的字符串,判断它是否可以由它的一个子串重复多次构成。给定的字符串只含有小写英文字母,并且长度不超过10000。 示例 1: 输入: “abab” 输出: True 解释: 可由子字符串 “ab” 重复两次构成。 示例 2: 输入: “aba” 输出: False 示

    2024年02月09日
    浏览(35)
  • 【学会动态规划】环绕字符串中唯一的子字符串(25)

    目录 动态规划怎么学? 1. 题目解析 2. 算法原理 1. 状态表示 2. 状态转移方程 3. 初始化 4. 填表顺序 5. 返回值 3. 代码编写 写在最后: 学习一个算法没有捷径,更何况是学习动态规划, 跟我一起刷动态规划算法题,一起学会动态规划! 题目链接:467. 环绕字符串中唯一的子字

    2024年02月10日
    浏览(28)
  • (字符串 ) 459. 重复的子字符串——【Leetcode每日一题】

    难度:简单 给定一个非空的字符串 s ,检查是否可以通过由它的一个子串重复多次构成。 示例 1: 输入: s = “abab” 输出: true 解释: 可由子串 “ab” 重复两次构成。 示例 2: 输入: s = “aba” 输出: false 示例 3: 输入: s = “abcabcabcabc” 输出: true 解释: 可由子串 “abc” 重复四次构

    2024年02月07日
    浏览(35)
  • 重复的子字符串

    目录 1.题目描述 2.题目求解 方法一:枚举 方法二:字符串匹配 方法三:另辟蹊径 给定一个非空的字符串  s  ,检查是否可以通过由它的一个子串重复多次构成。 示例 1: 示例 2: 示例 3: 提示: 1 = s.length = 104 s  由小写英文字母组成 先看一下官方给的两种解法: 方法一:枚

    2024年02月01日
    浏览(30)
  • c 取字符串中的子串

    strcpy(S.ch,ch1) 赋值函数; 字符串没特殊处理,就是从0开始的 %s输出字符串,%c输出字符

    2024年02月07日
    浏览(28)
  • LeetCode 1358. 包含所有三种字符的子字符串数目

    滑动窗口的经典题型,直接套模板就行了。

    2024年03月14日
    浏览(45)
  • R语言【cli】——ansi_substr():ANSI彩色字符串的子字符串

    Package  cli  version 3.6.0 这是base::substr()的颜色感知副本。它的工作原理与原来的完全相同,但保留了子字符串中的颜色。在计算字符串中的位置时,忽略ANSI转义序列。 参数【x】 :字符向量,可能是ANSI样式的,或者是强制转换为字符的向量。 参数【start】 :起始索引或索引

    2024年01月22日
    浏览(36)
  • 剑指Offer48.最长不含重复字符的子字符串 C++

    请从字符串中找出一个最长的不包含重复字符的子字符串,计算该最长子字符串的长度。 示例 1 : 输入: “abcabcbb” 输出: 3 解释: 因为无重复字符的最长子串是 “abc”,所以其长度为 3。 示例 2 : 输入: “bbbbb” 输出: 1 解释: 因为无重复字符的最长子串是 “b”,所以其长度为

    2024年02月12日
    浏览(32)
  • LeetCode:459. 重复的子字符串 —【2、KMP算法】

    🍎道阻且长,行则将至。🍓 🌻算法,不如说它是一种思考方式🍀 算法专栏: 👉🏻123 题目描述 :给定一个非空的字符串 s ,检查是否可以通过由它的一个子串重复多次构成。 来源:力扣(LeetCode) 难度: 简单 提示: 1 = s.length = 104 s 由小写英文字母组成 示例 1: 输入:

    2024年02月04日
    浏览(44)
  • 【dp】不同的子序列 & 两个字符串的删除操作 & 编辑距离

    dp[i][j]:以j-1为结尾的t出现在以i-1为结尾的s子序列的个数 需要开辟m+1行,n+1列的二维数组 为啥状态方程是: s[i] == t[j] 时 dp[i][j] = dp[i-1][j-1] + dp[i-1][j] s[i] != t[j] 时 dp[i][j] = dp[i-1][j] 先看s[i] == t[j] 时,以s = “rara” t = “ra” 为例,当i = 3, j = 1时,s[i] == t[j] 此时分为2种情况:

    2023年04月15日
    浏览(30)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包