枚举算法

什么是枚举?
  枚举,顾名思义,就是用最笨的方法,去解决问题(暴力枚举),一个集的枚举是列出某些有穷序列集的所有成员的程序,或者是一种特定类型对象的计数。这两种类型经常(但不总是)重叠。

枚举算法是我们在日常中使用到的最多的一个算法,它的核心思想就是:

枚举所有的可能
枚举法的本质就是从所有候选答案中去搜索正确的解,使用该算法需要满足两个条件:(1)可预先确定候选答案的数量;(2)候选答案的范围在求解之前必须有一个确定的集合。
接下来几道题可以让你更加的了解枚举

1.楼层编号
题目描述:

小林在NOIP比赛期间住在“新世界”酒店。和其他酒店不一样的是,这个酒店每天都有一个高能的数字t,这个数字在楼层中是不会出现的,以t=3为例,则3、13、31、33等楼层是不存在的,楼层编号为1,2,4,5,……所以实际上的4楼才是3楼
已知小林预定了编号为m层的房间,并且当天高能数字是t,现在他想知道房间所在的真实楼层是多少
1
2
3
4
输入描述

一行两个整数m和t,1<=m<=100000,0<=t<=9,保证m对t合法
1
输出描述

一行一个整数,表示真实楼层
1
样例输入

14 3

样例输出

12

思路:

1.包含这个高能数字的楼层一定不会出现,则有算法如下

bool s(int a,int b){
while(a!=){
if(a%==b){
return false;
}
a/=;
}
return true;
}

2.用for循环对sum进行累加,若不包含高能数字(即s(i,高能数字)=true)则sum++

for(int i=;i<=m;i++){
if(s(i,t)){
sum++;
}
}
cout<<sum

代码:

#include <iostream>
using namespace std;
bool s(int a,int b){
while(a!=){
if(a%==b){
return false;
}
a/=;
}
return true;
}
int main(){
int m,t,sum=;
cin>>m>>t;
for(int i=;i<=m;i++){
if(s(i,t)){
sum++;
}
}
cout<<sum;
return ;
}

2.冰壶比赛

题目描述:

在冰壶比赛中,给出一个目标点P以及一个规定的正整数r。每一局由甲和乙两队轮流投冰壶各8次后,该局比赛结束。此时,哪一方的冰壶最终离目标点P更近,该方得分,另一方不得分。得分方每颗离目标点P距离小于或等于r、位置较另一队所有冰壶都更接近目标点P的冰壶都可以得1分

比赛最多进行10局。双方之间的某局比赛结束后,落后一方可以弃权。此时,比赛不再进行下去

已知每一局结束时,双方的每个冰壶离目标点P的距离以及正整数r,请写一个程序判断两队之间每一局比赛的得分,以及总得分

输入:

第一行一个正整数r

以下有若干行(不超过20行),每一行8个正整数(之间用一个空格间隔)

第二行的第j个数表示第一局比赛结束时,甲方的第j个冰壶距离目标点P的距离

第三行的第j个数表示第一局比赛结束时,乙方的第j个冰壶距离目标点P的距离

……

第2k行的第j个数表示第k局比赛结束时,甲方的第j个冰壶距离目标点P的距离

第2k+1行的第j个数表示第k局比赛结束时,乙方的第j个冰壶距离目标点P的距离

如果有一方中途弃权,则最后一行(偶数行)只有一个整数-1,表示此时发生弃权情况

输出:

输出若干行,每行两个整数,中间以一个冒号间隔,表示每一局比赛甲乙双方的比分(甲得分在前)。最后一行有2个整数,中间以一个冒号间隔,表示甲乙双方比赛的最终得分(甲得分在前)

意思就是,先输入一个“标准”r,有10场比赛,每场比赛打8次,取最好成绩(最近的也就是最小的),再与对手最好成绩比较,比对手低的话一定不得分,比对手高的话还要比标准要小或等于才算得分,也就是说,每场比赛的得分,一定有一方不得分,有可能出现都不得分的情况,若弃权的话直接输出后return 0;即可。最后输出总的比分(计数即可)
1
2
3
主要还是枚举

