算法(Algorithms)

适用范围:入门级
难度系数:3

1、最大、最小值(max, min)

max: Returns the largest of a and b. If both are equivalent, a is returned.
min:Returns the smallest of a and b. If both are equivalent, a is returned.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
#include <iostream>     
#include <algorithm>    
using namespace std;

int main () {
  cout << "min(1,2)==" <<min(1,2) << '\n';
  cout << "max(2,1)==" <<max(2,1) << '\n';
  cout << "min('a','z')==" <<min('a','z') << '\n';
  cout << "max('a','z')==" <<max('a','z') << '\n';
  cout << "min(3.14,2.72)==" <<min(3.14,2.72) << '\n';
  cout << "max(3.14,2.73)==" <<max(3.14,2.73) << '\n';
  return 0;
}

2、交换(swap)

格式:swap(a,b)
参数:该函数接受两个必须交换的必需参数a和b。参数可以是任何数据类型。
返回值:该函数不返回任何内容,它交换两个变量的值。

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
#include <iostream>
#include <algorithm>
using namespace std;
int main(){
  int a=3,b=4;
  string c="cat",d="dog";
  swap(a,b);
  cout<<a<<"  "<<b<<endl;
  swap(c,d);
  cout<<c<<" "<<d;
}

edit & run

3、排序函数(sort)

OJ平台:P1051

格式:sort(first_pointer,first_pointer+n,cmp) 该函数可以给数组,或者链表list、向量排序。

实现原理:sort并不是简单的快速排序,它对普通的快速排序进行了优化,此外,它还结合了插入排序和堆排序。系统会根据你的数据形式和数据量自动选择合适的排序方法,这并不是说它每次排序只选择一种方法,它是在一次完整排序中不同的情况选用不同方法,比如给一个数据量较大的数组排序,开始采用快速排序,分段递归,分段之后每一段的数据量达到一个较小值后它就不继续往下递归,而是选择插入排序,如果递归的太深,他会选择堆排序。

此函数有3个参数:
参数1:第一个参数是数组的首地址,一般写上数组名就可以,因为数组名是一个指针常量。
参数2:第二个参数相对较好理解,即首地址加上数组的长度n(代表尾地址的下一地址)。
参数3:默认可以不填,如果不填sort会默认按数组升序排序。也就是1,2,3,4排序。可以实现降序。也可以自定义一个排序函数,改排序方式为降序什么的,也就是4,3,2,1这样。

使用此函数需先包含:#include <algorithm>
并且导出命名空间:using namespace std;
简单例子:对数组A的0~n-1元素进行升序排序,只要写sort(A,A+n)即可;对于向量V也一样,sort(v.begin(),v.end())即可。

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
#include <iostream>
#include <string>
#include <algorithm>
using namespace std;

bool compare(int a,int b){
    return a>b;  //如果是return a<b 就是升序排序;
}

int main(){
  int a[]={5,2,3,4,1,6,0};
  string b="asbtlk";
    char c[]={'e','g','a','y'};
     sort(a,a+7);  //默认从小到大,升序
     //降序有两种方式,第一是直接调用函数,第二种是greater<数据类型>()
     //sort(a,a+7,compare);
     //sort(a,a+5,greater<int>()); 
     //从大到小
    for (int i = 0; i <7 ; ++i) {
        cout<<a[i]<<' ';
    }
    cout<<endl;
    sort(c,c+4);
    cout<<c<<endl;
    sort(b.begin(),b.end()); //sort(b.begin(),b.begin()+3);
    cout<<b<<endl;
}

如果是多维数组,采用以下方法:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
/****************************************************************
 * multi array STL sort.
 * author: Alex Li
 * date:  2023-4
 * version: 1.0
****************************************************************/
 
#include <iostream>
#include <algorithm>
using namespace std;
#define R 3
#define C 3
 
void SortFun(int arr[R][C]){
    // One by one sort
    // individual rows.
    for (int i = 0; i < R; i++)
        sort(arr[i], arr[i] + C);
 }
 // Printing the sorted matrix
void Display(int arr[R][C]){
     for (int i = 0; i < R; i++) {
        for (int j = 0; j < C; j++)
            cout << (arr[i][j]) << " ";
        cout << endl;
    }
}

int main(){
    // Initialize the 2D array
    int arr[3][3]
        = { { 3,2,1 }, { 6, 5, 4 }, { 9, 8, 7 } };
    //sort(arr[0],arr[0]+3);
    // Sort the 2D array using the function
    SortFun(arr);
    Display(arr);
    return 0;
}

结构体排序方法:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
/****************************************************************
 * A C++ program to demonstrate STL sort() using  our own comparator for stuct
 * author: Alex Li
 * date: 2023-4
 * version: 1.0
 ****************************************************************/

#include <iostream>
#include <algorithm>
using namespace std;
  
// An interval struct has a start time and end time
struct Interval {
    int start, end;
};
  
