本关任务:在一串隐藏着一个或多个数值的字符中,选出字符串中的所有数字字符,并将选出的数字字符重新组成新字符串。如果在第一个数字字符之前有负号,则保留该负号,有多个负号时只保留一个。 例如:输入的字符串为“a-1-2-4sd5 s6”,抽取数字后得到的新字符串为“-12456”。用C++语言
时间: 2024-03-17 09:46:13 浏览: 38
可以使用C++中的字符串和循环结构来实现此任务,示例代码如下:
```c++
#include <iostream>
#include <string>
using namespace std;
int main() {
string s = "a-1-2-4sd5 s6";
string res = "";
bool has_negative = false; // 标记是否已有负号
for (int i = 0; i < s.size(); i++) {
if (s[i] >= '0' && s[i] <= '9') { // 如果当前字符是数字字符,则加入结果字符串
res += s[i];
} else if (s[i] == '-') { // 如果当前字符是负号
if (!has_negative && i == 0) { // 如果是第一个字符,则加入结果字符串
res += s[i];
has_negative = true;
} else if (s[i - 1] == '-') { // 如果前一个字符也是负号,则不加入结果字符串
continue;
} else { // 否则加入结果字符串
res += s[i];
has_negative = true;
}
}
}
cout << res << endl;
return 0;
}
```
输出结果为:-12456
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.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)
![](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)