样例输入

12

5 60 25 74 71 100 3 93

66 75 70 66 52 73 67 14

93 84 74 99 79 64 89 22

65 5 95 59 80 8 35 61

65 61 49 60 58 50 32 85

68 38 96 38 82 64 26 93

74 92 47 21 97 30 45 78

44 99 90 27 3 46 55 34

49 45 83 3 18 1 67 23

60 47 95 81 17 1 87 85

18 74 74 84 29 20 27 71

37 60 26 56 23 65 67 49

57 7 62 92 52 5 10 69

46 97 88 28 76 27 66 7

89 89 94 31 11 20 1 17

19 48 35 6 77 61 45 21

52 11 76 70 73 99 85 55

90 25 20 7 64 24 94 4

3 43 32 74 10 93 35 77

77 100 63 91 10 73 22 57

样例输出

2:0

0:2

0:0

0:1

0:0

0:0

1:0

1:0

0:2

1:0

5:5

样例解释:

可以看到标准为12,

第一局,甲最低3,乙最低14,3<14&&3<=12,甲得分,乙不得分

第二局,甲最低22,乙最低5,5<22&&5<=12,乙得分,甲不得分

第三局,甲最低32,乙最低26,都没有小于等于标准,都不得分

。。。。。。

代码

#include<iostream>
#include<string>
using namespace std;
int main()
{
int r,i,j;
cin>>r;
int a[],b[],f=,f1=,zf=,zf1=,min=,min1=;
for(i=;i<=;i++)
{
for(j=;j<=;j++)
{
cin>>a[j];
if(a[]==-)
{
cout<<zf<<':'<<zf1;
return ;
}
}
for(j=;j<=;j++)
{
cin>>b[j];
}
for(j=;j<=;j++)
{
if(a[j]<min)
{
min=a[j];
}
}
for(j=;j<=;j++)
{
if(b[j]<min1)
{
min1=b[j];
}
}
if(min<min1)
{
for(j=;j<=;j++)
{
if(a[j]<=r&&a[j]<min1)
{
f++;
}
}
cout<<f<<':'<<f1<<endl;
zf=zf+f;
f=;
}
else if(min1<min)
{
for(j=;j<=;j++)
{
if(b[j]<=r&&b[j]<min)
{
f1++;
}
}
cout<<f<<':'<<f1<<endl;
zf1=zf1+f1;
f1=;
}
else
{
cout<<<<':'<<<<endl;
}
min=;
min1=;
}
cout<<zf<<':'<<zf1;
return ;
}

这里用到了求最小值的方法,还可以改成sort排序后的[0]

