随机算法我也只是稍微接触了一下,就是想写篇博客自己稍微总结一下

其实随机算法也算是一个玄学吧,运气不好还是会wa。但是我们知道,计算机可以在短时间内计算大量的数据,所以碰到正确答案的概率还是挺大的。

当然随机不是随机答案啦,对于不同的题有可以不同的随机对象。通常我们会在一下情况下用随机:
1、逐个枚举太多无用的情况下选择随机 以减少枚举次数
2、判断正确性的时候降低暴力判断的复杂度

下面还是放题吧

poj2454 Jersey Politics

Description
In the newest census of Jersey Cows and Holstein Cows, Wisconsin cows have earned three stalls in the Barn of Representatives. The Jersey Cows currently control the state’s redistricting committee. They want to partition the state into three equally sized voting districts such that the Jersey Cows are guaranteed to win elections in at least two of the districts.
Wisconsin has 3*K (1 <= K <= 60) cities of 1,000 cows, numbered 1..3*K, each with a known number (range: 0..1,000) of Jersey Cows. Find a way to partition the state into three districts, each with K cities, such that the Jersey Cows have the majority percentage in at least two of districts.
All supplied input datasets are solvable.
Input
* Line 1: A single integer, K
* Lines 2..3*K+1: One integer per line, the number of cows in each city that are Jersey Cows. Line i+1 contains city i’s cow census.
Output
* Lines 1..K: K lines that are the city numbers in district one, one per line
* Lines K+1..2K: K lines that are the city numbers in district two, one per line
* Lines 2K+1..3K: K lines that are the city numbers in district three, one per line
Sample Input
2
510
500
500
670
400
310
Sample Output
1
2
3
6
5
4
Hint
Other solutions might be possible. Note that “2 3” would NOT be a district won by the Jerseys, as they would be exactly half of the cows.
translate
在泽西奶牛和荷斯坦奶牛的最新普查中,威斯康星奶牛在谷仓中获得了三个档位。 泽西奶牛目前控制着国家重新分配委员会。 他们想将国家分为三个相当大的投票地区,以便保证泽西奶牛在至少两个地区获得选举权。
威斯康星州有3 * K(1 <= K = = 60)个1000头牛的城市,编号为1..3 * K,每头都有泽西奶牛的已知数量(范围:1.001)。 找到一种将州划分为三个区域的方式,每个区域都有K个城市,使得泽西奶牛在至少两个地区拥有多数比例。
所有提供的输入数据集都可以解决。

首先有一个贪心:把序列从大到小排序,取前2*k个作为需要满足要求的两个子序列的元素。之后就是对于这2*k个元素如何分配的问题了
如果dfs的话会出事(这是肯定的),那么如何减少枚举次数呢?就是用随机算法了
但是如何随机也是有讲究的。如果我们直接随机这个序列,很有可能两个子序列的元素并没有改变(只是交换了一下顺序)。我们希望每一次的枚举都有效,即交换元素。那么很显然,随机这个交换的元素就好了

#include<ctime>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;struct node{int val,num;
}a[200];
int k;bool cmp(const node &x,const node &y){return x.val>y.val;
}
int main(){srand((unsigned)time(NULL));while(scanf("%d",&k)!=EOF){for(int i=0;i<3*k;i++){scanf("%d",&a[i].val);a[i].num=i;}sort(a+0,a+3*k,cmp);int sum1=0,sum2=0;for(int i=0;i<k;i++){sum1+=a[i].val;sum2+=a[i+k].val;}while(1){if(sum1>500*k&&sum2>500*k) break;int r1=rand()%k,r2=rand()%k;sum1=sum1-a[r1].val+a[k+r2].val;sum2=sum2-a[k+r2].val+a[r1].val;swap(a[r1],a[k+r2]);}for(int i=0;i<3*k;i++) printf("%d\n",a[i].num+1);}return 0;
}

poj3318 Matrix Multiplication

Description
You are given three n × n matrices A, B and C. Does the equation A × B = C hold true?
Input
The first line of input contains a positive integer n (n ≤ 500) followed by the the three matrices A, B and C respectively. Each matrix’s description is a block of n × n integers.
It guarantees that the elements of A and B are less than 100 in absolute value and elements of C are less than 10,000,000 in absolute value.
Output
Output “YES” if the equation holds true, otherwise “NO”.
Sample Input
2
1 0
2 3
5 1
0 8
5 1
10 26
Sample Output
YES
Hint
Multiple inputs will be tested. So O(n3) algorithm will get TLE.
translate
给定三个n×n矩阵A,B和C.方程A×B = C是否成立?

题目的hint说了,暴力的把矩阵乘起来要炸。
那么如果可以找到一个快速的判断方法,不一定要对错两面都具有绝对性,只要其中一面具有绝对性就好。
设v为随机生成的n维列向量,每个元素取1或0。看A*(B*v)和C*v是否相同。但是这样不稳定,因为即使A*B不等于C,这样算出来可能是相等的。经计算,这种情况还相等的概率小于1/2。那么多判断几次,出错的概率就会大大降低。所以试60次就差不多了

