深入理解OJ编程中的输入输出:11个经典题目详解与技巧分享及stringstream,sort详解

news2024/11/15 11:36:57

文章目录

  • 1.多组输入计算a+b
  • 2.给定组数计算a+b
  • 3.给定组数计算a+b(如果为0则结束)
  • 4.计算一些列数的和(第一个数为0时结束)
  • 5.计算一些列数的和(告诉了有几组)
  • 6.计算一系列数的和(不告知几组和何时结束,每一组第一个数为一共本组几个数)
  • 7.计算一系列数的和(一行一组,不告诉一组几个,需要判断)
  • 8.字符串排序(只排一组,告诉有几个)
  • 9字符串排序(无固定组数)
  • 10.字符串排序(输入用逗号分开)
  • 11.注意数据范围,用 long
      • 这道题想要教会我们什么?
  • stringstream详解
    • stringstream 类概述
    • 常见用法
        • 1. 创建 `stringstream` 对象
        • 2. 向 `stringstream` 写入数据
        • 3. 从 `stringstream` 读取数据
        • 4. 将 `stringstream` 转换为字符串
    • 在算法题中的使用场景
        • 1. 字符串到数字的转换
        • 2. 数字到字符串的转换
        • 3. 字符串分割
        • 4. 读取和写入数据
  • sort详解
        • 1. 函数原型
        • 2. 排序的时间复杂度
        • 3. 使用场景
        • 4. 常见用法
          • 4.1. 对数组进行排序
          • 4.2. 对 **`std::vector`** 进行排序
          • 4.3. 自定义排序规则
          • 4.4. 对结构体进行排序
          • 4.5. 部分排序
          • 4.6 使用比较函数对象
            • 4.6.1 `greater<int>`函数对象
            • 4.6.2 其他常见的函数对象
            • 4.6.3 自定义函数对象
        • 5. 注意事项
        • 6. 总结

本篇文章将详细介绍在ACM模式下常见的输入输出类型,搞懂这11道题可以帮我们打好算法基础,避免因为最后结果的输出导致无法完成题目。在讲完题目之后再讲两个常用的函数: stringstreamsort


1.多组输入计算a+b

image.png

#include<iostream>
using namespace std;
int main()
{
    int a,b;
    //使用while循环来处理所有输入
    while(cin>>a>>b)
    {
        cout<<a+b<<endl;
    }
    return 0;
}

2.给定组数计算a+b

image.png

#include<iostream>
using namespace std;
int main()
{
    int n;
    cin>>n;
    int a,b;
    while(n--)
    {
        cin>>a>>b;
        cout<<a+b<<endl;
    }
    return 0;
}

3.给定组数计算a+b(如果为0则结束)

image.png

#include<iostream>
using namespace std;
int main()
{
    int a,b;
    while(cin>>a>>b)
    {
       if(a==b&&b==0)
       {
           break;
       }
        cout<<a+b<<endl;
    }
    return 0;
}
  • **while**** 循环** 更适合处理未知数量的输入数据,使用起来更灵活,也是处理这种"无限输入,特定条件结束"的经典方式。
  • **for**** 循环** 在你知道确切的循环次数时使用更为方便,但在这个问题中,因为输入可能是无限的,因此 while 循环会更常用和合适。

4.计算一些列数的和(第一个数为0时结束)

image.png
解法1:

#include<iostream>
using namespace std;

int main() {
    int n;
    while (cin >> n && n != 0) { // 读取整数个数n,且n不为0时进入循环
        int sum = 0, temp;
        for (int i = 0; i < n; i++) { // 循环读取n个整数并求和
            cin >> temp;
            sum += temp;
        }
        cout << sum << endl; // 输出求和结果
    }
    return 0;
}

解法2:

#include<bits/stdc++.h>
using namespace std;
int main()
{
    int n=0;
    while(cin>>n&&n!=0)
    {
        int sum=0;
        vector<int> arr(n);
        for(int i=0;i<n;i++)
        {
            cin>>arr[i];
            sum+=arr[i];
        }
        cout << sum << endl;
    }
}

5.计算一些列数的和(告诉了有几组)

image.png

#include<iostream>
using namespace std;
int main() {
    int t;
    cin >> t; // 读取数据组数
    while (t--) { // 当t > 0时循环,每次循环处理一组数据
        int n, sum = 0;
        cin >> n; // 读取当前组的整数个数
        for (int i = 0; i < n; i++) { // 循环读取n个正整数并求和
            int temp;
            cin >> temp;
            sum += temp;
        }
        cout << sum << endl; // 输出当前组的和
    }
    return 0;
}

