查找假币--天平秤重法(C++,完善版)

2023-10-19 09:50

本文主要是介绍查找假币--天平秤重法(C++,完善版),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、题目

编写一个实验程序查找假币,有n(n>3)个硬币,其中有一个假币,且假币较轻,采用天平秤重方式找到这个假币,并给出操作步骤。

本篇文章是基于博主(逆风的蔷薇)的思路进行进一步完善的,感谢大神的思路!!

附原文链接:

http:// https://blog.csdn.net/fly_yr/article/details/48350551?utm_source=app&app_version=5.0.1&code=app_1562916241&uLinkId=usr1mkqgl919blen

#include<iostream>
using namespace std;
#define MAX 30
int found(int weight[],int left,int right)
{if (left == right)//如果只有一枚硬币,则返回0return 0;else if (left == right - 1)//如果有两枚硬币,则返回较轻的硬币{if (weight[left] == weight[right])	//两枚硬币一样重,返回-1return -1;else if (weight[left] > weight[right])	//左边比右边重,则返回右边的硬币return right + 1;else   //否则返回左边的额硬币return left + 1;}int left_weight=0;//记录左边的重量int right_weight=0;//记录右边的重量//如果是偶数个硬币if ((right - left + 1) % 2 == 0){for (int i = left; i < (left + (right - left + 1) / 2); i++)//记录左边的重量left_weight += weight[i];for (int j = left + (right - left + 1) / 2; j < right; j++)//记录右边的重量right_weight += weight[j];if (left_weight == right_weight)//如果左右一样重,则返回-1return -1;else{if (left_weight < right_weight)//右边重于左边,则对左边进行再次二分法天平秤重found(weight, left, left + (right - left) / 2);else						//否则对右边进行再次二分法天平秤重found(weight, left + (right - left + 1) / 2, right);}}//如果是奇数枚硬币else if ((right - left + 1) % 2 != 0){for (int i = 0; i <= left + (right - left + 1) / 2 -1; i++)//记录左边的重量left_weight += weight[i];for (int j = left + (right - left + 1) / 2 + 1; j <= right; j++)//记录右边的重量right_weight += weight[j];//如果两边一样重,且左边的某个硬币重量和中间的硬币重量一样重,则返回-1if (left_weight == right_weight && weight[left] == weight[left + (right - left+ 1) / 2])return -1;//否则返回中间值else if (left_weight == right_weight && weight[left] > weight[left + (right - left + 1) / 2])return left + (right - left + 1) / 2+1;//如果两边不一样重,再次进行类似判断else{if (left_weight < right_weight)found(weight, left, left + (right - left + 1) / 2-1);elsefound(weight, left + (right - left + 1) / 2 + 1, right);}}
}int main()
{int coin_weight[MAX];int NUM;while (1){cout << "请输入硬币个数:";cin >> NUM;cout << "请输入每枚硬币的重量" << endl;for (int i = 0; i < NUM; i++)cin >> coin_weight[i];int judge = found(coin_weight, 0, NUM - 1);if (judge == -1)cout << "无假币!" << endl;else if (judge == 0)cout << "无法判断是否是假币!" << endl;elsecout << "第" << judge << "个是假币" << endl;cout << "======================" << endl;cout << endl;}
}

运行结果:

欢迎各位大佬指出错误~

这篇关于查找假币--天平秤重法(C++,完善版)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/239017

相关文章

C++ 右值引用(rvalue references)与移动语义(move semantics)深度解析

《C++右值引用(rvaluereferences)与移动语义(movesemantics)深度解析》文章主要介绍了C++右值引用和移动语义的设计动机、基本概念、实现方式以及在实际编程中的应用,... 目录一、右值引用(rvalue references)与移动语义(move semantics)设计动机1

C++ move 的作用详解及陷阱最佳实践

《C++move的作用详解及陷阱最佳实践》文章详细介绍了C++中的`std::move`函数的作用,包括为什么需要它、它的本质、典型使用场景、以及一些常见陷阱和最佳实践,感兴趣的朋友跟随小编一起看... 目录C++ move 的作用详解一、一句话总结二、为什么需要 move?C++98/03 的痛点⚡C++

详解C++ 存储二进制数据容器的几种方法

《详解C++存储二进制数据容器的几种方法》本文主要介绍了详解C++存储二进制数据容器,包括std::vector、std::array、std::string、std::bitset和std::ve... 目录1.std::vector<uint8_t>(最常用)特点:适用场景:示例:2.std::arra

C++构造函数中explicit详解

《C++构造函数中explicit详解》explicit关键字用于修饰单参数构造函数或可以看作单参数的构造函数,阻止编译器进行隐式类型转换或拷贝初始化,本文就来介绍explicit的使用,感兴趣的可以... 目录1. 什么是explicit2. 隐式转换的问题3.explicit的使用示例基本用法多参数构造

C++,C#,Rust,Go,Java,Python,JavaScript的性能对比全面讲解

《C++,C#,Rust,Go,Java,Python,JavaScript的性能对比全面讲解》:本文主要介绍C++,C#,Rust,Go,Java,Python,JavaScript性能对比全面... 目录编程语言性能对比、核心优势与最佳使用场景性能对比表格C++C#RustGoJavapythonjav

C++打印 vector的几种方法小结

《C++打印vector的几种方法小结》本文介绍了C++中遍历vector的几种方法,包括使用迭代器、auto关键字、typedef、计数器以及C++11引入的范围基础循环,具有一定的参考价值,感兴... 目录1. 使用迭代器2. 使用 auto (C++11) / typedef / type alias

C++ scoped_ptr 和 unique_ptr对比分析

《C++scoped_ptr和unique_ptr对比分析》本文介绍了C++中的`scoped_ptr`和`unique_ptr`,详细比较了它们的特性、使用场景以及现代C++推荐的使用`uni... 目录1. scoped_ptr基本特性主要特点2. unique_ptr基本用法3. 主要区别对比4. u

C++11中的包装器实战案例

《C++11中的包装器实战案例》本文给大家介绍C++11中的包装器实战案例,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录引言1.std::function1.1.什么是std::function1.2.核心用法1.2.1.包装普通函数1.2.

C++多线程开发环境配置方法

《C++多线程开发环境配置方法》文章详细介绍了如何在Windows上安装MinGW-w64和VSCode,并配置环境变量和编译任务,使用VSCode创建一个C++多线程测试项目,并通过配置tasks.... 目录下载安装 MinGW-w64下载安装VS code创建测试项目配置编译任务创建 tasks.js

C++ 多态性实战之何时使用 virtual 和 override的问题解析

《C++多态性实战之何时使用virtual和override的问题解析》在面向对象编程中,多态是一个核心概念,很多开发者在遇到override编译错误时,不清楚是否需要将基类函数声明为virt... 目录C++ 多态性实战:何时使用 virtual 和 override?引言问题场景判断是否需要多态的三个关