c++实现各种排序算法

简介: 笔记

1.冒泡排序

#if 1
#include<iostream>
using namespace std;
int main()
{
  int t[10] = { 2,5,7,3,1,8,6,3,7,0 };
  int flag=0;
  for (int i = 1; i < 10; i++)
  {   
    for (int j = 0; j < 10 - i; j++)
      if (t[j] > t[j + 1])
        swap(t[j], t[j + 1]),flag=1;
    if (flag == 0)  break;
    flag == 0;
  }
  for (int i = 0; i < 10; i++)
    cout << t[i] << " ";
  return 0;
}
#endif

2.选择排序

#if 1
#include<iostream>
using namespace std;
int main()
{
  int t[10] = { 2,5,7,3,1,8,6,3,7,0 };
  for (int i = 0; i < 9; i++)
  {
    int min=i;
    for (int j = i + 1; j < 10; j++)
      if (t[min] > t[j])
        min = j;
    swap(t[i], t[min]);
  }
  for (int i = 0; i < 10; i++)
    cout << t[i] << " ";
  return 0;
}
#endif

3.插入排序

#if 1
#include<iostream>
using namespace std;
int main()
{
  int t[10] = { 2,5,7,3,1,8,6,3,7,0 };
  for (int i = 1; i < 9; i++)
  {
    for (int j = i +1; j > 0; j--)
      if (t[j] < t[j-1])
        swap(t[j-1], t[j]);
  }
  for (int i = 0; i < 10; i++)
    cout << t[i] << " ";
}
#endif

4.希尔排序

#if 1
#include<iostream>
using namespace std;
int main()
{
  int t[10] = { 2,5,7,3,1,8,6,3,7,0 };
  for (int div = 10 / 2; div >= 1; div /= 2)
    for (int k = 0; k < div; k++)
      for (int i = div + k; i < 10; i += div)
        for (int j = i; j > k; j -= div)
        {
          if (t[j] < t[j - div])
            swap(t[j], t[j - div]);
          else
            break;
        }
  for (int i = 0; i < 10; i++)
    cout << t[i] << " ";
  return 0;
}
#endif 

5.快速排序

#if 1
#include<iostream>
using namespace std;
int t[10] = { 2,5,7,3,1,8,6,3,7,0 };
void quike(int left, int right)
{
  int i = left;
  int j = right;
  int temp = t[left];
  int k;
  if (left >= right) return;
  while (i < j)
  {
    while (i < j && temp <= t[j])
      j--;
    while (i<j && temp>=t[i])
      i++;
    if (i < j)
      k=t[i],t[i]=t[j],t[j]=k;
  }
  if (i == j)
    k = t[left], t[left]=t[i],t[i]=k;
  cout << i << " " << j << endl;
  quike(left, j-1);
  quike(j+1, right);
}
int main()
{
  quike(0, 9);
  for (int i = 0; i < 10; i++)
    cout << t[i] << " " ;
}
#endif

6.归并排序

#if 1
#include<iostream>
using namespace std;
void merge(int* a, int l, int mid, int r)
{
  int n1 = mid - l+1;
  int n2 = r - mid;
  int* L = new int[n1+1];
  int* R = new int[n2+1];
  for (int i = 0; i < n1; i++)
    L[i] = a[i + l];
  for (int i = 0; i < n2; i++)
    R[i] = a[mid + 1 + i];
  L[n1] = 11111111;
  R[n2] = 11111111;       //以便下面的归并操作,不然会内存溢出的;
  int i = 0, j = 0;
  int k = l;
  for (; k <=r; k++)
  {
    if (L[i] >= R[j])
      a[k] = R[j++];
    else
      a[k] = L[i++];
  }
  delete[]L;
  delete[]R;
}
void mergesort(int *a, int l, int r)
{
  if (r > l)
  {
    int mid = (l + r) / 2;
    mergesort(a, l, mid);
    mergesort(a, mid + 1, r);
    merge(a, l, mid, r);
  }
}
int main()
{
  int t[10] = { 2,5,7,3,1,8,6,3,7,0 };
  mergesort(t, 0, 9);
  for (int i = 0; i < 10; i++)
    cout << t[i] << " ";
}
#endif

7.堆排序