6.计算一系列数的和(不告知几组和何时结束,每一组第一个数为一共本组几个数)

image.png

#include<iostream>
using namespace std;
int main() {
    int n;
    while(cin >> n) {  // 逐行读取每行的第一个整数,即整数的个数
        int sum = 0;
        for(int i = 0; i < n; i++) {
            int num;
            cin >> num;  // 逐个读取正整数
            sum += num;  // 将其加入求和变量
        }
        cout << sum << endl;  // 输出该行的和
    }
    return 0;
}

7.计算一系列数的和(一行一组,不告诉一组几个,需要判断)

image.png
解法1:

#include <iostream>
using namespace std;
int main() {
    int sum = 0;
    int a;
    while (cin >> a) {
        sum += a;
        // 这里用 cin.get() 是换行符来判断,是否到了最后一个数,如果是的话,就把和输出出来,并把 sum 置零
        if (cin.get() == '\n') {
            cout << sum << endl;
            sum = 0;  // 清零以准备下一行
        }
    }
}

解法2:

#include <iostream>
using namespace std;
int main() {
    int a;
    int sum = 0;
    while (scanf("%d", &a) != EOF) {
        sum += a;
        if (getchar() == '\n') {
            printf("%d\n", sum);
            sum = 0;  // 清零以准备下一行
        }
    }
}

解法3:

string line;          // 定义一个字符串变量line,用于存储一行输入
	while (getline(cin, line))  // 循环读取每一行输入
	{
		stringstream ss;  // 创建一个stringstream对象ss
		ss << line;      // 将当前行的输入字符串line放入ss中
		int cur_sum = 0; // 初始化当前行的和cur_sum为0
		int x;           // 定义一个整数变量x,用于存储从ss中读取的每个整数
		// 从ss中读取整数,直到没有更多的整数可读
		while (ss >> x)
			cur_sum += x;  // 将读取到的整数累加到cur_sum中

		cout << cur_sum << endl;  // 输出当前行的和
	}

8.字符串排序(只排一组,告诉有几个)

image.png
解法1:

#include<iostream>
#include<vector>
#include<algorithm>  // std::sort
using namespace std;

int main() {
    int n;
    cin >> n;
    vector<string> strings(n);

    for(int i = 0; i < n; i++) {
        cin >> strings[i];  // 读取 n 个字符串
    }

    sort(strings.begin(), strings.end());  // 对字符串进行排序
    //注意末尾没有空格
	for (int i = 0; i < n - 1; i++)
	{
		cout << s[i] << " ";
	}
	cout << s[n - 1] << endl;
    return 0;
}

解法2:

int n;
	vector<string> strs;
	cin >> n;
	for (int i = 0; i < n; i++)
	{
		string str;
		cin >> str;
		strs.push_back(str);
	}
	sort(strs.begin(), strs.end());
    for(int i = 0; i < n; i++) {
        if(i > 0) cout << " ";  // 控制输出格式
        cout << strings[i];
    }
    cout << endl;

9字符串排序(无固定组数)

image.png
解法1:

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int main() {
    vector<string> words;
    string word;
    
    while (cin >> word) {  // 读取每个单词
        words.push_back(word);
        if (cin.get() == '\n') {  // 检查是否到达行末
            sort(words.begin(), words.end());  // 对单词进行排序
            
            for (size_t i = 0; i < words.size(); ++i) {
                cout << words[i];
                if (i < words.size() - 1) {
                    cout << " ";  // 输出空格,除非是最后一个单词
                }
            }
            cout << endl;  // 换行,处理下一行输入
            words.clear();  // 清空单词列表,准备下一行输入
        }
    }
    return 0;
}

解法2:

string line;  // 用于存储每行输入的字符串

while (getline(cin, line)) {
    stringstream ss(line);  // 使用 stringstream 来处理行内的单词
    vector<string> words;   // 存储当前行的所有单词
    string word;            // 临时变量,用于存储每个单词

    while (ss >> word) {
        words.push_back(word);  // 将提取到的单词存储到 vector 中
    }

    sort(words.begin(), words.end());  // 使用标准库中的 sort 函数对单词进行排序

    for (size_t i = 0; i < words.size() - 1; ++i) {
        cout << words[i] << " ";  // 输出当前单词,并加上空格
    }
    cout << words.back();  // 输出最后一个字符串,不带空格
    cout << endl;  // 换行,处理下一行输入
}

