QQ登录

只需要一步,快速开始

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

算法越学越扎心,有没啥破解之法?

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

5273

主题

82

听众

17万

积分

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

    [LV.4]偶尔看看III

    网络挑战赛参赛者

    网络挑战赛参赛者

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

    群组2018美赛大象算法课程

    群组2018美赛护航培训课程

    群组2019年 数学中国站长建

    群组2019年数据分析师课程

    群组2018年大象老师国赛优

    跳转到指定楼层
    1#
    发表于 2020-4-24 17:58 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    ' c+ P  E1 v4 K+ b; t& `
    算法越学越扎心,有没啥破解之法?6 z% @4 M) w! i1 W: ^% u
    算法越学越扎心,有没啥破解之法?
    5 W, w2 O* Y" ~5 L7 J  I  W
    . m2 J% V' U$ w' ~' x( F对于算法的学习,我也是从一个小白一步步走来,当然,现在仍然很菜,,,不过,鉴于我觉得还有一些人比我更菜了,我决定谈谈我算法学习过程走过的坑,以及自己总结的一些经验。
    : b6 u; X4 n& ^1 s( o0 T4 Y. ?6 c
    ! N, U4 U- Z* [4 ^! h5 \0 G% t切勿盲目刷题:刷题前的知识积累
    ; ]2 U. ]' M% d
    2 h9 q0 ^2 P  k9 z1 c& U6 B说实话,想要提高自己的算法,真的没啥捷径,我觉得最好的捷径就是脚踏实地着多动手去刷题,多刷题。
    8 r) [4 W' d$ G" t8 }3 O. l: W5 Q( C) j  `
    但是,我必须提醒的是,如果你是小白,也就是说,你连常见的数据结构,如链表、树以及常见的算法思想,如递归、枚举、动态规划这些都没学过,那么,我不建议你盲目疯狂着去刷题的。而是先去找本书先去学习这些必要的知识,然后再去刷题。; N! F& W* m6 c" {4 L* m4 l
    - a- E: Y% Y# m% [* c' z9 O
    因为,如果这些基础都不懂的话,估计一道题做了几个小时,然后看答案都看不懂,做题没有任何思路,这是很难受的。久而久之,估计没啥动力了,我刚开始就是这样,一道题答案看一天,然而还是不大懂,什么回溯啊,暴力啊,还不知道是啥意思。
    7 c/ B, K$ A9 T1 F
    ( \7 T+ g, X' w6 w也就是说,假如你要去诸如leetcode这些网站刷题,那么,你要先具备一定的基础,这些基础包括:
    $ E) g3 g( B8 L5 l; K8 x. h- o3 y3 f& f4 s) {
    1、常见数据结构:链表、树(如二叉树)。(是的,链表和二叉树是重点,图这些可以先放着)+ {0 g, J) V" A' k/ Y
    3 M9 I0 h) _; Q: {! W. f
    2、常见算法思想:贪婪法、分治法、穷举法、动态规划,回溯法。(贪婪、穷举、分治是基础,动态规划有难度,可以先放着)* s  {) l- s7 A# t/ u+ M
    ) j6 N8 ?( B5 [& N/ ~
    以上列出来的算是最基本的吧。就是说你刷题之前,要把这些过一遍再去刷题。如果你连这些最基本的都不知道的话,那么你再刷题的过程中,会很难受的,思路也会相对比较少。. e" l1 t8 [: X: {9 i3 r+ {4 x- F

    ' P( @( P6 X6 ]3 I5 D总之,千万不要急,先把这些基本的过一遍,力求理解,再去刷题。: J. r/ P0 y+ _/ ]

    3 r3 y4 c& }' ^$ x在这里,我推荐基本我大一时看过的书籍吧,感觉还是非常不错的,如果对于数据结构时零基础的话,那么我建议你可以看《数据结构与算法分析:C语言描述版》这本书,这本书自认为真的很 nice,当时我把这本书里面的全部都看了,并且 coding 了一遍,感觉整个人有了质的飞跃。
    # x4 f" N8 b5 C" V) m8 K7 `+ }1 n0 K% e! z9 P* M7 L/ x! o+ r
    后面我时在一些学校的OJ刷题,当时看的一本书叫做《挑战程序设计大赛》,日本作家写的,我觉得这本书也很nice,里面有分初级,中级和高级三个模块,基础比较差的可以从初级开始看起。
    1 a; Y1 V+ R8 w. T, J, H6 j; s
    , H& e) j% A$ X5 _, y* j# d( q当然,这两本书,你可以在这个Github上找到:https://github.com/iamshuaidi/CS-Book
    , D' l/ n/ X# a! S, j. ~) a* C总结下:9 |) v2 i, Z7 F$ J. M7 Y

    . p) g8 k# `+ `2 M. ~+ }0 J6 _提高数据结构与算法没啥捷径,最好的捷径就是多刷题。但是,刷题的前提是你要先学会一些基本的数据结构与算法思想。
    * X) e/ Z# _/ S
    / v) a* a& s8 r  GAC不是目的,我们要追求完美+ z" ]! L" N8 ]! q) b; G
    + L4 j8 [0 ]& n$ R8 k& W5 M
    如何刷题?如何对待一道算法题?
    / _. J+ D3 F! P+ N& J; N: m$ E4 S( m1 b. j5 d
    我觉得,在做题的时候,一定要追求完美,千万不要把一道题做出来之后,提交通过,然后就赶紧下一道。我认为这意义不大,因为一道题的解法太多了,有些解法态粗糙了,我们应该要寻找最优的方法。/ S+ {7 w( G( S8 U/ ?% `2 u
    : P" Z, b3 G, y/ P% J
    算法能力的提升和做题的数量是有一定的关系,但并不是线性关系。也就是说,在做题的时候,要力求一题多解,如果自己实在想不出来其他办法了,可以去看看别人是怎么做的,千万不要觉得模仿别人的做法是件丢人的事。6 F8 d; T8 I" Y9 C

    3 ~" p2 l0 |! |7 P) S$ _$ W我做题的时候,我一看到一道题,可能第一想法就是用很粗糙的方式做,因为很多题采用暴力法都会很容易做,就是时间复杂度很高。之后,我就会慢慢思考,看看有没其他方法来降低时间复杂度或空间复杂度。最后,我会去看一下别人的做法,当然,并不是每道题都会这样执行。
    0 p# y+ M& Y8 I- d( ?
    7 d$ I1 R: j' f8 w$ o  o0 c衡量一道算法题的好坏无非就是时间复杂度和空间复杂度,所以我们要力求完美,就要把这两个降到最低,令他们相辅相成。
    . @% X- L9 A8 m- o9 a, @! R8 Z4 j' x9 O8 k) }
    我举道例题吧:2 L& d: H; M* e, @7 |

    - Q( w& C% ]! D% Z5 x问题: 一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法?
    6 w0 p5 s* v) ?: I2 H; u8 q8 o: {/ }4 t% g% J, ^! U3 G
    这道题我在以前的分章分析过,不懂的可以先看下之前写的:递归与动态规划—基础篇1' Y! ?! O" v7 q2 s# C

    # ~/ J9 S8 ~( ^方法1::暴力递归; n2 [! H- v' o7 A* l
    ' _( n5 H4 Y1 E) \! X) Q  a* J
    这道题不难,或许你会采取下面的做法:
    $ H% Y' D# l2 M, `: H0 b% Y* w
    : z8 ^. ]6 f# kpublic int solve(int n){* u0 }* @2 m" ]5 D
        if(n <= 2){
    1 y# Y8 I% e2 X        return n;/ P' K5 I+ E1 ^2 w5 {
        }else{
    & I. I3 E+ i! k        return solve(n-1) + solve(n-2);
    ) @( X0 G' R. ]3 d1 J# P" p! N    }
    0 Y" V( `( e5 r4 m7 s" n) a' s, A}; W, A# C1 L$ U) d$ I
    1
    3 B: @, A, v8 p3 J5 t2
    & Z! O; ~& O6 w1 @. x3
    6 h3 @7 Y! Q+ D3 K. r; U. Y46 ]  S. M: r) `1 t
    5& Y$ Z$ S7 O0 F  O* d
    6; Y8 z& Y/ X8 G5 F. q( Q: U! Z
    74 x) s/ i; Q, a- R% O
    这种做法的时间复杂度很高,指数级别了。但是如果你提交之后侥幸通过了,然后你就接着下一道题了,那么你就要好好想想了。# Q8 p% ~+ f) J0 z, V6 @

    2 `& Z! H; D) o8 p方法二:空间换时间+ s# o" e9 M, R# n5 k9 E

    6 A- o. u# n8 x力求完美,我们可以考虑用空间换时间:这道题如何你去仔细想一想,会发现有很多是重复执行了。不行你可以画个图
    0 v5 E1 k! w1 p8 ^3 S  j" M$ J! k8 R
    所以可以采取下面的方法:
    $ R- V  f+ m+ o5 r6 i
    3 V0 b7 I) Y* y6 \. {% M//用一个HashMap来保存已经计算过的状态
    - S5 B- i) c/ G% A0 Gstatic Map<Integer,Integer> map = new HashMap();4 C! U4 c2 I( W# e1 S, i$ M
    public static int solve(int n){
    - G: J/ Q" Q% J; x( k1 d         if(n <= 2){$ w  W. d' o( A
            return n;
    ! k5 K7 Y4 m: K1 s    }else{//是否计算过0 E6 `2 Y) F, g4 M
            if(map.containsKey(n)){- d$ i/ r# }/ m
                return map.get(n);0 Z9 T+ V- x) n9 A6 v8 i% Y8 M
            }else{: A9 Y4 B) r8 t& s8 S0 _: s7 P$ g
                int m = solve(n-1) + solve(n-2);
    9 n3 O) e* c) K! ^4 I. c* k            map.put(n, m);
      L1 D8 q% v8 k) r) Y* V& y            return m;4 B9 R6 B- B9 m, y) R7 m
            }
    * g. r0 F+ E  d$ {    }; r1 g* p. t- N0 {( x- y) q- I
    }
      r. @( n% y4 F4 D" h! S8 i2 |, g2 Q! G/ r
    1( {3 R1 @4 ^9 M' q" i3 O; h: Z
    28 K% O8 ~$ x/ ^7 m
    3: l& V: J) h% W4 _5 S3 M# r
    48 I6 v) h1 @( {# _* z
    53 s* z! y/ E( u
    6
    6 q4 W4 F! v: L* S- K/ I7
    ; l' r4 |6 N7 r8 N. T8
    + ]7 B" u5 Z1 {" M6 M/ A- ]+ Y9; e/ ]' o* e4 h* y/ @# Q5 L
    10
    : P1 l6 o* K( @! h2 O11
    1 T& @: Y) E) M; t+ g+ W$ o- X; I* I2 u12- C; U  m; K: M" y
    13
    3 M) f7 w" P6 b9 g6 c140 J8 g- Q/ ^  f& o$ B. p
    157 C2 ]5 `; I3 Q
    16
    4 [" F% a+ U$ d0 Z这样,可以大大缩短时间。也就是说,当一道题你做了之后,发现时间复杂度很高,那么可以考虑下,是否有更好的方法,是否可以用空间换时间。. a8 J( \: P9 q% T4 B
    9 p4 k6 R& [2 Z$ J( C4 n, c
    方法三:斐波那契数列/ t' w3 Q) Y0 U

    2 G7 p, \) h1 W5 P+ u$ m9 K0 V实际上,我们可以把空间复杂度弄的更小,不需要HashMap来保存状态:; K. ?, S: i# X
    + H& s' o5 l) W' L
    public static int solve(int n){) w3 w/ [6 l$ Q5 }  A$ J1 K  P
        if(n <= 2){3 y5 h( Z% i6 R/ Z% E1 v9 I* |2 x
            return n;
    % E( M3 s8 Y1 k: p! d. J    }
    - i4 R& b' P/ @0 }. a( n    int f1 = 0;
    & j2 v) K( x" R' L7 X& ^, s: d    int f2 = 1;3 O) N( S6 m; {* O. p
        int sum = 0;
    7 Y. \7 b! I' Q: n( O+ k    for(int i = 1; i<= n; i++){
      R( v6 o0 ?  v* S+ A/ |& T        sum = f1 + f2;5 b( c+ V1 r- m! t9 c% G. y6 }" h) M
            f1 = f2;7 _/ u5 U0 ?; T
            f2 = sum;
    ) e" b! |$ v! p! f0 m' u    }1 ?4 S3 J; I2 `+ A6 N5 C5 _
        return sum;
    ' s; U" p) _) U/ ]: l! m+ `3 k}
    0 M& n; T% y) m" z$ H5 G1
    0 A5 C2 z2 s3 @; z2
    + c4 p' m/ `! h- M3( h; H0 z3 u/ G7 c
    4( X' j2 m" n$ G  P- G0 X
    5
    / J/ l4 O( W) ~% j6
    , L( r: w% ]$ N: E+ M78 Y4 E. w) b8 ?5 w" F# U3 {( g
    84 f% b: z& Y* M7 n0 Q8 t
    9
    & U  ~; q" g8 B6 t" H4 U101 m9 S- h' }( \# _- _
    11% Y3 t4 j# a# P; p' @- i6 j
    12
    " l0 a% [8 W% [6 \13
    3 K, X& ]- D& O8 _: V14
    . L8 H1 {. ?) S* B& }. R* K我弄这道题给你们看,并不是在教你们这道题怎么做,而是有以下目的:
    . [# ]' L& f& _, _3 k) }" J
    + r, k/ J6 O5 I* u, J. g6 H1、在刷题的时候,我们要力求完美。$ d# r1 v- a! B- |+ g5 V8 f
    7 ]  l6 K% @- [
    2、我想不到这些方法啊,怎么办?那么你就可以去看别人的做法,之后,遇到类似的题,你就会更有思路,更知道往哪个方向想。* t! s6 n1 \9 j# U- g2 M

    % E6 `2 o- E9 B5 L/ r5 H& \  A3、可以从简单暴力入手做一道题,在考虑空间与时间之间的衡量,一点点去优化。
    0 n7 T7 q0 |$ k$ r. |
    , x+ ?2 H( E+ |6 Y挑战自己,跳出舒适区
    , D2 s+ h1 R$ q* c
    2 X. B4 }6 [5 m6 \$ ]; [什么叫舒适区?在刷题的时候,可能有一类题是你比较懂的,你每次一看就有思路,然后半个小时就撸好代码,提交代码,然后通过了,然后,哇,又多刷了一道题,心里很舒服。) u6 M( g* i6 b4 i

    & P2 V/ r; x& s4 [但是,记住,前期你可以多刷这种题练手,提升自己的乐趣,但,我还是建议你慢慢跳出舒适区,去做一些自己不擅长的题,并且找段时间一直刷这种题。例如,我觉得我在递归方面的题还是挺强的,- t/ S: }" O/ D; M, @1 R" O
    但是,我对动态规划的题,很菜,每次都要想好久,每次遇到这种题都有点害怕,没什么信心。不过有段时间我觉得只刷动态规划的题,直接在 leetcode 选定专题,连续做了四五十道,刚开始很难受,后来就慢慢知道了套路了,一道题从两三个小时最后缩到半小时,简单的十几分钟就搞定。感觉自己对这类型的题也不惧怕的。* a2 u7 [. c3 f' _. R- P: P% u/ [# J/ a

    / e* O9 a0 Z. @$ d当然,对于动态规划的学习,大家也可以看我这篇广受好评的文章:为什么你学不过动态规划?告别动态规划,谈谈我的经验) x% M; Y7 ]; Q1 T$ q$ V
    6 J# L3 A6 p) Q
    所以,建议你,一定要学好跳出自己的舒适区。2 M' P) g! b# u7 J; S( [

    " W/ i2 R* _) Z8 h0 ~一定要学会分类总结$ Y+ y% b/ o. B  u1 S5 r
    6 G# @9 U; a4 ]$ l& S2 P: d
    有些人以为 leetcode 的题刷的越多,就一定能越厉害,其实不然,leetcode 虽然有 1000 多道题,但题型就那么几类,我们前期在刷的时候,我是建议按照题型分类刷题的,例如我这整理刷二叉树相关,然后刷链表相关,然后二分法,然后递归等等,每刷一种题型,都要研究他们的套路,如果你愿意去总结,那么 leetcode 的题,其实你刷几百道,有目的、挑选的刷,我觉得就差不多了。" y3 d( i. ]1 S9 e; S
    6 T8 @- Y" v* i6 y& R
    我看过一本书,叫做《程序员代码面试指南:IT 名企算法与数据结构题目最优解》,这本书就非常不错,里面按照栈,队列,链表,二叉树,字符串等一个专题一个专题来刷的,并且每道题都给出了最优解,而且里面的题有一定的难度,感兴趣的,真心不错,如果你把这本书的题全部搞定,并且总结相关套路,那么你的算法一定有很大的提升。  K: C0 x7 y% v) _) l3 S

    6 K# m" ?4 L' r. K+ V) _推荐一些刷题网站' B$ n* v# \2 d: y1 [0 {5 ^

    4 {6 ^6 W2 U, u* F( L' P: N# w我一般是在leetcode和牛客网刷题,感觉挺不错,题目难度不是很大。
    % H9 I( I: O4 _: F5 a  G7 x" a4 T! J
    在牛客网那里,我主要刷剑指Offer,不过那里也有个在线刷leetcode,不过里面的题量比较少。牛客网刷题有个非常方便的地方就是有个讨论区,那里会有很多大佬分享他们的解题方法,不用我们去百度找题解。所以你做完后,实在想不出,可以很方便着去看别人是怎么做的。
    7 Q" F, j8 v4 M9 ]) h1 F% y4 C
    - F( Y" ?5 g: K2 C8 D至于leetcode,也是大部分题目官方都有给出答案,也是个不错的刷题网站。你们可以两个挑选一个,或者两个都刷。
    6 v" u( O8 T5 l8 y% q" a# ^9 i2 C0 p* l% q* O
    当然,还有其他刷题的网站,不过,其他网站没刷过,不大清除如何。! @' S5 T9 d; n) ?1 C' E( I% R
    & a. L3 H8 ~* V* F6 v) Q; Y
    至于leetcode,有中文版和英文版# o3 i( B7 V6 k# q& R6 v% \

    / M3 V9 t. Y8 X6 `, Mleetcode有中文版
    . Q& y% q, Z7 F- ~) y* ~, D! G7 J6 s: @6 U$ G
    英文版
    0 v# \- G( Q" S# e* X# \7 B5 M' N
    根据自己的兴趣选。7 m: [* w1 Q2 @' k' F6 f
    . z& I$ ~* F$ m6 {, f" S& L
    学习一些解题技巧8 N% e% }; _" k  m: }) i

    ) v7 n* @5 i9 Z: c/ v说实话,有些题在你没看别人的解法前,你好不知道有这么美妙优雅的解法,看了之后,卧槽,居然还可以这样。而我们在刷题的过程中,就要不断累积这些技巧,当你累计多了,你就会形成一种
    # b9 ?; M- r4 H* ~' m# B( Q神经反应,一下子就想到了某种方法。解题技巧很多,例如数组下标法、位图法、双指针等等,我自己也分享过一篇总结一些算法技巧的文章7 a! v. a0 w6 k, t/ }7 j
    , S. z' Q" k2 D: J
    推荐阅读:一些常用的算法技巧总结. H* @3 M4 ]6 f5 _+ I
    8 N2 C$ h/ G: E. b) a5 ~" ^
    例如在刷题的时候,我们要学会巧用双指针、数组下标法、位运算等等技巧来解决问题,可能会有意想不到的效果。我给你再找点我之前写文章的一些例子吧:
    0 x1 B5 J/ s( \
    6 `1 a" g# S. j* M% W分享一道解法巧妙的算法题5 W! p. X+ K. k- z- v8 V
    ' U+ V# U5 N) {. ~5 X/ N
    【算法技巧】位运算装逼指南) u0 P( _* w% B. {! h5 q2 m

    . G5 ~) _' O: ?! ~3 `  h这是个长期累积的过程,我自己也精彩在我的公众号里分享一些解题的文章,感兴趣的可以关注我的公众号:帅地玩编程。
    ( X  J3 W9 c& l' ^
    % p: k7 T% A1 p1 Y9 ^. o5 k& A再说数据结构发重要性
    0 C8 f3 _3 I" n1 U
    + Z) }  Y, d& o7 r! {: ?5 B& Q- }前面我主要是说了我平时都是怎么学习算法的。在数据结构方法,我只是列举了你们一定要学习链表和树(二叉堆),但这是最基本的,刷题之前要掌握的,对于数据结构,我列举下一些比较重要的:- J: [; ?2 h4 ^8 b
    - c0 f. Y( g* y1 k1 R6 h
    1、链表(如单向链表、双向链表)。
    0 X7 C7 |3 N, ~1 m8 ?( g: R  O' [
    2、树(如二叉树、平衡树、红黑树)。- D4 a0 z, h' c7 N

    ) u* n! p! u3 j9 n! R2 M* `2 {3、图(如最短路径的几种算法)。6 Q# l" l* @/ p& l0 U# Q. `- B
    ' \  j2 y0 ?( T; _
    4、队列、栈、矩阵。
    , A+ r5 s. ~2 o8 S
    8 t6 R# [% U# u( S" J( l对于这些,自己一定要动手实现一遍。你可以看书,也可以看视频,新手可以先看视频,不过前期可以看视频,之后我建议是一定要看书。
    5 D# l0 R( d7 |% f* R+ f" I# o+ C! u+ w# M# i) Q9 m
    例如对于平衡树,可能你跟着书本的代码实现之后,过阵子你就忘记,不过这不要紧,虽然你忘记了,但是如果你之前用代码实现过,理解过,那么当你再次看到的时候,会很快就记起来,很快就知道思路,而且你的抽象能力等等会在不知不觉中提升起来。之后再学习红黑树啊,什么数据结构啊,都会学的很快。
    - z% ~. G' |9 Z" i& u) P3 b0 o
    # _, @0 u# f- U$ O! s5 H* i* e对于有哪些值得学习的算法,我之前也总结过,这里推荐给大家程序员必须掌握的核心算法有哪些?,这篇文章居然 40多万阅读量了,有点受宠若惊。: e4 I' K" d* L) A2 i1 R
    + K. M1 r4 v& R0 K/ b, X
    最最重要
    ; u, M8 s; O4 H$ S/ v, U
    5 u* v3 w# ]' C, n6 R3 p7 x动手去做,动手去做,动手去做。重要的话说三遍。3 U9 V- x0 O, @8 l( M

    2 @. T" [+ h- v" k千万不要找了一堆资源,订好了学习计划,我要留到某某天就来去做…5 C$ h' X- S" j: z1 g' x2 U
    & Z9 [0 Y! f5 `7 j7 u7 W( T) [
    千万不要这样,而是当你激情来的时候,就马上去干,千万不要留到某个放假日啊什么鬼了,很多这种想法的人,最后会啥也没做的。
      F4 K: m2 t9 ~' Q1 Q" {( a# x) X9 i6 r8 Y6 V. }' f  ]$ T( D
    也不要觉得要学习的有好多啊,不知道从哪学习起。我上面说了,可以先学习最基本的,然后刷题,刷题是一个需要长期坚持的事情,一年,两年。在刷题的过程中,可以穿插和学习其他数据结构。
    & p, _; k9 M- \- ?+ P
    4 p/ G& J( L6 b总结一下吧
    " R5 q/ ~# o) ]
    , k- L6 L$ ?3 o. S; i( n! _所以我给大家的建议就是,先学习基本的数据结构以及算法思想,不要盲目刷题,接着刷题的过程中,不能得过且过,尽量追求最优解,还有就是要跳出舒适区,逼自己成长,刷题的过程中,要学会分类总结。2 e. }4 s  y% m

    ; m0 v' V+ J8 R$ H, a当然,最重要的,就是你去动手了,不然,一切免谈!3 K; U4 B  c2 N9 H* K! y
    : N5 k% s7 V% |; g9 a- ?
    看在熬夜写过的份上,送我个赞呗,嘻嘻。
    & T- x/ [. S: P) W& l5 s' x. F+ h! f3 d# w————————————————, Y  b' f* j9 C, ]
    版权声明:本文为CSDN博主「帅地」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    ( I- P. A! m- }3 r) e原文链接:https://blog.csdn.net/m0_37907797/article/details/104765116
    8 R( [: F' T/ y% D9 G' L
    ; h4 I* p( c2 U3 i. Q( {& o# S$ `4 s% |* H' H& `( h
    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-4-21 06:24 , Processed in 0.469980 second(s), 51 queries .

    回顶部