QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2637|回复: 0
打印 上一主题 下一主题

还在为数学建模的事发愁?带你一起来看看数模竞赛中必备的经典算法

[复制链接]
字体大小: 正常 放大
杨利霞        

5273

主题

82

听众

17万

积分

  • TA的每日心情
    开心
    2021-8-11 17:59
  • 签到天数: 17 天

    [LV.4]偶尔看看III

    网络挑战赛参赛者

    网络挑战赛参赛者

    自我介绍
    本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。

    群组2018美赛大象算法课程

    群组2018美赛护航培训课程

    群组2019年 数学中国站长建

    群组2019年数据分析师课程

    群组2018年大象老师国赛优

    跳转到指定楼层
    1#
    发表于 2021-7-9 17:26 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    还在为数学建模的事发愁?带你一起来看看数模竞赛中必备的经典算法
    4 L( K: ~4 C* q% `* f6 Y6 ]" M  U3 p6 ~' H
    前言
    " |# Z! e4 }' x数学建模比赛是本科生和研究生阶段最重要的比赛之一,包括全国大学生数学建模竞赛(俗称“国赛”)和美国大学生数学建模竞赛(俗称“美赛”)。在这些比赛中取得好成绩,不仅有助于保研、有助于找工作,更重要的是形成科学的思维模式。以下是博主精心整理的两个matlab专栏,包含入门到精通及实战内容,需要的小伙伴可根据自己需求自行订阅。
    + H, X" p% c1 K/ ~0 f  ~
    7 E5 o" y- N$ @- C. u2 Z/ f+ [! B8 j
    8 w. N  t% X# _9 y" d- ?( A
    MATLAB-30天带你从入门到精通  Y9 z5 V. g. r/ m
    - A2 N: d+ x) E" F; o
    % f' C% s2 w7 m& n/ q" d; l$ J
    https://blog.csdn.net/wenyusuran/category_10614422.html- T8 l+ @3 l7 r# q0 `

      h. j' I9 l# K

    " `9 O% f# I4 _! @. j7 hMATLAB深入理解高级教程(附源码)
    " e. K$ G4 f! W! t5 y6 w
    , x9 M) @9 c: A( j

    % e: s0 c4 k" J* T( w$ dhttps://blog.csdn.net/wenyusuran/category_2239265.html
    % [" X8 C( k$ ?
    % \% K3 ]0 o$ V" W, Z0 p5 Z
    3 l$ _  a% e: ]. R$ Z
    在博主的资源中也有各种算法的应用实例源代码,需要的小伙伴自取哟。% z" B* h9 L$ J, z9 w( M  q" [+ n
    3 l, f) J/ q7 ~
    9 V, l/ R) z: y" k5 B4 F- u, S

    + H- @+ Q9 S+ c% w* Q" p
    7 {% |8 E% m5 n4 `' n
    * s& \0 c( R3 e1 u) L. H

      J% W0 \% G; g  N4 B
    9 \# v8 A3 h8 N# |- H1 L) m
    & G) s9 t9 K7 Q9 S- O- f
    1 A% Y& b5 d+ ]* @; j, n
    4 W$ N" n9 B1 M

    9 D) z# |6 I- U7 v) H
    / _+ l" s# `# R) z8 s9 [; Z6 x, P
    01  蒙特卡罗算法
    $ D7 y) B  J  t/ }3 ]5 n3 b( @9 y1946 年,美国拉斯阿莫斯国家实验室的三位科学家 JohnvonNeumann, Stan Ulam和 Nick Metropolis 共同发明了蒙特卡罗方法。
    $ n( R% H3 Y5 |: J* O1 @
    / L  f* r3 j9 q1 K6 z4 A, }
    , H& h  _3 h  k; _+ W. R& T
    蒙特卡罗方法(Monte Carlo method),又称随机抽样或统计模拟方法,是一种以概率统计理论为指导的一类非常重要的数值计算方法。此方法使用随机数(或更常见的伪随机数)来解决很多计算问题的方法。
    , k9 j/ ^* \, ]* G( s9 e. M
      u' r$ l8 x4 Q( r
    & m. q% N7 j0 r; J
    由于传统的经验方法由于不能逼近真实的物理过程,很难得到满意的结果,而蒙特卡罗方法由于能够真实地模拟实际物理过程,故解决问题与实际非常符合,可以得到很圆满的结果。& b- V% z' z) K1 e4 n
    4 k7 w) L$ O9 v, L# i4 I6 P

    : D: a) t9 a1 Q  t蒙特卡罗方法的基本原理及思想如下:1 \: Q! s1 n1 ]( H

    4 S% u5 G+ |1 R) M2 K+ {

    ; H% c& j7 M7 i1 b' p" d当所求解问题是某种随机事件出现的概率,或者是某个随机变量的期望值时,通过某种“实验”的方法,以这种事件出现的频率估计这一随机事件的概率,或者得到这个随机变量的某些数字特征,并将其作为问题的解。
    # {0 [2 p+ J/ S0 Y1 u, q7 v
    / l# |  s0 H) k( F  L* C
    & q+ f$ C4 K/ x, Y
    举个栗子,直观了解蒙特卡洛方法:& J' q( t* c% }# K2 G

    6 R4 ]0 D/ l3 T+ j: T$ ~

    & h  @: Y# p0 p8 d) x7 i$ n$ y假设我们要计算一个不规则图形的面积,那么图形的不规则程度和分析性计算(比如:积分)的复杂程度是成正比的。蒙特卡洛方法是怎么计算的呢?假想你有一袋豆子,把豆子均匀地朝这个图形上撒,然后数这个图形之中有多少颗豆子,这个豆子的数目就是图形的面积。当你的豆子越小,撒的越多的时候,结果就越精确。在这里我们要假定豆子都在一个平面上,相互之间没有重叠。
    ! h, P3 ^- L) @2 V
    # _) I, `8 T8 v7 O
    2 G: D$ M/ D, P" m8 V
    , V7 `! a* w5 {- ?9 P9 b" c+ {
    5 f( S) ?( s0 B3 j

    ) S% y/ V% |- e
    ; v/ D! Z+ E7 S& y# c
    蒙特卡罗方法通过抓住事物运动的几何数量和几何特征,利用数学方法来加以模拟,即进行一种数字模拟实验。它是以一个概率模型为基础,按照这个模型所描绘的过程,通过模拟实验的结果,作为问题的近似解。# y: l6 s4 ^( [4 J8 v

    % d& D7 N& A/ I- r

    + l1 q' ?  b! L6 E" T蒙特卡罗方法与一般计算方法有很大区别,一般计算方法对于解决多维或因素复杂的问题非常困难,而蒙特卡罗方法对于解决这方面的问题却比较简单。其特点如下:
    / L1 a" ~$ S1 k6 c4 A( f2 T0 J: _! x$ Q* \) {" @% H

    " F+ R; G$ U& t$ F7 ia、直接追踪粒子,物理思路清晰,易于理解;
    $ Q/ K3 L& I+ n! f/ j* }. [4 [2 E# l, M3 M7 E) M0 y/ T1 A

    9 z  L0 j+ p& {1 i0 l! lb、采用随机抽样的方法,较真切的模拟粒子输运的过程,反映了统计涨落的规律;
    9 f) I! F0 H' r$ R" W& i1 U/ N/ ~4 e( S$ h
    $ ^1 C+ j, f2 s9 J
    c、不受系统多维、多因素等复杂性的限制,是解决复杂系统粒子输运问题的好方法
    9 N. L: C: W3 G. a' O1 U- Q
    ( p  H  ^5 ^$ g. K% i$ p

    . X8 w2 r+ N: w1 A, n+ c; m等等  W- n: v. @0 }5 }2 B: ]

    + X) k$ b1 v6 \8 {

    ) v: E% [4 q: [* S 02  数据拟合、参数估计、插值等数据处理算法
    - A# p8 A  R& P  {我们通常会遇到大量的数据需要处理,而处理数据的关键就在于这些算法,通常使用 Matlab 作为工具。2 W% c0 w/ A$ \5 }# f1 r* L

    ) o2 f7 H0 A; W6 }9 B6 G

    * F  d8 ]: P0 H( S% O" J) c数据拟合在数学建模比赛中中有应用,与图形处理有关的问题很多与拟合有关系,一个例子就是 98 年数学建模美国赛 A 题,生物组织切片的三维插值处理,94 年 A 题逢山开路,山体海拔高度的插值计算,还有吵的沸沸扬扬可能会考的“非典”问题也要用到数据拟合算法,观察数据的走向进行处理。+ L$ _8 k2 V+ z9 ]8 v' x) c
    . f. b4 `- W% q
    0 ~0 @0 q0 O9 f0 X9 y, d6 J
    4 T. m! D* w* w, Q
    $ k/ d( y% g' V: m
    1 R3 k1 U+ z% d% `" r

    ) S2 M+ i. w; ]) u% n) d此类问题在 MATLAB 中有很多现成的函数可以调用,熟悉 MATLAB,这些方法都能游刃有余的用好。
    $ x7 V6 x! K5 o# j) [- \' {  a0 M5 t( R! ]) i

    + T* T3 C! ]3 [- H1 {% r1 [0 Y3 a 03 线性规划、整数规划、多元规划、二次规划等规划类问题
    . A5 y& x$ B: I+ k% v9 ]. ]数学建模竞赛中很多问题都和数学规划有关,可以说不少的模型都可以归结为一组不等式作为约束条件、几个函数表达式作为目标函数的问题。4 _3 [% e* N  w: n
    2 c$ ?& R3 E: i% \4 j/ m- |  ^) Q

    6 u3 W$ a/ Z! P3 s遇到这类问题,求解就是关键了,比如 98 年 B 题,用很多不等式完全可以把问题刻画清楚,因此列举出规划后用 Lindo、Lingo 等软件来进行解决比较方便,所以还需要熟悉这两个软件。0 z! e; Z0 J6 r# Y
    ) i7 @4 u# c& k+ v4 ^

    / |4 J5 Z0 c" U: {* q. q, ^& ^ 04  图论算法3 L' E/ d8 f$ a
    这类问题算法有很多,包括:Dijkstra、Floyd、Prim、Bellman-Ford,最大流,二分匹配等问题。
    * m' ~* u% h3 a3 g( p, d7 S7 S
    $ `6 O, D  M  f5 t. H0 t
    2 ~. `8 L# z, a+ n
    关于此类图论算法,可参考 IntroductiontoAlgorithms--算法导论,关于图算法的第22章-第26章。' K/ ?3 P; S6 u
    8 f2 C; j( Y% v: E' T

    ! r. a; ^+ |8 y( j7 J1 M# Z
    , v$ d# y) c. v  H# y- `9 ?

    % h! G( ?6 P* r% T' x* B& c3 L3 |% J; L( y

    * ~' ~. R. J. D! L' c 05  动态规划、回溯搜索、分治算法、分支定界等计算机算法
    ! x0 c5 F9 x+ Q; X( u9 e* O' e在数学建模竞赛中,如:92 年 B 题用分枝定界法,97年 B 题是典型的动态规划问题,此外 98 年 B 题体现了分治算法。
    2 V8 m) a/ ~4 y: E) p
    / S. W4 _$ A+ ~; K0 B3 j5 |0 y8 F, ?
    7 F. z; N, q0 m
    8 w0 G6 s% z  X. x
    / N% m9 f. d% h' m5 ^+ r! G

    7 Y! z9 ?( ~5 n9 v

    * v' a+ g8 ]/ y+ r- `! b( Z- j& n4 z这方面问题和 ACM 程序设计竞赛中的问题类似,推荐看一下算法导论,与《计算机算法设计与分析》(电子工业出版社)等与计算机算法有关的书。
    - k" W. |! A+ B. p' k7 V* `" V- P: F" Q6 |$ P
    : m, l% t; ]2 G. T
    06  最优化理论的三大经典算法:模拟退火法、神经网络、遗传算法) h' H8 @; h; y1 R
    这十几年来最优化理论有了飞速发展,模拟退火法、神经网络、遗传算法这三类算法发展很快。, P" s8 }2 P/ l9 O
    $ p& a! }0 O4 Y1 R
    9 r$ x: \3 z2 K% ?( \9 ~  K
    在数学建模竞赛中:比如 97 年 A 题的模拟退火算法,00 年 B 题的神经网络分类算法,01 年 B 题这种难题也可以使用神经网络。2 o6 |- `6 S3 L( L! c2 D

    : i  D1 H% x& [5 J

    7 N. }* H: x5 f8 F还有美国竞赛 89 年 A 题也和 BP 算法有关系,当时是 86 年刚提出 BP 算法,89 年就考了,说明赛题可能是当今前沿科技的抽象体现。5 ~+ h9 o7 h: M( w* ~8 y3 @' @: C' L
    2 l3 F3 g1 l) J) S1 }4 Y, [* h
    : y+ O0 k6 P/ }& S0 `
    03 年 B 题伽马刀问题也是目前研究的课题,目前算法最佳的是遗传算法。
    ( X) T$ f  O9 Z/ u5 V' R- m5 G3 ~( G  w  o4 h; q9 H* g1 f; F& l

    9 Q; d4 K" ?, j* B9 N. y/ n( ]: O0 U' L5 ]# x+ T# Q+ P, [( y: O- B
    : G3 G( d5 H1 D

      j2 m1 J4 K4 A% D. i

    ! E4 l( I. Y$ S' ^% K9 e & `- H' ~& ?: Y
    - W5 N. T* C8 B' Q" Q
    ! @( y. J! y" i( i
    07  网格算法和穷举法" j% h5 Z' ^6 o' S3 N; }4 [" u
    网格算法和穷举法一样,只是网格法是连续问题的穷举。% Z* `: ^  n0 {  [

    , k+ o6 {2 x3 {1 h( f
    $ s2 A. v3 n& m
    比如要求在 N 个变量情况下的最优化问题,那么对这些变量可取的空间进行采点,比如在 [a;b] 区间内取 M+1 个点,那么这样循环就需要进行 (M+1)N 次运算,所以计算量很大。
    ' f# D2 C1 b* x+ P& m0 s, |# A
    . _! |4 y7 W. ]/ {0 b7 N: ^+ j
    5 s8 @3 Y" Y; g# L
    在数学建模竞赛中:比如 97 年 A 题、99 年 B 题都可以用网格法搜索,这种方法最好在运算速度较快的计算机中进行,还有要用高级语言来做,最好不要用MATLAB 做网格,否则会算很久。0 p8 r" z% n+ Y1 x, z" s2 b

    ! i* H1 D( V/ B& p: O& f! r
    3 o2 {) s- P6 g
    穷举法大家都熟悉,自不用多说了。
    1 n8 {* E8 H7 }1 r) G4 {+ o
    - k: v8 p3 }& s* u
    - B' p5 n' a! Z2 K8 s. s8 m
    08 一些连续离散化方法
    . S7 M# U, y0 r) f/ J大部分物理问题的编程解决,都和这种方法有一定的联系。物理问题是反映我们生活在一个连续的世界中,计算机只能处理离散的量,所以需要对连续量进行离散处理。: e) z  o  J  F$ a
    / I6 [9 C; y* n% i# p1 t1 b
    5 |$ h2 }, m! l1 _9 R4 ^
    这种方法应用很广,而且和上面的很多算法有关。事实上,网格算法、蒙特卡罗算法、模拟退火都用了这个思想。
    0 ^5 C( W6 P6 D: A5 w: ?; P7 c% P/ G0 O" M  i/ A
    9 N, ?: y1 b9 H
    09 数值分析算法+ j6 S1 x0 H+ o9 [* J
    数值分析(numericalanalysis),是数学的一个分支,主要研究连续数学(区别于离散数学)问题的算法。
    ; y$ |! B0 y- l) n/ ^) W: V& P9 w1 x6 _4 H8 P8 v

    4 R! k. w* o' V4 y. ~如果在比赛中采用高级语言进行编程的话,那一些数值分析中常用的算法比如方程组求解、矩阵运算、函数积分等算法就需要额外编写库函数进行调用。
    ; @, a; j, W' q$ W3 J  c3 ^
    ) R( x5 Y+ g( u" ^. d' g6 n0 c: [

    6 R3 i# P, d7 l  {- L$ B" E这类算法是针对高级语言而专门设的,如果你用的是 MATLAB、Mathematica,大可不必准备,因为像数值分析中有很多函数一般的数学软件是具备的。9 `2 p0 j! M  R8 F3 C( p6 l6 y
    + G6 G  e8 b3 G, v8 w2 a

    ' g$ h8 U$ ^* @* Z* n! L3 ~- x 10  图象处理算法
    4 ^7 z. b! u7 a8 A2 F在数学建模竞赛中:比如 01 年 A 题中需要你会读 BMP 图象、美国赛 98 年 A 题需要你知道三维插值计算,03 年 B 题要求更高,不但需要编程计算还要进行处理,而数模论文中也有很多图片需要展示,因此图象处理就是关键。做好这类问题,重要的是把 MATLAB 学好,特别是图象处理的部分。9 I# f" @- ^1 t! P! B

    ) L8 n; Z7 K, J
    5 f7 T6 W0 W# @/ ?, Y) e, w7 M+ Z

    3 H# {* @' I9 z" d' U6 J

    , ~; m) Y7 _5 R6 M$ _# G————————————————
    5 f; X  h4 g8 u6 K+ K& A, A/ w版权声明:本文为CSDN博主「文宇肃然」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。( c4 h) y* d: G1 G. k6 ?  Z* ]- G
    原文链接:https://blog.csdn.net/wenyusuran/article/details/114093268  y2 e" L/ g+ P0 A# R
    + A2 T- c) O/ y) n6 z+ W9 L
    ; M- `6 X8 V+ @. B9 w8 c: k3 L1 A
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-5-26 23:49 , Processed in 0.437907 second(s), 51 queries .

    回顶部