10.字符串排序(输入用逗号分开)

image.png
解法1:

#include <iostream>
#include <vector>
#include <algorithm>
#include <sstream>

using namespace std;

int main() {
    string line;
    while (getline(cin, line)) {  // 读取一行字符串
        vector<string> words;
        string word;
        stringstream ss(line);
        
        while (getline(ss, word, ',')) {  // 读取每个单词,使用逗号作为分隔符
            words.push_back(word);
        }

        // 使用 sort 函数对字符串数组进行排序
        sort(words.begin(), words.end());

        // 输出排序后的字符串
        for (size_t i = 0; i < words.size() - 1; i++) {
            cout << words[i] << ",";  // 输出字符串和逗号
        }
        cout << words.back();  // 输出最后一个字符串,不带逗号
        cout << endl;
    }

    return 0;
}

11.注意数据范围,用 long

image.png

image.png

**注意:**看好数据范围
题目要求处理的整数范围是 0 < a, b < 2 × 10^10。然而,int 类型在大多数 C++ 实现中最多只能表示到 2^31 - 1 (即大约 2.14 × 10^9),这比题目中的最大值要小得多。使用 int 类型来存储输入数据,如果输入的数据非常大,可能会导致整数溢出,进而使结果错误。

正确代码:

#include<bits/stdc++.h>
using namespace std;
int main()
{
    long long a, b;  // 使用 long long 类型以处理更大的数值范围
    while(cin >> a >> b)
    {
        cout << (a + b) << endl;  // 输出两个大整数的和
    }
    return 0;
}

这道题想要教会我们什么?

  1. 大数处理: 在C++编程中,尤其是在处理大数时,要谨慎选择数据类型。int 类型在面对超大数值时可能会溢出,因此要熟练掌握使用 long long 来处理更大的整数。
  2. 边界条件测试: 你的代码可能在处理样例和小数据时表现良好,但在面对大范围数据时会暴露问题。这提醒你在设计和测试代码时,需要覆盖更广泛的边界条件。
  3. 全面的代码测试: 在面对在线编程题时,不仅要在自己的测试环境下测试,还要注意潜在的极限条件。OJ系统通常会有更全面的测试数据,因此提交前要确保代码在所有可能的条件下都能正常运行。

拓展:longlong long
long 和 long long 是 C++ 中的两种整数数据类型,它们之间主要的区别在于它们能表示的数值范围不同。

  1. long 类型
    在大多数编译器和平台上,long 通常是 4字节(32位),和 int 一样大。
    它的取值范围通常是 -2,147,483,648 到 2,147,483,647,即
    2-31到 231 -1
  1. long long 类型
    long long 是一种较新的类型,通常是 8字节(64位),比 long 能表示更大的整数。
    它的取值范围通常是 -9,223,372,036,854,775,808 到 9,223,372,036,854,775,807,即
    -263到263 -1

stringstream详解

stringstream 是 C++ 标准库中的一个非常有用的类,它结合了字符串操作和流操作的功能。stringstream 允许你像处理文件流一样处理字符串,这在很多场合都非常有用,尤其是在算法题中。下面详细介绍 stringstream 的常见用法和在算法题中的使用场景
当然可以!stringstream 是 C++ 标准库中的一个非常有用的类,它结合了字符串操作和流操作的功能。stringstream 允许你像处理文件流一样处理字符串,这在很多场合都非常有用,尤其是在算法题中。下面详细介绍 stringstream 的常见用法和在算法题中的使用场景。

stringstream 类概述

stringstream 类是 <sstream> 头文件的一部分,它继承自 istreamostream,这意味着你可以像使用 cincout 一样使用它来进行输入输出操作。

常见用法

1. 创建 stringstream 对象
#include <sstream>
std::stringstream ss;

2. 向 stringstream 写入数据

你可以使用 << 运算符向 stringstream 写入数据,就像使用 cout 一样:

ss << "Hello, " << 42 << "!";

3. 从 stringstream 读取数据

你可以使用 >> 运算符从 stringstream 读取数据,就像使用 cin 一样:

int num;
ss >> num;  // 读取整数

4. 将 stringstream 转换为字符串