// Compares two intervals according to starting times.
bool compareInterval(Interval i1, Interval i2)
{
    return (i1.start < i2.start);
}
  
int main()
{
    Interval arr[]
        = { { 6, 8 }, { 1, 9 }, { 2, 4 }, { 4, 7 } };
    //how many elements in the array.
    int n = sizeof(arr) / sizeof(arr[0]);
  
    // sort the intervals in increasing order of start time
    sort(arr, arr + n, compareInterval);
  
    cout << "Intervals sorted by start time : \n";
    for (int i = 0; i < n; i++)
        cout << "[" << arr[i].start << "," << arr[i].end
             << "] ";
  
    return 0;
}

4、反转(reverse)

实现数组、字符串、向量的元素反转。也就是原来顺序的逆序
它的反转区间是左闭右开[i, j)

数组:
reverse(a,a+n) a是数组名
int s[]={0,1,2,3,4,5};
reverse(s,s+6);
输出结果是5,4,3,2,1,0
reverse(a+m,a+n) 从数组a[m]~a[n-1]反转
int s[]={0,1,2,3,4,5};
reverse(s+1,s+4);
输出结果是0,3,2,1,4,5

字符串:
string s=”abcde”;
reverse(s.begin(), s.end())
如果是区间也遵循左闭右开的原则。

向量:
vector<int> vec={1,2,3,4,5}
reverse(vec.begin(), vec.end())

4、查找(find)

在 C++ 中,find 是标准库中的 一个通用算法,用于在容器(如 std::vector, std::list 等)中查找满足条件的元素。

头文件:<algorithm>

参数:

  • firstlast:指定查找的范围([first, last))。
  • value:需要查找的值。

返回值:

  • 如果找到目标值,返回指向该元素的迭代器(指针)。
  • 如果未找到目标值,返回 last

复杂度

  • 时间复杂度为 O(n),因为std::find会逐一比较范围内的每个元素。

示例代码:在容器中查找值

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
#include <iostream>
#include <vector>
#include <algorithm> // std::find
using namespace std; // 引入标准命名空间

int main() {
    vector<int> nums = {10, 20, 30, 40, 50};

    // 查找值为30的元素
    auto it = find(nums.begin(), nums.end(), 30);

    if (it != nums.end()) {
        cout << "Found 30 at index: " << distance(nums.begin(), it) << endl;
    } else {
        cout << "30 not found in the vector." << endl;
    }

    return 0;
}

注意事项

  • 如果你需要频繁查找元素,考虑使用其他容器,例如std::setstd::unordered_set,它们提供 O(1) 或 O(log n) 的查找效率。
  • 对于std::vector,如果需要快速查找,建议对其排序后使用二分查找(std::binary_search)。

4、遍历(for_each)

5、排列(permutation)

6、二分查找(binary_search, lower_bound, upper_bound)

头文件:#include <algorithm>

1、binary_search
查找指定值是否存在
a. 函数模板: binary_search(arr[],arr[]+size,indx)
b. 参数说明:
arr[] :数组首地址
size:数组元素的个数
indx:需要查找的值
c:函数功能:在数组中以二分法检索的方式查找,若在数组(要求数组元素非递减)中查找到indx元素则返回true,若查找不到则返回值为flase。;

2. lower_bound:
功能:查找第一个大于或等于某个元素的位置。
a.函数模板:lower_bound(arr[],arr[]+size , indx):
b.参数说明:
arr[]: 数组首地址
size:数组元素个数
indx:需要查找的值
c.函数功能: 函数lower_bound()在first和last中的前闭后开区间进行二分查找,返回大于或等于val的第一个元素位置(注意是地址)。如果所有元素都小于val,则返回last的位置。
注意:函数lower_bound()在first和last中的前闭后开区间进行二分查找,返回大于或等于val的第一个元素位置。如果所有元素都小于val,则返回last的位置,且last的位置是越界的!

3.upper_bound:查找第一个大于某个元素的位置。
a.函数模板:upper_bound(arr[],arr[]+size , indx):
b.参数说明:
arr[]: 数组首地址
size:数组元素个数
indx:需要查找的值
c.函数功能:函数upper_bound()返回的在前闭后开区间查找的关键字的上界,返回大于val的第一个元素位置。

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
#include<iostream>
#include<algorithm>
using namespace std;
int main()
{
    int a[100]= {4,10,11,30,69,70,96,100};
    int b=binary_search(a,a+9,11);//查找成功,返回1
    cout<<b<<endl;
    int c=binary_search(a,a+9,40);//查找失败,返回0
    cout<<c<<endl;
    int d=lower_bound(a,a+9,10)-a;
    cout<<d<<endl;
    int e=lower_bound(a,a+9,69)-a;
    cout<<e<<endl;
    int f=upper_bound(a,a+9,10)-a;
    cout<<f<<endl;
    int g=upper_bound(a,a+9,69)-a;
    cout<<g<<endl;
}
Scroll to Top