#include<ctime>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;int n;
struct matrix{int k[505][505];int x,y;
}A,B,C,v,_B,_C,_A;void get_rand(matrix &v){for(int i=1;i<=n;i++) v.k[i][1]=rand()%2;
}
void mult_mt(matrix &_a,const matrix &a,const matrix &v){_a.x=a.x,_a.y=v.y;for(int i=1;i<=n;i++){int tmp=0;for(int j=1;j<=n;j++)tmp+=a.k[i][j]*v.k[j][1];_a.k[i][1]=tmp;}
}
bool check(const matrix &a,const matrix &b){for(int i=1;i<=n;i++) if(a.k[i][1]!=b.k[i][1]) return false;return true;
}
int main(){srand((unsigned)time(NULL));scanf("%d",&n);for(int i=1;i<=n;i++)for(int j=1;j<=n;j++) scanf("%d",&A.k[i][j]);for(int i=1;i<=n;i++)for(int j=1;j<=n;j++) scanf("%d",&B.k[i][j]);for(int i=1;i<=n;i++)for(int j=1;j<=n;j++) scanf("%d",&C.k[i][j]);A.x=A.y=B.x=B.y=C.x=C.y=n;int m=60;   v.x=n,v.y=1;while(m--){get_rand(v);mult_mt(_B,B,v);mult_mt(_C,C,v);mult_mt(_A,A,_B);if(!check(_C,_A)){printf("NO\n");return 0;}}printf("YES\n");return 0;
}

转载于:https://www.cnblogs.com/LinnBlanc/p/7763125.html

浅浅地谈一下随机算法【poj2454】【poj3318】相关推荐

  1. 浅谈流处理算法 (1) – 蓄水池采样

    转载自  浅谈流处理算法 (1) – 蓄水池采样 前言 现如今,"大数据 "已经不是什么新概念,"一千个人眼中有一千个大数据".社交网络,智能穿戴设备,智能家居 ...

  2. 浅谈Base64编码算法

    一.什么是编码解码 编码:利用特定的算法,对原始内容进行处理,生成运算后的内容,形成另一种数据的表现形式,可以根据算法,再还原回来,这种操作称之为编码. 解码:利用编码使用的算法的逆运算,对经过编码的 ...

  3. 浅谈国密算法 SM1、SM2、SM3、SM4

    浅谈国密算法 国密算法是我国自主研发创新的一套数据加密处理系列算法.从SM1-SM4分别实现了对称.非对称.摘要等算法功能.特别适合应用于嵌入式物联网等相关领域,完成身份认证和数据加解密等功能.当然, ...

  4. 数据库浅谈之共识算法

    数据库浅谈之共识算法 HELLO,各位博友好,我是阿呆

  5. 浅谈关于特征选择算法与Relief的实现

    一. 背景 1) 问题 在机器学习的实际应用中,特征数量可能较多,其中可能存在不相关的特征,特征之间也可能存在相关性,容易导致如下的后果: 1.     特征个数越多,分析特征.训练模型所需的时间就越 ...

  6. 对计算机知识体系的了解,浅浅而谈计算机专业知识体系(对要进入计算机专业学习的人的小小建议)...

    之所以是浅浅而谈,是因为我下个学期刚上大四,所以对整个体系还不能完全了解.之所以谈,是因为我已经知道大四的内容是什么,方向是什么. 我个人觉得,首先对"计算机"有一个认识:我是计算 ...

  7. 从决策树学习谈到贝叶斯分类算法

    从决策树学习谈到贝叶斯分类算法 从决策树学习谈到贝叶斯分类算法 引言 最近在面试中,除了基础 &  算法 & 项目之外,经常被问到或被要求介绍和描述下自己所知道的几种分类或聚类算法,而 ...

  8. 从决策树学习谈到贝叶斯分类算法、EM、HMM - 结构之法 算法之道

    转载自:http://scm.zoomquiet.io/data/20121220000040/index.html 第一篇:从决策树学习谈到贝叶斯分类算法.EM.HMM (Machine Learn ...

  9. 从决策树学习谈到贝叶斯分类算法、EM、HMM

    从决策树学习谈到贝叶斯分类算法.EM.HMM 引言 最近在面试中,除了基础 &  算法 & 项目之外,经常被问到或被要求介绍和描述下自己所知道的几种分类或聚类算法(当然,这完全不代表你 ...

最新文章

  1. [POI2007]ZAP-Queries
  2. CBAC ftp测试
  3. WinRAR 命令行简体中文说明
  4. 网络知识:视频监控传输带宽与存储容量的计算方法
  5. [leetcode-347-Top K Frequent Elements]
  6. promise 为什么出现
  7. html的坐标怎么表示,经纬度怎样表示
  8. Cisco系列交换机型号
  9. PDF文件如何加密?分享两种好用方法
  10. leetcode 306 累加数(js)
  11. 裸金属服务器启动之PXE与IPXE实践
  12. 单片机消抖c语言程序,基于单片机定时器软件消抖C51程序研究
  13. 【自然语言处理】详说中文自动分词
  14. 【POJ】 1014 Dividing(多重背包,优化)
  15. SN_Writer写IMEI号
  16. Python语言中的注释方法应用
  17. 如何用计算机看网络电视,教您如何使用海信电视观看局域网中计算机共享的视频...
  18. Windows影射模式
  19. spring、springboot集成 log4j日志、log4j2日志以及slf4j
  20. mysql数据库管理人员_dba数据库管理员的职责是什么

热门文章

  1. 历届试题 打印十字图
  2. SQL开发技巧 join从句
  3. 【Qt】QModbusTcpClient类
  4. 【Qt】Qt登录对话框(设计器实现)
  5. 描述java源程序构成_2.1 Java程序的构成
  6. Linux驱动入门基础基础知识
  7. 每天一道LeetCode-----计算二叉树的最大深度及最小深度,判断二叉树是否是高度平衡二叉树
  8. Linux下cron周期性计划任务
  9. MAX232和PL2303、CH340的区别
  10. HUD - 4463 Outlets