你可以使用 str() 成员函数获取 stringstream 中的内容作为字符串:

std::string str = ss.str();

在算法题中的使用场景

1. 字符串到数字的转换

使用 stringstream 来将字符串转换为数字类型,这对于解析输入非常有用:

#include <iostream>
#include <sstream>
using namespace std;
int main() {
    string input = "12345";
    stringstream ss(input);
    int number;
    ss >> number;
    cout << "Number: " << number << endl;
    return 0;
}

2. 数字到字符串的转换

使用 stringstream 来将数字转换为字符串类型,这对于构建输出非常有用:

#include <iostream>
#include <sstream>

using namespace std;

int main() {
    int number = 12345;
    stringstream ss;
    ss << number;
    string strNumber = ss.str();
    cout << "String: " << strNumber << endl;
    return 0;
}

3. 字符串分割

使用 getlinestringstream 来分割字符串,这对于处理 CSV 或其他分隔符分隔的数据非常有用:

#include <iostream>
#include <sstream>
#include <string>
#include <vector>

using namespace std;

int main() {
    string line = "a,c,bb";
    vector<string> words;
    string word;
    stringstream ss(line);
    
    while (getline(ss, word, ',')) {  // 读取每个单词,使用逗号作为分隔符
        words.push_back(word);
    }

    // 输出排序后的字符串
    for (size_t i = 0; i < words.size() - 1; i++) {
        cout << words[i] << ",";  // 输出字符串和逗号
    }
    cout << words.back();  // 输出最后一个字符串,不带逗号
    cout << endl;

    return 0;
}

getline(ss,word,‘,’)
** 在 C++ 中,getline 是一个用于从输入流中读取一行字符串的函数,它也可以从 stringstream 这样的流中读取。getline 的第三个参数允许你指定一个分隔符,这样你可以按分隔符来读取数据,而不仅仅是到换行符为止。
**getline(ss, word, ',')**
的含义是从 **stringstream** 对象 **ss** 中读取字符到字符串 **word**,直到遇到指定的分隔符 **,** 为止,或者到达流的结尾。**
下面是这行代码的各个参数的具体含义:

  • **ss**: 输入流对象,这里是 **stringstream**
  • **word**: 用于存储读取到的字符串。
  • **,**: 分隔符,表示在读取过程中遇到的逗号 **,** 会作为分隔符,读取到逗号时停止读取,逗号不会包括在读取到的字符串中。

假设我们有以下的输入流内容 **ss**,它是一个 **stringstream** 对象,内容如下:

apple,banana,orange,grape

以下是几种情况下的 getline(ss, word, ',') 的行为示例:
示例 1代码:

getline(ss, word, ',');
cout << word << endl;

结果:

apple

解释:第一次调用 getline(ss, word, ',') 会读取到第一个逗号 , 之前的内容 apple,并将其存储到 word 中。然后输出 apple
示例 2代码:

getline(ss, word, ',');
getline(ss, word, ',');
cout << word << endl;

结果:

banana

解释:第一次调用 getline(ss, word, ',') 会读取 apple。第二次调用 getline(ss, word, ',') 会读取 banana,直到下一个逗号 , 为止。然后输出 banana
示例3:代码:

getline(ss, word, ',');
getline(ss, word, ',');
getline(ss, word, ',');
cout << word << endl;

结果:

orange

解释:第一次调用 getline(ss, word, ',') 读取 apple。第二次调用读取 banana。第三次调用读取 orange。此时 ss 的下一个内容是 grape。所以 word 变为 orange,输出 orange
示例 4代码:

getline(ss, word, ',');
getline(ss, word, ',');
getline(ss, word, ',');
getline(ss, word, ',');
cout << word << endl;

结果:

grape

解释:前三次调用分别读取 applebananaorange。最后一次调用读取到 grape,并且遇到流的结尾,grape 是最后一个单词。输出 grape

总结:
getline(ss, word, ',') 用于按逗号分隔读取输入流中的字符串,这在处理用特定字符分隔的数据时非常有用。每次调用 getline 都会读取到下一个分隔符之前的内容,并将其存储到 word 变量中。

4. 读取和写入数据

std::stringstream 结合了 std::istringstreamstd::ostringstream 的功能,既可以从字符串中读取数据,也可以将数据写入字符串。
示例:读取和写入数据

#include <iostream>
#include <sstream>

using namespace std;