C++枚举算法的更多相关文章

  1. 枚举算法总结 coming~^.*

    感谢CJ同学监督╭(╯^╰)╮.从放假到现在都木有更新博客了~噶呜~小娘谨记教诲,每天会更新博客==!! 看了一下POJ训练计划,虽然已经零零散散做了40多道题了,还是从头开始整理一下漏掉的知识点.T ...

  2. 【枚举Day1】20170529-2枚举算法专题练习 题目

    20170529-2枚举算法专题练习 题解: http://www.cnblogs.com/ljc20020730/p/6918360.html 青岛二中日期 序号 题目名称 输入文件名 输出文件名 ...

  3. 利用枚举算法实现todoList:把对应项添加的内容列表

    功能: 点击城市列表项,如果内容列表不存在,则插入点击项: 如果内容列表中已存在,则不插入,然后把内容列表中的对应项放到第一位. HTML代码: <!DOCTYPE html> <h ...

  4. 【枚举Day1】20170529-2枚举算法专题练习 题解

    题目: http://www.cnblogs.com/ljc20020730/p/6918328.html 评测器:cena 评测记录: 1.OneMoreRectangle 一个矩形 ●如果任意枚举 ...

  5. poj2814-拨钟问题-C语言-枚举算法

    #include <stdio.h> #include <stdlib.h> /* 首先,我们考虑用长度为9的数组表示表盘的状态以及调表的操作,终止的条件是表盘状态数组所有元素 ...

  6. jszs 枚举算法

    <!doctype html> <html> <head> <meta charset="utf-8"> <title> ...

  7. 数据结构与算法之枚举(穷举)法 C++实现

    枚举法的本质就是从全部候选答案中去搜索正确的解,使用该算法须要满足两个条件: 1.能够先确定候选答案的数量. 2.候选答案的范围在求解之前必须是一个确定的集合. 枚举是最简单.最基础.也是最没效率的算 ...

  8. flink 实现三角枚举EnumTriangles算法详解

    1.三角枚举,从所有无向边对中找到相互连接的三角形 /** * @Author: xu.dm * @Date: 2019/7/4 21:31 * @Description: 三角枚举算法 * 三角枚举 ...

  9. 『高次同余方程 Baby Step Giant Step算法』

    高次同余方程 一般来说,高次同余方程分\(a^x \equiv b(mod\ p)\)和\(x^a \equiv b(mod\ p)\)两种,其中后者的难度较大,本片博客仅将介绍第一类方程的解决方法. ...

随机推荐

  1. leetcode 945. 使数组唯一的最小增量

    题目 给定整数数组 A,每次 move 操作将会选择任意 A[i],并将其递增 1. 返回使 A 中的每个值都是唯一的最少操作次数. 示例 1: 输入:[1,2,2] 输出:1 解释:经过一次 mov ...

  2. 在Windows中安装OpenCV-Python |四

    目标 在本教程中 我们将学习在你的Windows系统中设置OpenCV-Python. 下面的步骤在装有Visual Studio 2010和Visual Studio 2012的Windows 7- ...

  3. CNN更新换代!性能提升算力减半,还即插即用

    传统的卷积运算,要成为过去时了. Facebook和新加坡国立大学联手提出了新一代替代品:OctConv(Octave Convolution),效果惊艳,用起来还非常方便. OctConv就如同卷积 ...

  4. Qt 事件使用示例 (一)

    Qt 事件使用示例,以一个常见的使用来说明:QLabel 当鼠标滑过时改变颜色. 事先说明要想实现这一功能有很多种方法,如Qss实现,本文使用Qt事件的方式来实现. 第一步,我们得实现一个从QLabe ...

  5. PHP7内核(五):系统分析生命周期

    上篇文章讲述了模块初始化阶段之前的准备工作,本篇我来详细介绍PHP生命周期的五个阶段. 一.模块初始化阶段 我们先来看一下该阶段的每个函数的作用. 1.1.sapi_initialize_reques ...

  6. dijskra算法(求正权图中最短路)

    思想:每次找到离原点最近的顶点,以这个点为中心扩展松弛,更新其余点到原点的最短路径. 注意:if(e[u][v]>x)e[u][v]=x; book[ ]数组标记最短路程的顶点集合 #inclu ...

  7. 怎么获取WebAPI项目中图片在服务端的路径

    1.这是我的项目结构. 2.路径格式为:[http://服务器域名/文件夹/文件.扩展名] 测试:假如我要获取到[logo_icon.jpg]这张图.在浏览器的地址栏中输入上面那个格式的路径. 3.可 ...

  8. Ubuntu系统在Anaconda中安装Python3.6的虚拟环境

    原因:Anaconda的python版本是3.7的,TensorFlow尚不支持此版本,于是我们创建一个Python的虚拟环境以支持TensorFlow 创建tf环境 conda create --n ...

  9. Python中类型的概念(一)

    本课程主要介绍6种Python语言中的类型:数字类型.字符串类型.元组类型.列表类型文件类型.字典类型 1.数字类型 Python语言包括三种数字类型:整数类型.浮点数类型.复数类型 (1)整数类型 ...

  10. Bitmap之位图采样和内存计算详解

    原文首发于微信公众号:躬行之(jzman-blog) Android 开发中经常考虑的一个问题就是 OOM(Out Of Memory),也就是内存溢出,一方面大量加载图片时有可能出现 OOM, 通过 ...