用c++ 采用指针编程:将一个宇符串反序输出,即: 输入:ABCDEFG 输出:GFEDCBA
时间: 2024-02-27 20:54:51 浏览: 89
好的,我来为您解答。
您可以使用指针来实现宇符串反序输出的功能,具体步骤如下:
1. 定义一个字符数组,并输入字符串。
2. 定义两个指针,一个指向字符串的开头,一个指向字符串的结尾。
3. 使用循环,将字符串中的字符从后往前逐个输出到屏幕上。
4. 最后别忘了加上换行符。
下面是一个示例代码:
```
#include <iostream>
#include <cstring>
using namespace std;
int main()
{
char str[100];
cout << "请输入字符串:";
cin >> str;
int len = strlen(str);
char *p1 = str;
char *p2 = str + len - 1;
while (p1 < p2) {
char tmp = *p1;
*p1++ = *p2;
*p2-- = tmp;
}
cout << "反序输出为:";
cout << str << endl;
return 0;
}
```
当您运行程序并输入字符串时,程序会将字符串反序输出到屏幕上。
希望这个回答对您有所帮助,如有疑问请随时追问。
相关问题
。 2.采用指针编程:将一个宇符串反序输出,即: 输入:ABCDEFG 输出:GFEDCBA用c++编写
以下是用C++编写的程序,实现了将一个字符串反序输出:
```c++
#include <iostream>
#include <cstring>
using namespace std;
int main() {
char str[] = "ABCDEFG";
int len = strlen(str);
cout << "原字符串为:" << str << endl;
char* left = str;
char* right = str + len - 1;
while (left < right) {
char temp = *left;
*left = *right;
*right = temp;
left++;
right--;
}
cout << "反序输出的字符串为:" << str << endl;
return 0;
}
```
程序中,首先定义了一个字符串str,并使用strlen函数计算其长度。然后输出原字符串,方便比较反序输出后的结果。接着定义两个char型指针变量left和right,分别指向字符串的首地址和尾地址。使用while循环,每次交换left和right指向的字符,并将left指针往后移动一位,right指针往前移动一位,直到left >= right为止。最后输出反序输出后的字符串。
c++采用指针编程:将一个字符串反序输出,即: 输入:ABCDEFG 输出: GFEDCBA
以下是一个采用指针编程的 C++ 程序,可以将一个字符串反序输出:
```c++
#include <iostream>
#include <cstring>
using namespace std;
int main() {
char str[100];
cout << "Enter a string: ";
cin.getline(str, 100);
int len = strlen(str);
char *p = str + len - 1; // 定义指针变量并初始化为字符串末尾
cout << "Reverse string: ";
while (p >= str) {
cout << *p--; // 输出指针指向的字符,并将指针向前移动
}
return 0;
}
```
在这个程序中,我们首先定义了一个名为 `str` 的字符数组,并使用 `cin.getline()` 函数从用户输入中读取字符串。然后,我们使用 `strlen()` 函数计算出字符串的长度,并定义一个指针变量 `p` 并初始化为字符串末尾的字符位置。在 `while` 循环中,我们使用解引用操作符 `*` 输出指针指向的字符,并将指针向前移动一个位置。
程序的输出为:
```
Enter a string: ABCDEFG
Reverse string: GFEDCBA
```
需要注意的是,为了反序输出字符串,我们使用了指针变量 `p`,并将其初始化为字符串末尾的字符位置。在 `while` 循环中,我们使用 `p >= str` 来判断指针是否越界。如果指针 `p` 大于或等于字符串的起始位置 `str`,则说明还没有遍历到字符串的开头,可以继续输出字符。否则,说明已经遍历完了整个字符串,循环结束。
阅读全文