int main() {
    stringstream ss;  // 创建字符串流

    ss << "123 456 78.9";  // 将数据写入字符串流

    int a, b;
    float c;

    ss >> a >> b >> c;  // 从字符串流中读取数据

    cout << "a = " << a << endl;
    cout << "b = " << b << endl;
    cout << "c = " << c << endl;

    return 0;
}

在这个例子中,stringstream 同时用作输入和输出流。
stringstream 是一个非常强大的工具,它可以帮助你在字符串操作方面更加灵活。它不仅可以在字符串和数字之间进行转换,还可以用于解析和构造字符串,甚至用于模拟文件输入输出。希望这些示例对你有所帮助!如果有任何其他问题,请随时提问。

sort详解

std::sort 是 C++ 标准库中的一个排序算法,用于对容器中的元素进行排序。它位于 <algorithm> 头文件中,并且通常用于对 std::vectorstd::arraystd::deque 等容器的元素进行排序。它采用了高效的排序算法(通常是快速排序,但在某些实现中可能会使用其他算法,如堆排序(HeapSort)或插入排序(Insertion Sort))。以下是对 std::sort 的全面讲解,包括其用法、典型场景、以及代码示例。

1. 函数原型

std::sort 的基本原型如下:

template<class RandomAccessIterator>
void sort(RandomAccessIterator first, RandomAccessIterator last);

template<class RandomAccessIterator, class Compare>
void sort(RandomAccessIterator first, RandomAccessIterator last, Compare comp);
  • **Compare** 是一个比较函数或仿函数(functor),定义了元素之间的比较逻辑。
  • **RandomAccessIterator**: 这是指向容器中元素的随机访问迭代器类型。
  • **first**: 这是指向待排序序列的第一个元素的迭代器。
  • **last**: 这是指向待排序序列的最后一个元素之后的位置的迭代器。
2. 排序的时间复杂度

std::sort 的时间复杂度通常为 O(n log n),其中 n 是待排序元素的数量。这个复杂度使其在大多数情况下都表现出色。尽管最坏情况下的复杂度可能达到 O(n^2),但实际应用中,快速排序通常提供了相当稳定的性能。

3. 使用场景

std::sort 适用于各种需要排序的场景,包括但不限于:

  • 对数组、向量或其他容器中的元素进行排序。
  • 对某个结构体的数组进行排序,可以通过自定义比较函数来实现复杂排序需求。
  • 在需要对算法中的数据进行排序以提高效率时。
4. 常见用法

4.1. 对数组进行排序

以下是对数组进行排序的示例:

#include <iostream>
#include <algorithm> // 引入 sort 函数
using namespace std;

int main() {
    int arr[] = {5, 2, 9, 1, 5, 6}; // 定义一个整数数组
    int n = sizeof(arr)/sizeof(arr[0]); // 计算数组大小

    // 对数组进行排序
    sort(arr, arr + n);

    // 输出排序后的数组
    for (int i = 0; i < n; i++) {
        cout << arr[i] << " "; // 打印每个元素
    }
    cout << endl;

    return 0;
}

4.2. 对 std::vector 进行排序

以下是对 std::vector 进行排序的示例:

#include <iostream>
#include <vector>
#include <algorithm> // 引入 sort 函数
using namespace std;

int main() {
    vector<int> vec = {10, 5, 8, 1, 2}; // 定义一个整数向量
    // 对向量进行排序
    sort(vec.begin(), vec.end());
    // 输出排序后的向量
    for (int num : vec) {
        cout << num << " "; // 打印每个元素
    }
    cout << endl;
    return 0;
}

4.3. 自定义排序规则

可以通过传递一个自定义比较函数或函数对象来改变排序的规则。例如,按降序排序:

#include <iostream>
#include <vector>
#include <algorithm> // 引入 sort 函数
using namespace std;

// 自定义比较函数,用于降序排序
bool compare(int a, int b) {
    return a > b;
}

int main() {
    vector<int> vec = {10, 5, 8, 1, 2}; // 定义一个整数向量

    // 对向量进行降序排序
    sort(vec.begin(), vec.end(), compare);

    // 输出排序后的向量
    for (int num : vec) {
        cout << num << " "; // 打印每个元素
    }
    cout << endl;

    return 0;
}

4.4. 对结构体进行排序

假设我们有一个结构体 Person,按年龄排序:

