给你若干个字符串,请编程输出每个字符串的子串个数
时间: 2024-03-09 12:45:38 浏览: 33
以下是一个用 Python 编程输出若干个字符串子串个数的示例代码:
```python
def count_substrings(s):
subs = set()
for i in range(len(s)):
for j in range(i + 1, len(s) + 1):
sub = s[i:j]
subs.add(sub)
return len(subs)
strings = ["hello", "world", "programming", "language"]
for s in strings:
print(f"{s} has {count_substrings(s)} substrings.")
```
该程序定义了一个 `count_substrings` 函数,该函数接受一个字符串参数,并返回该字符串的子串数量。在函数内部,我们使用嵌套循环来遍历字符串中的所有子串,并将它们添加到一个集合中。由于集合只包含唯一元素,因此最后我们返回集合的大小作为子串数量。
在主程序中,我们使用一个字符串列表 `strings` 存储了若干个字符串,然后用一个循环遍历每个字符串,分别计算它们的子串数量并输出到控制台。计算子串数量的方法与前面的示例代码相同,即使用嵌套循环遍历字符串中的所有子串,并将它们添加到一个集合中,最后返回集合的大小。
注意,在实际应用中,如果字符串数量较大或字符串长度较长,计算子串数量的时间复杂度可能会很高,因此可能需要优化算法或使用并行计算等技术来加速计算过程。
相关推荐
![docx](https://img-home.csdnimg.cn/images/20210720083331.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![ppt](https://img-home.csdnimg.cn/images/20210720083527.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![application/msword](https://img-home.csdnimg.cn/images/20210720083327.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![doc](https://img-home.csdnimg.cn/images/20210720083327.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)