C/C++暴力/枚举/穷举题目持续更新(刷蓝桥杯基础题的进!)

目录

前言

 一、百钱买百鸡

二、百元兑钞

三、门牌号码(蓝桥杯真题)

 四、相乘(蓝桥杯真题)

五、卡片拼数字(蓝桥杯真题)

六、货物摆放(蓝桥杯真题)

七、最短路径(蓝桥杯真题)

八、完数(蓝桥杯真题)


前言

  循环有while,do-while,for三种形式,三者各自可以自己嵌套自己,也可以交叉嵌套。暴力破解法(穷举法)(枚举法),即用循环把该有的结果全部遍历出来,之后再用if语句做筛选,判断这个答案是不是我们需要的,此思想在蓝桥杯竞赛中相当重要。

解决此类题目的思路:

  首先我们应该确定穷举范围,不能多,不能少,要不然就容易漏掉一个。其次想应该用什么方式穷举,单层for循环或者嵌套,然后想if的判断条件。

  下面几道例题具体展现暴力的思想,每道题均采用问题描述,分析,代码实现和运行结果的形式呈现。

 一、百钱买百鸡

问题描述:

  我国古代数学家张丘建在《算经》一书中曾提出过著名的“百钱买百鸡”问题,该问题叙述如下:鸡翁一,值钱五;鸡母一,值钱三;鸡雏三,值钱一;百钱买百鸡,则翁、母、雏各几何?

  翻译过来,意思是公鸡一个五块钱,母鸡一个三块钱,小鸡三个一块钱,现在要用一百块钱买一百只鸡,问公鸡、母鸡、小鸡各多少只?

分析:

  思路讲解:假设买的全为公鸡,则最能买到20只,即100/5=20,所以x<=20;同理若买的全为母鸡则100/3=33余1,y<=33;此处小心小鸡数目不是300,而应该是100,因为题目要求了要买100只鸡,所以z<=100; if语句满足三个条件:1、一百元 2、一百只鸡 3、小鸡数量是三的倍数。

代码实现:


#include<iostream>
using namespace std;int main() {int x, y, z;              //分别代表公鸡,母鸡,小鸡的数量for (x = 0; x <= 20; x++) {for (y = 0; y <= 33; y++) {for(z=0;z<=100;z++)if (z % 3 == 0 && (5 * x + 3 * y + z / 3) == 100 && (x+y+z)==100) //满足三个条件:1、一百元 2、一百只鸡3、小鸡数量是三的倍数
{   cout << "公鸡,母鸡,小鸡数:" << x << " " << y << " " << z << " " << endl;}}}
}

运行结果: 

二、百元兑钞

问题描述:

  一百元可以兑换多少张10元,5元,1元?有多少种兑换方法?要求每种情况都要包含10元,5元,1元。

分析:
  和第一道题思路一致,三重循环暴力破解,设置count值求解次数。

代码实现:


