c++输入一个字符串输出倒数第三个字符用string
时间: 2023-07-19 15:10:15 浏览: 190
可以使用 `string` 类型的 `substr()` 方法来获取一个字符串中的子串。例如,以下是一个示例代码,用于输入一个字符串并输出倒数第三个字符:
```c++
#include <iostream>
#include <string>
using namespace std;
int main() {
string str;
cout << "请输入一个字符串:";
cin >> str;
if (str.length() >= 3) {
string sub_str = str.substr(str.length() - 3, 1);
cout << "倒数第三个字符是:" << sub_str << endl;
} else {
cout << "字符串长度不足三个字符!" << endl;
}
return 0;
}
```
在上面的代码中,我们首先使用 `cin` 输入一个字符串,并且判断字符串长度是否大于等于 3。如果是,我们使用 `substr()` 方法来获取倒数第三个字符,然后输出结果;否则,我们输出一条错误信息。
相关问题
C++把一个字符串strfilename倒数十八位到倒数三位取出到字符串strpici里
可以使用 C++ 中的 `substr` 函数来实现:
```cpp
string strfilename = "这里是你的文件名字符串";
string strpici = strfilename.substr(strfilename.length() - 18, 15);
```
其中,`substr` 函数接受两个参数,第一个参数为子串的起始位置,第二个参数为子串的长度。因此,`strfilename.length() - 18` 表示起始位置为字符串 `strfilename` 的倒数第 18 个字符,而 `15` 则表示要取子串的长度。
需要注意的是,这里取的长度是 15,而不是 16。因为 `substr` 函数是从起始位置开始,向后取指定长度的子串,因此要减去起始位置的一个字符。
用c++编写一个字符串降序
### 回答1:
我可以给你一个简单的示例:#include <stdio.h>
int main()
{
char str[100];
int i;
printf("Enter a string: ");
scanf("%s", str);
printf("The string in reverse order is: ");
for (i = strlen(str) - 1; i >= 0; i--)
{
printf("%c", str[i]);
}
return 0;
}
### 回答2:
要用C语言编写一个字符串降序的程序,可以按照以下步骤进行实现:
1. 首先,定义一个字符串变量,并初始化为需要排序的字符串。
2. 使用标准库函数strlen()获取字符串的长度,得到字符串的字符数。
3. 创建一个整型变量i和j,用于循环和交换操作。
4. 使用嵌套循环来比较和交换字符串中的字符,使其按照降序排列。外层循环遍历字符串中的每个字符,从第一个字符一直到倒数第二个字符。内层循环则从外层循环的下一个字符开始,依次与外层循环指定的字符进行比较,并根据需要进行交换操作。
5. 使用临时变量来进行交换。如果内层循环指定的字符比外层循环指定的字符要大,则使用一个临时变量temp将两个字符交换位置。
6. 完成排序后,将排序后的字符串输出或保存。
以下是一个示例代码:
#include <stdio.h>
#include <string.h>
int main() {
char str[100] = "cba"; // 初始化字符串
int len = strlen(str); // 获取字符数
// 冒泡排序
for (int i = 0; i < len - 1; i++) {
for (int j = i + 1; j < len; j++) {
if (str[j] > str[i]) {
char temp = str[j];
str[j] = str[i];
str[i] = temp;
}
}
}
printf("降序排列后的字符串: %s\n", str);
return 0;
}
以上代码使用冒泡排序算法对字符串进行降序排列,并输出排序后的结果。在这个示例中,初始的字符串为"cba",经过排序后得到的结果为"cba"。
### 回答3:
要用C语言编写一个字符串降序的程序,可以使用标准库中的字符串操作函数来实现。下面是一个简单的实现示例:
```c
#include <stdio.h>
#include <string.h>
// 比较函数,用于按字典序比较两个字符串
int compare(const void *a, const void *b) {
return strcmp(*(const char **)b, *(const char **)a);
}
int main() {
char str[100][100]; // 定义一个二维字符数组保存多个字符串
int n, i;
printf("请输入字符串个数:");
scanf("%d", &n);
printf("请输入%d个字符串:\n", n);
for (i = 0; i < n; i++) {
scanf("%s", str[i]);
}
// 使用标准库中的快速排序函数对字符串数组进行降序排序
qsort(str, n, sizeof(char *), compare);
printf("降序排序后的字符串为:\n");
for (i = 0; i < n; i++) {
printf("%s\n", str[i]);
}
return 0;
}
```
以上程序中,首先定义了一个二维字符数组`str`用于保存输入的多个字符串。然后通过`scanf`函数分别读入字符串的数量和具体的字符串。接下来使用`qsort`函数对字符串数组进行排序,排序方法由自定义的`compare`函数指定,该函数使用`strcmp`函数对两个字符串进行字典序比较,并返回比较结果。最后在屏幕上输出排序后的字符串数组即可。