#include <iostream>
#include <vector>
#include <algorithm> // 引入 sort 函数
using namespace std;

struct Person {
    string name;
    int age;
};

// 自定义比较函数,用于按年龄排序
bool compareByAge(const Person& a, const Person& b) {
    return a.age < b.age;
}

int main() {
    vector<Person> people = {{"Alice", 30}, {"Bob", 25}, {"Charlie", 35}}; // 定义一个 Person 向量

    // 对向量中的 Person 进行排序,按年龄
    sort(people.begin(), people.end(), compareByAge);

    // 输出排序后的向量
    for (const Person& p : people) {
        cout << p.name << " (" << p.age << ") "; // 打印每个 Person 的信息
    }
    cout << endl;

    return 0;
}

4.5. 部分排序

可以对容器的部分区域进行排序:

#include <iostream>
#include <vector>
#include <algorithm> // 引入 sort 函数
using namespace std;

int main() {
    vector<int> vec = {10, 5, 8, 1, 2}; // 定义一个整数向量

    // 对向量的部分区域进行排序
    sort(vec.begin() + 1, vec.end() - 1);

    // 输出排序后的向量
    for (int num : vec) {
        cout << num << " "; // 打印每个元素
    }
    cout << endl;

    return 0;
}

好的,接着上面的讲解,我们来看一下如何使用比较函数对象来自定义排序逻辑。

4.6 使用比较函数对象

在C++中,sort函数除了能够进行默认的升序排序外,还允许我们通过提供比较函数对象来自定义排序规则。比较函数对象是可以作为函数使用的类或结构体的实例,它能够根据我们定义的逻辑对元素进行比较。

4.6.1 greater<int>函数对象

greater<int>是标准库中的一个函数对象,用于实现降序排序greater模板类是定义在<functional>头文件中的,它的作用是对两个对象进行“大于”比较。
示例代码:

#include <iostream>
#include <vector>
#include <algorithm>  // 包含sort函数的头文件
#include <functional> // 包含greater的头文件

using namespace std;

int main() {
    // 创建一个包含整数的向量
    vector<int> v = {3, 1, 4, 1, 5};

    // 使用sort函数对向量进行排序,并使用greater<int>()作为比较函数对象,实现降序排序
    sort(v.begin(), v.end(), greater<int>());

    // 输出排序后的向量
    for (int i : v) {
        cout << i << " ";  // 依次输出每个元素
    }

    return 0;
}

输出:

5 4 3 1 1

4.6.2 其他常见的函数对象

除了greater外,C++标准库还提供了其他常见的函数对象,例如:

  • less<T>:用于实现升序排序(默认行为)。
  • greater_equal<T>:用于实现“大于等于”比较。
  • less_equal<T>:用于实现“小于等于”比较。

这些函数对象可以直接用于sort函数中,帮助我们根据不同的需求定制排序规则。

4.6.3 自定义函数对象

除了使用标准库提供的函数对象外,C++还允许我们自定义比较函数对象。例如,我们可以创建一个函数对象来实现按字符串长度排序。
示例代码:

#include <iostream>
#include <vector>
#include <algorithm>  // 包含sort函数的头文件

using namespace std;

// 自定义函数对象,用于按字符串长度排序
struct LengthCompare {
    bool operator()(const string &a, const string &b) const {
        return a.length() < b.length();  // 返回a是否小于b
    }
};

int main() {
    // 创建一个包含字符串的向量
    vector<string> v = {"apple", "banana", "pear", "grape"};

    // 使用sort函数,并传入自定义的比较函数对象LengthCompare
    sort(v.begin(), v.end(), LengthCompare());

    // 输出排序后的向量
    for (const string &s : v) {
        cout << s << " ";  // 依次输出每个字符串
    }

    return 0;
}

输出:

pear grape apple banana

在这个例子中,我们定义了一个名为LengthCompare的函数对象,用于按字符串的长度进行排序。sort函数会使用我们提供的逻辑来决定排序顺序。

5. 注意事项
  • std::sort 要求排序的范围必须是随机访问迭代器,因此它适用于 std::vector、数组等支持随机访问的容器。对于其他类型的容器(如链表),请使用其他排序算法,如 std::listsort 成员函数。
  • 确保提供的比较函数是严格弱序的,即对于任意元素 a, b, c,如果 a < bb < c,则必须有 a < c
  • 自定义比较函数必须满足这一特性,否则排序结果可能不正确。