//百元兑钞问题
int main() {int a, b, c,count=0;for (a = 1; a < 10; a++) for(b=1;b<20; b++)for (c = 1; c < 100; c++) if (100 == a * 10 + b * 5 + c) {cout << "10元有:" << a << "张";cout << "5元有:" << b << "张";cout << "1元有:" << c << "张";cout << endl;count++;break;//提高效率,每次兑换方案成功后跳出最内层循环}cout << "共有" << count << "种兑换方法";return 0;
}

运行结果

三、门牌号码(蓝桥杯真题)

问题描述:

  小蓝要为一条街的住户制作门牌号。这条街一共有2020位住户,门牌号从1到2020编号。小蓝制作门牌的方法是先制作0到9这几个数字字符,最后根据需要将字符粘贴到门牌上,例如门牌1017需要依次粘贴字符1、0、1、7,即需要1个字符0,2个字符1,1个字符7。请问要制作所有的1到2020号门牌,总共需要多少个字符2?

分析:

  此题比较简单,问题简化为:1~2020总共有多少个2?用到求一个数各位数字的思想,即把当前这个数每一位都拆出来。

拆解一个数的各位代码

代码实现:

int main() {int count = 0;for (int i = 1; i <= 2020; i++) {int n = i;while (n != 0) {int t = n % 10;n /= 10;if (t == 2)count++;}}cout<<"0~2020共有" << count<<"个2";return 0;
}

运行结果: 

 四、相乘(蓝桥杯真题)

问题描述:

  小蓝发现,他将 1 至 1000000007 之间的不同的数与 2021 相乘后再求除以 1000000007 的余数,会得到不同的数。
  小蓝想知道,能不能在 1 至 1000000007 之间找到一个数,与 2021 相乘后 再除以 1000000007 后的余数为 999999999。
  如果存在,请在答案中提交这个数; 如果不存在,请在答案中提交 0。

分析:  

此题非常简单,分析省略。

代码实现:

int main() {unsigned long long i,n=1000000007,b=999999999;for(i=1;i<=n;i++)if (i * 2021 % n == b) {cout << i;}
}

运行结果:


 

五、卡片拼数字(蓝桥杯真题)

问题描述:

本题为填空题,只需要算出结果后,在代码中使用输出语句将所填结果输出即可。小蓝有很多数字卡片,每张卡片上都是数字0到9。小蓝准备用这些卡片来拼一些数,他想从1开始拼出正整数,每拼一个,就保存起来,卡片就不能用来拼其它数了。小蓝想知道自己能从1拼到多少。例如,当小蓝有30张卡片,其中0到9各3张,则小蓝可以拼出1到10,但是拼11时卡片1已经只有一张了,不够拼出11。现在小蓝手里有0到9的卡片各2021张,共20210张,请问小蓝可以从1拼到多少?

分析:

依旧用到上一题求一个数各位数字的思想,比较拆出来的各位数和剩余卡片数量,卡片数量不够说明拼不了这个数字,这时退出循环,最多拼到上一个数。

代码实现:

int main()
{int cards[10] = { 2021,2021,2021,2021,2021,2021,2021,2021,2021,2021 };//定义一个整数数组cards,包含了数字0到9的卡片数量,每个数字的卡片数量都是2021int num = 1;  //ans代表所要拼接的数字int temp = 0; //用另一个变量操作numint temp2 = 0; //拆出的各位数字while (1) //用一个无限循环{temp = num;while (temp != 0)//第一次写的时候忘记了这条语句,当temp=0时,对该数操作完毕{temp2 = temp % 10;cards[temp2]--; //对应的该卡片数量减一if (cards[temp2] == 0) //说明对应卡片用完{cout << num - 1 << endl; //即最大的拼接数字为上一个数字return 0; //循环终止}temp = temp / 10;}num++;}return 0;

运行结果:

六、货物摆放(蓝桥杯真题)

问题描述:

  小蓝有一个超大的仓库,可以摆放很多货物。现在,小蓝有n 箱货物要摆放在仓库,每箱货物都是规则的正方体。小蓝规定了长、宽、高三个互相垂直的方向,每箱货物的边都必须严格平行于长、宽、高。小蓝希望所有的货物最终摆成一个大的立方体。即在长、宽、高的方向上分别堆L、W、H 的货物,满足n = L × W × H。给定n,请问有多少种堆放货物的方案满足要求。
例如,当n = 4 时,有以下6 种方案:1×1×4、1×2×2、1×4×1、2×1×2、2×2×1、4×1×1。
请问,当n = 2021041820210418 (注意有16 位数字)时,总共有多少种方案?

分析:

 当n = 4 时,1×1×4、1×2×2、1×4×1、2×1×2、2×2×1、4×1×1。通过这个例子,可以看出找出n的所有因子并求出所有的组合方式,存放到数组中,再使用三重循环遍历所有因子,找出所有因子用到求素数的思想。

代码实现:

#include<iostream>
#include<cmath>
using namespace std;
typedef unsigned long long A;
//typedef 是一个类型声明语句,它用于定义一个新的数据类型标识符,给一个已有的数据类型取别名。
//即unsigned long long ==A;A n = 2021041820210418;
A a[3000], cnt = 0; //存放因子
int main(void)
{//找出所有因子放进数组,素数思想for (int i = 1; i <= sqrt(n); i++) {if (n % i == 0) {a[++cnt] = i;if (i * i != n) //简化寻找次数a[++cnt] = n / i;}}//循环A count = 0; //计数for (int l = 1; l <= cnt; l++)for (int w = 1; w <= cnt; w++)for (int h = 1; h <= cnt; h++)if (a[l] * a[w] * a[h] == n) count++;cout << count;return 0;}

运行结果: 

七、最短路径(蓝桥杯真题)

问题描述:

  小蓝学习了最短路径之后特别高兴,他定义了一个特别的图,希望找到图中的最短路径。小蓝的图由2021 个结点组成,依次编号1 至2021。对于两个不同的结点a, b,如果a 和b 的差的绝对值大于21,则两个结点之间没有边相连;如果a 和b 的差的绝对值小于等于21,则两个点之间有一条长度为a 和b 的最小公倍数的无向边相连。

  例如:结点1 和结点23 之间没有边相连;结点3 和结点24 之间有一条无向边,长度为24;结点15 和结点25 之间有一条无向边,长度为75。
  请计算,结点1 和结点2021 之间的最短路径长度是多少。

分析:

求最小公倍数问题以及怎样找到并更新最短路径。

代码实现:

int main()
{int f[2022];  // 数组 f[j] 存放从节点 i到节点 j 的最短路径。memset(f, 0, sizeof f);for (int i = 1; i <= 2021; i++){for (int j = i + 1; j <= i + 21; j++) //考虑与节点 i 相差不超过 21 的节点 j。{if (j > 2021)//确保j不超出范围break;//把路径长度存储到数组中j对应的节点位置中if (f[j] == 0)  //如果节点 j 还没有被计算过(即 f[j] == 0),则将 f[j] 设置为从节点 i 到节点 j 的路径长度。f[j] = f[i] + j * i / gcd(i, j);   //j * i / gcd(i, j)为求最小公倍数elsef[j] = min(f[j], f[i] + j * i / gcd(i, j)); // 如果节点j已经有计算过的路径长度,则更新 f[j] 为当前的较短路径长度。}}cout << f[2021] << endl;return 0;
}

解释上面用到的函数:

1、memset(f, 0, sizeof f); 是一个用于将数组 f 中的所有元素初始化为 0 的函数调用。memset 是 C 标准库中的一个函数,用于将一段内存区域的每个字节设置为指定值,传递数组首地址,让memset 函数知道要操作的内存区域的起始地址,以及需要操作的字节范围。这种方式常用于在程序开始时将数组或其他内存区域初始化为特定的默认值,以确保它们在使用前具有一致的初始状态。这样可以消除未初始化变量可能导致的意外结果,并提高代码的可靠性。

2、min() 函数通常用于找出两个或多个值中的最小值。它可以是标准库中的函数,也可以是用户自定义的函数,C++ 标准库中的 min() 函数可能在 <algorithm> 头文件中定义,它接受两个或多个参数,并返回这些参数中的最小值。

运行结果:

八、完数(蓝桥杯真题)

问题描述:

编写一个程序,输出2~10000之间的所有完全数。完全数是指它的各因子(除该数本身外)之和正好等于该数本身的数。例如:6 = 1 + 2 + 3,28 = 1 + 2 + 4 + 7 + 14。

分析:

与第六题的货物摆放问题类似,首先找到所有一个数的所有因子,再判断。

代码:

#include <iostream>// 判断一个数是否为完数
bool isPerfectNumber(int number) {int sum = 0;for (int i = 1; i < number; i++) {if (number % i == 0) {sum += i;}}// 如果因子之和等于该数,则该数为完数return sum == number;
}int main() {for (int i = 1; i <= 10000; i++) {if (isPerfectNumber(i)) {std::cout << i << " 是完数" << std::endl;}}return 0;
}

运行结果:

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

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

相关文章

图解目标检测 之 【YOLOv9】 算法 最全原理详解

YOLOv9与SOTA模型对比 什么是 YOLOv9&#xff1f;YOLOv9是YOLO系列中的最新产品&#xff0c;是一种实时目标检测模型。它通过先进的深度学习技术和架构设计&#xff0c;包括通用 ELAN (GELAN) 和可编程梯度信息 (PGI)&#xff0c;展现出更好的性能。 YOLO 系列通过引入计算机视…

Java/Python/Go不同开发语言基础数据结构和相关操作总结-GC篇

Java/Python/Go不同开发语言基础数据结构和相关操作总结 1. 常见gc方式1.1 gc判断对象是否存活1.2 引用计数法1.2 标记-清除算法1.3 复制算法1.4 标记-压缩算法1.5 分代收集算法 2. java的gc方式以及垃圾回收器2.1 gc方式2.1 gc回收器2.1.1 Serial收集器2.1.2 ParNew收集器2.1.…

Socket、UDP、TCP协议和简单实现基于UDP的客户端服务端

目录 Socket TCP和UDP区别 UDP&#xff1a;无连接&#xff0c;不可靠传输&#xff0c;面向数据报&#xff0c;全双工 TCP&#xff1a;有连接&#xff0c;可靠传输&#xff0c;面向字节流&#xff0c;全双工 无连接和有连接 可靠传输和不可靠传输 面向数据报和面向字节流…

学习或从事鸿蒙开发工作,有学历要求吗?

目前安卓有2,000万的开发者。本科及以上学历占比为35%&#xff1b;iOS有2,400万开发者&#xff0c;本科及以上学历占比为40% 绝大多数的前端开发者都是大专及以下学历&#xff0c;在2023年华为开发者大会上余承东透露华为的开发者目前有200万&#xff0c;但鸿蒙开发者统计的数据…

C#,数组数据波形排序(Sort in Wave Form)的朴素算法与源代码

1 波形排序 所谓“波形排序”就是一大一小。 将n个身高互不相同的人排成一行 ,对于每个人 ,要求他要么比相邻的人均高 ,要么比相邻的人均矮 ,问共有多少种排法 ,这一问题称为波形排列问题。 2 源程序 using System; using System.Collections; using System.Collections.Gen…

[嵌入式系统-33]:RT-Thread -18- 新手指南:三种不同的版本、三阶段学习路径

目录 前言&#xff1a;学习路径&#xff1a;入门学习-》进阶段学习》应用开发 一、RT-Thread版本 1.1 标准版 1.2 Nano 1.3 Smart版本 1.4 初学者制定学习路线 1.5 RT-Thread在线文档中心目录结构 1.6 学习和使用RT-Thread的三种场景 二、入门学习阶段&#xff1a;内…

信息系统项目管理师论文分享(质量管理)

水一篇文章。我发现身边考高项的朋友很多都是论文没过&#xff0c;我想着那就把我的论文分享出来&#xff0c;希望能有帮助。 质量管理 摘要 2020年5月&#xff0c;我作为项目经理参加了“某市某医联体的互联网诊疗&#xff08;互联网医院和远程医疗&#xff09;平台”的建设…

编程的基础:理解时间和空间复杂度

编程的基础&#xff1a;理解时间和空间复杂度 时间复杂度空间复杂度示例常数时间复杂度 O(1)线性时间复杂度 O(n)线性对数时间复杂度 O(n log n)二次时间复杂度 O(n^2)指数时间复杂度 O(2^n) 空间复杂度示例常数空间复杂度 O(1)线性空间复杂度 O(n)线性对数空间复杂度 O(log n)…

apache 模式、优化、功能 与 nginx优化、应用

一、I/O模型——Input/Output模型 1.同步/异步 A程序需要调用B程序的某一个功能&#xff0c;A发送一个请求需要B完成一个任务 同步&#xff1a;B不会主动去通知A是否完成需要A自己去问 异步&#xff1a;B会主动通知A是否完成 2.阻塞/非阻塞 A发送一个请求需要B完成一个任务 …

Vision Mamba:使用双向状态空间模型进行高效视觉表示学习

模型效果 将DeiT和Vim模型之间的性能和效率比较&#xff0c;为了进行准确性比较&#xff0c;我们首先在IN1K分类数据集上预训练DeiT和Vim&#xff0c;然后在不同的下游密集预测任务上微调通用主干&#xff0c;即&#xff0c;语义分割、目标检测、实例分割。结果表明&#xff0c…

Maven 私服 Nexus3

一、Maven和Nexus3 简介 Maven是一个采用纯Java编写的开源项目管理工具&#xff0c;采用一种被称之为Project Object Model(POM)概念来管理项目&#xff0c;所有的项目配置信息都被定义在一个叫做POM.xml的文件中, 通过该文件Maven可以管理项目的整个生命周期&#xff0c;包括…

2024年危险化学品经营单位主要负责人证考试题库及危险化学品经营单位主要负责人试题解析

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 2024年危险化学品经营单位主要负责人证考试题库及危险化学品经营单位主要负责人试题解析是安全生产模拟考试一点通结合&#xff08;安监局&#xff09;特种作业人员操作证考试大纲和&#xff08;质检局&#xff09;特…

Ubuntu22.04和Windows10双系统安装

概要 本篇演示Ubuntu22.04和Windows10双系统的安装。先安装Ubuntu22.04&#xff0c;再安装Windows10。 一、说明 1、电脑 笔者的电脑品牌是acer(宏碁/宏基) 电脑开机按F2进入BIOS 电脑开机按F12进入Boot Manager 2、U盘启动盘 需要用到两个U盘启动盘 &#xff08;1&a…

市场复盘总结 20240223

仅用于记录当天的市场情况&#xff0c;用于统计交易策略的适用情况&#xff0c;以便程序回测 短线核心&#xff1a;不参与任何级别的调整&#xff0c;采用龙空龙模式 一支股票 10%的时候可以操作&#xff0c; 90%的时间适合空仓等待 二进三&#xff1a; 进级率中 57% 最常用的…

牛客周赛 Round 33 解题报告 | 珂学家 | 思维场

前言 整体评价 感觉这场更偏思维&#xff0c;F题毫无思路&#xff0c;但是可以模拟骗点分, E题是dij最短路. A. 小红的单词整理 类型: 签到 w1,w2 input().split() print (w2) print (w1)B. 小红煮汤圆 思路: 模拟 可以从拆包的角度去构建模拟 注意拆一包&#xff0c;可以…

vmware安装centos 7.9 操作系统

vmware安装centos 7.6 操作系统 1、下载centos 7.9 操作系统镜像文件2、安装centos 7.9 操作系统3、配置centos 7.6 操作系统3.1、配置静态IP地址 和 dns3.2、查看磁盘分区3.3、查看系统版本 1、下载centos 7.9 操作系统镜像文件 本文选择centos 7.9 最小化安装镜像包 这里选…

Nest创建神经元,并显示电压变化曲线

nest 安装与介绍 NEST&#xff08;神经模拟工具&#xff09;最初是在 1990 年代后期开发的。它的主要目标是作为计算神经科学模拟器。它支持具有不同生物学细节水平的各种神经元和突触模型。例如&#xff0c;NEST 的神经元模型范围从泄漏积分和激发模型到详细的 Hodgkin-Huxle…

python jupyter notebook打开页面方便使用

如果没安装jupyter, 请安装&#xff1a; pip install jupyter notebook 运行jupyter notebook jupyter-notebook

03|Order by与Group by优化

索引顺序依次是 &#xff1a; name,age,position 案例1 EXPLAIN SELECT * FROM employees WHERE name LiLei AND position dev ORDER BY age;分析: 联合索引中只是用到了name字段做等值查询[通过key_len 74可以看出因为name字段的len74]&#xff0c;在这个基础上使用了age进…

学会字符转换

字符转换 题目描述&#xff1a;解法思路&#xff1a;解法代码&#xff1a;运行结果&#xff1a; 题目描述&#xff1a; 输入⼀一个字符串&#xff0c;将字符串中大写字母全部转为小写字母&#xff0c;小写字母转成大写字母&#xff0c;其他字符保持不变。注&#xff1a;字符串…