输入一个字符串输出字母交换 C++
时间: 2024-09-30 19:04:03 浏览: 36
在C++中,你可以通过迭代或者使用内置的algorithm库来实现字母交换的功能。这里是一个简单的例子,展示如何交换字符串中的字符:
```cpp
#include <iostream>
#include <string>
std::string swapLetters(std::string str) {
// 使用标准库函数transform和swapcase
std::transform(str.begin(), str.end(), str.begin(), ::tolower); // 转换所有字母为小写
std::transform(str.begin(), str.end(), str.begin(), ::toupper); // 再转换回大写
return str;
}
int main() {
std::string input = "Hello, World!";
std::cout << "Original string: " << input << "\n";
std::cout << "After swapping letters: " << swapLetters(input) << "\n";
return 0;
}
```
这个程序首先将输入的字符串全部转为小写,然后再转换回大写,实现了字母交换的效果。
相关问题
使用c语言编写一个程序,题目描述:编写一个如下声明的递归函数,使得字符串Str倒序,并在主程序中调用该函数测试效果 函数声明:void Reverse(string & Str);输入格式:输入为连续多行的多个字符串,一个字符串一行,每个字符串由阿拉伯数字、字母或特殊字符组成,字符串中不包括空格。输出格式:输出为输入倒序后的字符串,一行输出一个字符串,对应于一行输入字符串的倒序字符串。
这道题目的函数声明中使用了C++中的引用类型,而C语言中并没有该类型。下面是一份使用C语言实现的代码,实现字符串倒序的功能:
```c
#include <stdio.h>
#include <string.h>
// 递归函数,用于实现字符串倒序
void Reverse(char *str, int start, int end)
{
if (start >= end) {
return;
}
char tmp = str[start]; // 交换字符串的首尾字符
str[start] = str[end];
str[end] = tmp;
Reverse(str, start+1, end-1); // 递归调用
}
int main()
{
char str[100];
while (fgets(str, sizeof(str), stdin)) {
str[strlen(str)-1] = '\0'; // 去掉换行符
Reverse(str, 0, strlen(str)-1);
printf("%s\n", str);
}
return 0;
}
```
程序中使用了递归函数Reverse实现字符串的倒序。在主函数中,使用fgets读取输入字符串,去掉换行符后,调用递归函数Reverse实现倒序,并输出结果。
c++程序设计,输入5个字符串(含空格),用指针实现按字母顺序由小到大对字符串 排序后输出。
以下是一个使用指针实现字符串排序的示例代码:
```
#include <iostream>
#include <cstring>
using namespace std;
void sort_strings(char** strings, int n) {
for (int i = 0; i < n - 1; i++) {
for (int j = i + 1; j < n; j++) {
if (strcmp(strings[i], strings[j]) > 0) {
char* temp = strings[i];
strings[i] = strings[j];
strings[j] = temp;
}
}
}
}
int main() {
const int n = 5;
char* strings[n];
// 输入5个字符串
for (int i = 0; i < n; i++) {
string str;
getline(cin, str);
strings[i] = new char[str.length() + 1];
strcpy(strings[i], str.c_str());
}
// 对字符串排序
sort_strings(strings, n);
// 输出排序后的字符串
for (int i = 0; i < n; i++) {
cout << strings[i] << endl;
}
// 释放内存
for (int i = 0; i < n; i++) {
delete[] strings[i];
}
return 0;
}
```
在上面的代码中,我们定义了一个`sort_strings`函数,它使用了一个指向字符指针的指针作为参数。在函数内部,我们使用了两个嵌套的循环来比较字符串并进行排序。我们使用`strcmp`函数来比较两个字符串的大小,如果第一个字符串大于第二个字符串,则交换它们的位置。在`main`函数中,我们定义了一个指向字符指针的数组`strings`,并使用`getline`函数从输入流中读取5个字符串。我们使用`new`关键字为每个字符串分配内存,并使用`strcpy`函数将字符串复制到分配的内存中。然后,我们调用`sort_strings`函数对字符串进行排序,并输出排序后的字符串。最后,我们使用`delete`关键字释放每个字符串占用的内存。
阅读全文