6. 总结

std::sort 是 C++ 中一个功能强大且常用的排序算法。它适用于多种场景,包括对基本类型、用户自定义类型进行排序,以及对部分数据进行排序。通过自定义比较函数,可以灵活地控制排序的行为,以适应不同的需求。希望这个详细的讲解能帮助你更好地理解和应用 std::sort


07c03ae6d77b4b153f6d1ec710be7c14_7a80245f0b5f4021a033b3789a9efdeb.png

  1. 📜 [ 声明 ] 由于作者水平有限,本文有错误和不准确之处在所难免,
  2. 本人也很想知道这些错误,恳望读者批评指正!
  3. 我是:勇敢滴勇~感谢大家的支持!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2086369.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何评估云服务器提供商可靠性与信誉度

在云计算时代&#xff0c;选择一个可靠和信誉良好的云服务器提供商对于个人用户和企业来说至关重要。以下是评估云服务器提供商可靠性与信誉度的关键指标和方法&#xff1a; 1. 服务水平协议&#xff08;SLA&#xff09;&#xff1a; 可用性承诺&#xff1a; 查看云服务器提供…

服务器内存飙升分析小记

1. 写在最前面 这个繁忙的八月真的是转瞬即逝&#xff0c;我明明感觉似乎好像才八月刚开始&#xff0c;但是其实已经到了八月的尾巴。这个月本来想抽空整理一下学习 AI 模型相关的东西&#xff0c;奈何每天不是在查问题就是在查问题的路上&#xff0c;不是在修 Bug 就是在写 B…

AI Lossless Zoomer v3.1.0.0 — 超实用的AI无损图片放大工具

AI Lossless Zoomer 是一款基于腾讯开源 Real-ESRGAN 算法的 AI 图片无损放大工具&#xff0c;支持多线程和批量处理&#xff0c;具备自定义输出格式和路径等高级设置选项&#xff0c;并允许用户选择不同的 AI 引擎进行图片放大处理。此版本修复了一些小 bug&#xff0c;并增加…

Jhipster应用,cdn加速方案。

Jhipster, 采用springbootwebfluxreacttypescript技术栈。项目部署是采用k8shelm 部署在GCP上的&#xff0c;所以这个单体项目幕后是跑在pod上的。 项目上线后&#xff0c;发现单页面应用加载速度很慢&#xff0c;如图所示长时间处于加载状态&#xff1a; 仔细分析一下原因&am…

ESXi服务器无法安装Windows11:“不符合此版本的Windows所需最低系统要求“

目录 一、问题描述1.使用环境2.问题截图3.问题解析 二、解决方法Ⅰ1.按 ShiftF10 弹出命令提示符2.在弹出的Dos框中输入regedit&#xff0c;回车&#xff0c;进入注册表。3.打开HKEY_LOCAL_MACHINE\SYSTEM\Setup&#xff0c;并新建 LabConfig 的项&#xff0c;在 LabConfig 下创…

51单片机-静态数码管显示

时间&#xff1a;2024.8.29 作者&#xff1a;Whappy 目的&#xff1a;学习51单片机 代码&#xff1a; #include <REGX52.H> #include "intrins.h"unsigned char NixieTable[] {0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F,0x77,0x7C,0x39,0x5E,0x79…

C++系列-STL容器之deque

STL容器之deque deque概括deque与vector内存管理的区别vector内存分配方式deque内存分配方式 deque与vector随机访问效率的区别deque与vector插入和删除操作的区别deque与vector适用场景 deque的构造函数deque的构造函数举例 deque的赋值操作deque容器的大小操作deque容器的插入…

瑞芯微RK3566开发板USB OTG模式介绍及命令切换,触觉智能EVB3566主板鸿蒙硬件厂商

一、USB OTG的模式 host模式&#xff08;下行&#xff09;&#xff1a;为u盘等设备供电&#xff0c;不可以进行调试&#xff0c;连接adb或者烧录等操作。 device模式&#xff08;上行&#xff09;&#xff1a;可以进行调试&#xff0c;连接adb或者烧录等操作&#xff0c;即US…

Delphi5实现主要——明细型数据库应用

文章目录 效果图主要——明细型数据库特点 数据库实现方式完整代码 效果图 主要——明细型数据库 在Delphi中&#xff0c;主要——明细型数据库是一种数据库应用程序的设计模式&#xff0c;它涉及到多个数据库表之间的关联操作&#xff0c;以实现对复杂数据结构的有效管理。这…