#if 1
#include<iostream>
using namespace std;
void heapify(int arr[], int n, int i)
{
  int largest = i;
  int l = i * 2 + 1;
  int r = i * 2 + 2;
  if (l<n && arr[l]>arr[largest])
    largest = l;
  if (r<n&&arr[r]>arr[largest])
    largest = r;
  if (largest != i)
  {
    swap(arr[i], arr[largest]);
    heapify(arr, n, largest);
  }
}
void heapsort(int arr[], int n)
{
  for (int i = n / 2 - 1; i >= 0; i--)
    heapify(arr, n, i);
  for (int i = n - 1; i >= 0; i--)
  {
    swap(arr[0], arr[i]);
    heapify(arr, i, 0);
  }
}
int main()
{
  int t[10] = { 2,5,7,3,1,8,6,3,7,0 };
  heapsort(t, 10);
  for (int i = 0; i < 10; i++)
    cout << t[i] << " ";
}
#endif

8.基数排序

#if 0
#include<iostream>
using namespace std;
int maxbit(int data[], int n)
{
  int d = 1;
  int p = 10;
  for (int i = 0; i < n; i++)
    while (data[i] >= p)
      p *= 10, ++d;
  return d;
}
void base_sort(int a[], int n)
{
  int d = maxbit(a, n);
  int *temp = new int[n];
  int *count = new int[10];
  int i, j, k;
  int radix = 1;
  for (i = 1; i <= d; i++)
  {
    for (j = 0; j < 10; j++)
      count[j] = 0;
    for (j = 0; j < n; j++)
    {
      k = (a[j] / radix) % 10;
      count[k]++;
    }
    for (j = 1; j < 10; j++)
      count[j] = count[j - 1] + count[j];
    for (j = n - 1; j >= 0; j--)
    {
      k = (a[j] / radix) % 10;
      temp[count[k] - 1] = a[j];
      count[k]--;
    }
    for (j = 0; j < n; j++)
      a[j] = temp[j];
    radix = radix * 10;
  }
  delete[]temp;
  delete[]count;
}
int main()
{
  int t[10] = { 2,5,7,3,1,8,6,3,7,0 };
  base_sort(t, 10);
  for (int i = 0; i < 10; i++)
    cout << t[i] << " ";
}
#endif

各个算法的原理请去百度百科查找,那里有各种算法的信息解释,以及扩展,在这里就说明了。

Thank for your reading


公众号:FPGA之旅

目录
相关文章
|
3天前
|
存储 算法 安全
基于红黑树的局域网上网行为控制C++ 算法解析
在当今网络环境中,局域网上网行为控制对企业和学校至关重要。本文探讨了一种基于红黑树数据结构的高效算法,用于管理用户的上网行为,如IP地址、上网时长、访问网站类别和流量使用情况。通过红黑树的自平衡特性,确保了高效的查找、插入和删除操作。文中提供了C++代码示例,展示了如何实现该算法,并强调其在网络管理中的应用价值。
|
8天前
|
算法 安全 C++
用 C++ 算法控制员工上网的软件,关键逻辑是啥?来深度解读下
在企业信息化管理中,控制员工上网的软件成为保障网络秩序与提升办公效率的关键工具。该软件基于C++语言,融合红黑树、令牌桶和滑动窗口等算法,实现网址精准过滤、流量均衡分配及异常连接监测。通过高效的数据结构与算法设计,确保企业网络资源优化配置与安全防护升级,同时尊重员工权益,助力企业数字化发展。
32 4
|
4月前
|
存储 算法 安全
超级好用的C++实用库之sha256算法
超级好用的C++实用库之sha256算法
162 1
|
3月前
|
算法 数据处理 C++
c++ STL划分算法;partition()、partition_copy()、stable_partition()、partition_point()详解
这些算法是C++ STL中处理和组织数据的强大工具,能够高效地实现复杂的数据处理逻辑。理解它们的差异和应用场景,将有助于编写更加高效和清晰的C++代码。
54 0
|
3月前
|
存储 算法 程序员
迪杰斯特拉(Dijkstra)算法(C/C++)
迪杰斯特拉(Dijkstra)算法(C/C++)
|
3月前
|
人工智能 算法 Java
【搜索算法】数字游戏(C/C++)
【搜索算法】数字游戏(C/C++)
|
4月前
|
存储 算法 安全
超级好用的C++实用库之国密sm4算法
超级好用的C++实用库之国密sm4算法
105 0
|
4月前
|
算法 安全 Serverless
超级好用的C++实用库之国密sm3算法
超级好用的C++实用库之国密sm3算法
154 0
|
4月前
|
算法 数据安全/隐私保护 C++
超级好用的C++实用库之MD5信息摘要算法
超级好用的C++实用库之MD5信息摘要算法
105 0
|
5月前
|
算法 C++ 容器
C++标准库中copy算法的使用
C++标准库中copy算法的使用
44 1