【基础算法】分治算法 & C++实现

简介: 分治算法的基本思想是将一个规模为N的问题分解为K个规模较小的子问题,这些子问题相互独立且与原问题性质相同。求出子问题的解,就可得到原问题的解。即一种分目标完成程序算法,简单问题可用二分法完成。下面的硬币问题就是分治算法的一种典型算法题。

简要介绍:


       分治算法的基本思想是将一个规模为N的问题分解为K个规模较小的子问题,这些子问题相互独立且与原问题性质相同。求出子问题的解,就可得到原问题的解。即一种分目标完成程序算法,简单问题可用二分法完成。下面的硬币问题就是分治算法的一种典型算法题。


●硬币问题


       在下面我们将硬币分为1和0两个值,1为真硬币,0为假硬币。找偶数枚硬币和奇数枚硬币将其随机排成一列,其中有一个假硬币,用分治算法寻找出这枚假硬币所在的位置。如下两图所示:


当硬币个数为偶数时(10枚):

a97c4e4ce3335ad80ea6256860d479d1_c98c1b0a6ad84168a195efba835a4dbd.png

当硬币个数为奇数时(13枚):

1ac08754c04a78c002bd62e4dd1a5cd2_9e0abdc0a8364362a112b82553da0221.png

代码实现:

#include<iostream>
using namespace std;
#define maxsize 20
class fenzhi {
public:
  int falsecoin(int low, int high);
  void showresult();
  int num;
  int coin[maxsize];
  int result;
};
int fenzhi::falsecoin(int low, int high)
{
  int sum1=0;
  int sum2=0;
  int sum3=0;
  if (low + 1 == high)  //只有两枚硬币
  {
  if (coin[low] < coin[high])
  {
    result = low + 1;
    return result;
  }
  else
  {
    result = high + 1;
    return result;
  }
  } 
  //分治算法
  if((high-low+1)%2==0)  //n是偶数
  { 
  for (int i = low; i <= low+(high-low)/2; i++)
  {
    sum1 += coin[i];//前半段和
  }
  for (int j = low + (high - low) / 2+1; j <= high; j++)
  {
    sum2 += coin[j];//后半段和
  }
  if (sum1 > sum2)
  {
    result = falsecoin(low + (high - low) / 2 + 1, high); //递推后半段
    return result;
  }
  else if(sum1 < sum2)
  {
    result = falsecoin(low, low + (high - low) / 2); //递推前半段
    return result;
  }
  }
  else  //n是奇数
  {
  for (int i = low;i<=low+(high-low)/2-1;i++)
  {
    sum1 += coin[i];   //中位数的前半段和
  }
  for (int j = low + (high - low) / 2+1; j <= high; j++)
  {
    sum2 += coin[j];   //中位数的后半段和
  }
  sum3 = coin[low + (high - low) / 2];   //中位数
  if (sum1 > sum2)      //前半段和大于后半段和
  {
    result = falsecoin(low + (high - low) / 2 + 1, high);//递推后半段
    return result;
  }
  else if (sum1 < sum2)   //前半段和小于后半段和
  {
    result = falsecoin(low, low + (high - low) / 2 - 1);//递推前半段
    return result;
  }
  if (sum1 + sum3 == sum2 + sum3)    //前半段和加中位数等于后半段和加中位数,所以中位数为目标寻找值
  {
    result = low + (high - low) / 2+1;
    return result;
  }
  }
}
void fenzhi::showresult()
{
  cout << "假币所在的位置:" << this->result << endl;
}
void text()
{
  fenzhi fz;
  cout << "输入硬币的总数目:" << endl;
  cin >> fz.num;
  cout << "请输入硬币的真假(1真/0假):" << endl;
  for (int i = 0; i < fz.num; i++)
  {
  cin >> fz.coin[i];
  }
  fz.falsecoin(0, fz.num - 1);
  fz.showresult();
}
int main()
{
  text();
}

ae37b88c97841913d7aeef0503643991_ad8961e3d0a74333bfba4bc5baec10c9.png

目录
相关文章
|
2天前
|
算法 数据中心 C++
基于C++雪花算法工具类Snowflake -来自chatGPT
基于C++雪花算法工具类Snowflake -来自chatGPT
8 1
|
8天前
|
算法 数据处理 C++
C++一分钟之-迭代器与算法
【6月更文挑战第21天】C++ STL的迭代器统一了容器元素访问,分为多种类型,如输入、输出、前向、双向和随机访问。迭代器使用时需留意失效和类型匹配。STL算法如查找、排序、复制要求特定类型的迭代器,注意容器兼容性和返回值处理。适配器和算法组合增强灵活性,但过度使用可能降低代码可读性。掌握迭代器和算法能提升编程效率和代码质量。
23 3
|
12天前
|
算法 前端开发 Linux
【常用技巧】C++ STL容器操作:6种常用场景算法
STL在Linux C++中使用的非常普遍,掌握并合适的使用各种容器至关重要!
38 10
|
14天前
|
算法 C++
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题-2
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题
|
14天前
|
算法 C++
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题-1
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题
|
14天前
|
存储 算法 C++
【数据结构与算法】:带你手搓顺序表(C/C++篇)
【数据结构与算法】:带你手搓顺序表(C/C++篇)
|
3天前
|
算法 搜索推荐 C++
C++之STL常用算法(遍历、查找、排序、拷贝、替换、算数生成、集合)
C++之STL常用算法(遍历、查找、排序、拷贝、替换、算数生成、集合)
12 0
|
8天前
|
算法
数据结构与算法===分治算法
数据结构与算法===分治算法
|
15天前
|
算法 C++
计算机算法设计与分析 第2章 递归与分治策略 (笔记)
计算机算法设计与分析 第2章 递归与分治策略 (笔记)
|
15天前
|
算法 C++
【c/c++算法】曼哈顿算法简单运用
【c/c++算法】曼哈顿算法简单运用