数据结构(邓俊辉)学习笔记】串 16——Karp-Rabin算法:串即是数

文章目录 1. 化串为数2. 凡物皆数3. 亦是数 1. 化串为数 接下来的这节&#xff0c;我们再来讨论一种十分另类的串匹配算法&#xff0c;也就是所谓的 Karp-Rabin 算法。回顾此前所介绍的几种串匹配算法&#xff0c;我们所面临的难题是一样的。也就是说在这里&#xff0c;我们每次…

ES配合高德地图JS-API实现地理位置查询

目录 实现功能点 技术选型 具体实现 Vue3整合高德地图JS API-2.0 添加商户&#xff1a;前端 添加商户&#xff1a;后端/ES 查询用户当前地理坐标 获取附近&#xff08;指定距离&#xff09;的商户 总结/测试Demo代码地址 测试概述&#xff1a;用户使用高德地图组件获取商户…

GPT实现的adb shell命令实现某音自动点赞和关注

摘要:这个可能是没啥用的自动点赞和关注功能,自娱自乐为主哈 具体可行性步骤如下: 1.打开手机的开发者选项,将指针位置的设置开关打开,目的是看触屏时的坐标值 2.随便打开一个抖音,找到点赞的爱心图标的坐标轴,并记下来,待会有用 备注:尽量获取爱心尖端的坐标值,由…

erlang学习:用OTP构建系统2,警报管理

今日学习用OTP构建系统的警报管理&#xff0c; 首先进行配置错误记录器 [{sasl,[{sasl_error_logger, false},{error_logger_mf_dir, "/code/erlang/erlangstudy"},{error_logger_mf_maxbytes, 10485760},{error_logger_mf_maxfiles, 10}]} ].警报处理器gen_event的…

【Material-UI】Slider 组件中的 Discrete Sliders 详解

文章目录 一、Slider 组件概述1. 组件介绍2. Discrete Sliders 的特点 二、Discrete Sliders 的基本用法1. step 属性2. marks 属性3. valueLabelDisplay 属性 三、深入理解 Discrete Sliders 的配置1. 自定义刻度标记2. 限制可选值3. 设置较小的步长4. 始终显示值标签 四、应用…

Win10+GTX1050Ti安装Pytorch

目的 本文主要记录自己安装pytorch过程。 环境&#xff1a;win10 pycharm 显卡&#xff1a;GTX1050Ti 过程记录 1、确认pytorch版本 打开pytorch官网&#xff1a;https://pytorch.org/ 选择stable 2.3.0 版本&#xff0c;CUDA有11.8及12.1&#xff0c;我们看看GTX1050Ti支持…

发红包案例(java)

User类创建 public class User {private String name;private int money;public User(){}public User(String name,int money){this.namename;this.moneymoney;}public void show(){System.out.println("Name:"name" Money:"money);}public String getNam…

ruoyi-vue-pro(v3)

启动上的问题 这里第二部npm install会有问题 切换成http 解决SSL 证书问题导致的连接错误 npm config set registry http://registry.npm.taobao.org/

Zookeeper 官方示例2-SyncPrimitive 代码解读(二)

测试命令 java jar .\ZookeeperDemo-0.0.1-SNAPSHOT.jar bTest 192.168.206.100:2181 2 1. Barrier&#xff08;阻塞原语&#xff09; 1.1 概念 [!quote] A barrier is a primitive that enables a group of processes to synchronize the beginning and the end of a comput…

猫头虎 分享:Python库 NumPy 的简介、安装、用法详解入门教程

猫头虎 分享&#xff1a;Python库 NumPy 的简介、安装、用法详解入门教程 &#x1f431;&#x1f42f; 摘要 在Python编程领域&#xff0c;特别是人工智能和数据科学方向&#xff0c;NumPy库的重要性不言而喻。 作为一个强大且广泛使用的库&#xff0c;NumPy为我们提供了处理…

WLAN原理实验简述——AP上线

一、需求&#xff1a; AP通过AC上线。 AC通过控制VLAN管理AP,创建VLAN100和放行。 AP同AC建立CAPWAP关系。 二、实验拓扑图&#xff1a; 三、实验步骤&#xff1a; LSW1: sys Enter system view, return user view with CtrlZ. [Huawei]Sysname lsw1 [lsw1]undo info enable I…