solution.md 934 字节
Newer Older
每日一练社区's avatar
每日一练社区 已提交
1 2 3 4 5
# 不同子串

**题目描述**

一个字符串的非空子串是指字符串中长度至少为1 的连续的一段字符组成的串。  
每日一练社区's avatar
每日一练社区 已提交
6

每日一练社区's avatar
每日一练社区 已提交
7
例如,字符串aaab 有非空子串a, b, aa, ab, aaa, aab, aaab,一共7 个。  
每日一练社区's avatar
每日一练社区 已提交
8

每日一练社区's avatar
每日一练社区 已提交
9
注意在计算时,只算本质不同的串的个数。  
每日一练社区's avatar
每日一练社区 已提交
10 11

请问,字符串`0100110001010001`有多少个不同的非空子串?
每日一练社区's avatar
每日一练社区 已提交
12 13 14

以下程序实现了这一功能,请你补全空白处的内容:

每日一练社区's avatar
每日一练社区 已提交
15
```c
每日一练社区's avatar
每日一练社区 已提交
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33
#include <bits/stdc++.h>
using namespace std;

int main()
{
    set<string> s;
    string str;
    cin >> str;
    for (int i = 0; i < str.size(); i++)
        for (int j = i; j < str.size(); j++)
            __________________
    cout << s.size();
    return 0;
}
```


## 答案
每日一练社区's avatar
每日一练社区 已提交
34

每日一练社区's avatar
每日一练社区 已提交
35
```c
每日一练社区's avatar
每日一练社区 已提交
36 37
s.insert(str.substr(i, j - i + 1));
```
每日一练社区's avatar
每日一练社区 已提交
38

每日一练社区's avatar
每日一练社区 已提交
39 40 41
## 选项

### A
每日一练社区's avatar
每日一练社区 已提交
42

每日一练社区's avatar
每日一练社区 已提交
43
```c
每日一练社区's avatar
每日一练社区 已提交
44 45 46 47
s.insert(str.substr(i, j + i + 1));
```

### B
每日一练社区's avatar
每日一练社区 已提交
48

每日一练社区's avatar
每日一练社区 已提交
49
```c
每日一练社区's avatar
每日一练社区 已提交
50 51 52 53
s.insert(str.substr(i, j - i - 1));
```

### C
每日一练社区's avatar
每日一练社区 已提交
54

每日一练社区's avatar
每日一练社区 已提交
55
```c
每日一练社区's avatar
每日一练社区 已提交
56 57
s.insert(str.substr(i, j - i));
```