数学建模笔记——评价类模型(三)

最近回到老家养生,逗逗鸡遛遛狗看看小说,就没怎么更新,当然也没怎么学习,不知不觉都一周了……嗯,这样确实不太好,接下来会恢复更新的频率,一周两三篇。由于就我一个人写,效率也不太高,还请谅解。

由于这几天没看消息,微信后台有个同学拜托我找书,但超过48小时就无法回复了,qwq向这位朋友说一声抱歉,如果看到的话可以直接加我好友~其他想找书的同学也可以直接加我微信……毕竟如果不是网上可以找到的免费电子书,全国图书馆联盟的书基本都是三元一本,自己付费hhh……淘宝一般收五元一本,想来这两元就是人工费了……所以不是我要收三块钱,是人家网站要收三块钱……

好的,废话不多说,今天再讲一个评价类模型——模糊综合评价模型。

事先声明,我也是第一次接触这方面知识,可能无法很好地去解释原理什么的,应用的过程我会好好写的。

(至于上一篇文章说的熵权法还有一个之前提到的灰色关联分析,回头我再补上)

模糊综合评价模型

简介

首先来说明以下“模糊数学”,模糊数学是研究和处理模糊现象的一种数学理论和方法。在实际生活中,有许多概念难以用确定性的集合去描述。例如“年轻”这个概念,是1530岁属于年轻呢,还是1825属于年轻呢?对于这种问题,每个人可能会有不同的看法,也很难给出精确的范围,我们可以把它理解成一种模糊的概念。

生活中常提到的大与小,长与短,美与丑等概念,都是一种模糊的概念。其实还蛮好识别的,可以问问自己,多大算大?多小算小?多长算长?这种问题感觉有点儿抬杠似的,不过正是因为没有一个精确的范围,我们只能发出这样的疑问。与这种模糊概念相对应的,就是确定性概念了,例如性别,一般而言不是男就是女,且基本有了准确的划分依据;再比如身高,都是180,190这样的测量结果,也是十分精确,并不会有太大歧义的。注意,“身高”是一个确定性概念,而“高”就是一个模糊性概念,大家自己想一想hhh

模糊数学就是用来处理涉及模糊概念的问题,尝试使用某种方法将模糊的概念量化,方便进行处理计算。模糊综合评价,自然就是模糊数学在评价类问题的一大应用了,也就是处理涉及模糊概念的评价类问题。

其实也可以发现了,评价类问题的核心之一,就是把各种评价指标量化,再去加权啦求和啦等等,基本都差不太多,模糊综合评价模型也是如此,理解以及实践起来都不是太难。(此处仅指我接触到的评价类模型,太高深的就不晓得了)

相关概念

为了更好地解释之后的模型,有必要介绍一些模糊数学里的相关概念。

首先回顾一下经典的集合。我们在高中的时候就接触了集合的概念:具有相同属性的事物的集体。这种经典集合有一些基本属性,例如确定性,给定一个集合,任给一个元素,这个元素要么属于,要么不属于这个集合,不存在第三种情况。

在模糊综合评价模型中,我们不用这种经典的集合,因为我们要处理的是模糊概念,所以需要使用模糊集合。模糊集合是用来描述模糊性概念的集合,它与经典集合的区别之一是,模糊集合不具备确定性。例如35岁,我们既可以认为它“年轻”,也可以认为它是“中年”,并没有一个精确的界定。

因此,我们不像传统集合那样,一个元素要么属于一个集合,要么不属于。我们使用“隶属度”来表示元素与模糊集合之间的关系,也就是元素隶属于模糊集合的程度。谈到隶属度,就有必要提到隶属函数,这是一个很重要的概念。简单而言,隶属函数就是隶属度对各个元素的函数,定义域是我们所研究的元素,函数值就是隶属度。隶属度的范围是[0,1],其值越大,就代表越属于这个集合。(隶属函数内实际上不是按定义域值域去描述的,这里只是方便理解qwq)

举一个简单的例子。我们要衡量“年轻”这个概念,不好直接在0-150岁之间画一条线,把年轻和不年轻区分开。因此对于0-150之间的每一个整数年龄,我们给定一个相应的值,也就是隶属度,来判断它与“年轻”这个集合的关系。为了更方便的给出这样的值,就设计了以我们想要研究的元素——这里是0-150之间的整数——为定义域的函数,隶属函数。该隶属函数U_{A}(x)定义如下。

其中A代表模糊集合,在这里即是“年轻”这个集合,x代表集合中的元素,即0-150之间的年龄,我们可以画出函数图像。


可以发现,当年龄小于20时,相应的隶属度为1,即我们认为小于20岁一定属于年轻的范畴;当年龄在20到40之间时,隶属度随着年龄的增大而逐渐变小;当年龄大于40时,我们认为其基本脱离了年轻的范畴,隶属度也全部为0。如果一个人30岁,我们无法认定他是否年轻,但我们使用0.5这个隶属度,认为30岁有50%的程度,属于年轻的范畴,也有50%的程度不属于年轻的范畴。0.5衡量了30岁这个年龄属于年轻这个集合的程度,表达了30岁和“年轻”之间的关系。

我们也可以从概率的角度去理解隶属度,实际生活中隶属度的确定,也往往是通过调查来实现。例如问100个人,30岁是不是年轻,如果有40个人回答是,其隶属度就可以确定为40/100=0.4,当调查的总数越大,这一值就越趋近于真正的隶属度。是不是很像“频率趋近于概率”呢?至于上面的隶属函数,只是为了方便理解随意构造出来的,并不等同于真实的调查结果,但是依然反映了构造者的主观想法。事实上,隶属函数也不是唯一的,不同的人,不同大小的样本,得出的隶属函数很可能是不同的。

嗯,基本的概念,也就是模糊集合,隶属函数,隶属度到此已普及完毕,由于我也接触没多久,可能讲得不太清楚准确。简单来说,我理解的隶属度,就是元素属于某个模糊集合的程度,而隶属函数就是用来确定隶属度的函数,就这样。倒也不必太多纠结,不影响后面的具体应用即可。

模糊集合的分类

一般来说,模糊集合主要有三类,分别为偏小型,中间型和偏大型。其实也就类似于TOPSIS方法中的极大型、极小型、中间型、区间型指标,并没有什么特别的。举个例子,“年轻”就是一个偏小型的模糊集合,因为岁数越小,隶属度越大,就越“年轻”;“年老”则是一个偏大型的模糊集合,岁数越大,隶属度越大,越“年老”;而“中年”则是一个中间型集合,岁数只有处在某个中间的范围,隶属度才越大。总结来说,就是考虑“元素”与“隶属度”的关系,再类比一下,就是考虑隶属函数的单调性。下图可以代表“年轻”、“中年”、“年老”这三个模糊集合的隶属函数图像,看一下就懂我的意思啦。



为什么要知道模糊集合的分类呢?因为在模糊综合评价模型中,需要确定相应的模糊概念属于偏大型还是偏小型还是中间型,之后再采用相应的隶属函数,才能求出合适的隶属度。再次注意,不管模糊集合是哪一种类型,隶属度越大,属于这个集合的程度也越大,记住了吗?

以上只是常见的三种,其实想一想就知道,应该有蛮多形状的,只要一个元素对应一个隶属度,且范围在[0,1]之间即可。上述三种只是比较常见的三种,也是评价类问题常涉及的模糊集合类型。

当然啦,可能还有一些疑问,例如对于“年轻”,“年老”这种集合,我们把岁数当成了我们研究的元素,岁数是可以量化为数字的。类似的,快与慢这种模糊概念可以使用速度量化,深与浅可以使用深度量化等等。那,美与丑,使用啥子来量化呢?这个我也不晓得……想来没有一个常见的变量可以用来量化美与丑,一般的评价类模型中,应该也不会涉及到这种比较坑的问题吧(不会吧不会吧)。感兴趣的还是自行查阅吧……

隶属函数的确定方法

确定隶属函数,其实也就是给定一个模糊集合,之后再通过某些方法,给出我们需要研究的元素相对于该模糊集合的隶属度。例如对于“年轻”这个模糊集合,我们就要想办法去确定0岁-150岁之间每个岁数相对于“年轻”集合的隶属度,画出图像,便是隶属函数的图像了。

具体有三种方法来确定隶属函数。

1.模糊统计法
模糊统计法的原理是,找多个人对同一个模糊概念进行描述,用隶属频率去定义隶属度。类似于求概率时,我们可以用频率趋近于概率。例子我们上文提到过,我们想知道30岁相对于“年轻”的隶属度,那就找来n个人问一问,如果其中有m个人认为30岁属于“年轻”的范畴,那\frac {m}{n}就可以用来作为30岁相对于“年轻”的隶属度。n越大时,这一估计越符合实际情况,也就越准确。其他的岁数也照这个方法去问,就能画出一个函数图像啦。

嗯,这个方法比较符合实际情况,但是往往通过发放问卷或者其他手段进行调查,数学建模比赛时,时间可能不太够吧,所以仅做介绍,基本不予采用。(不过现在淘宝填问卷还蛮快的,有钱真好)

2.借助已有的客观尺度
对于某些模糊集合,我们可以用已经有的指标去作为元素的隶属度。例如对于“小康家庭”这个模糊集合,我们想确定100户家庭的隶属度,那就可以用“恩格尔系数”衡量相应的隶属度。恩格尔系数=食品支出总额/家庭总支出,显而易见,家庭越接近小康水平,其恩格尔系数应该越低,那“1-恩格尔系数”就越大,我们便可以把“1-恩格尔系数”看作家庭相对于“小康家庭”的隶属度。不过这只是打个比方,毕竟对于富豪家庭,恩格尔系数很小,隶属度很大,但是富豪家庭是不是“小康家庭”,还是有待商榷的。
类似的,对于“设备完好”这一模糊集合,我们可以使用设备完好率来衡量隶属度,对于“质量稳定”这一模糊集合,我们可以使用正品率衡量隶属度。遇到问题的时候可以先百度一下,指不定就找到了一个好的指标。

不过要注意,隶属度是在[0,1]之间的,因此寻找指标的时候,也要注意在[0,1]之间。不在的话,可以进行归一化处理,之前提到过的。

这种方法建模中可以使用,看具体题目而定啦

3.指派法
这是一个主观性比较强的方法,即凭主观意愿,在确定模糊集合的所属分类后,给它指派一个隶属函数,得到元素的隶属度。听上去就很主观,但也是比赛中最常用的方法之一,只需进行选择,便可轻轻松松得到隶属函数。
我把常用的函数形式贴在下面。



图片可能不是很清楚,但基本可以看出,对于偏小型模糊集合,隶属函数总体上递减,也就是元素的某个特征越大,隶属度越小;对于偏大型集合,隶属函数总体上递增,也就是元素的某个特征越大,隶属度越大;对于中间型集合,隶属函数总体上先递增后递减,中间一部分或是某个点取到最大值。

实际建模比赛中,为了计算方便,最常使用的是梯形分布式隶属函数(我听的课是这么说的)。当然啦,具体问题还是要具体分析,隶属函数平滑一点,陡峭一点,中间一部分还是一个点取极值,都要根据具体的情况去抉择,但总体上就是这么回事了。

再看一眼梯形分布式的隶属函数图像。


以上就是确定隶属函数的几种方法了。还有一些其他的方法,比如德尔菲法,二元对比排序法,综合加权法等等,有兴趣可以自己查阅。

模糊综合评价解题步骤

铺垫了这么久,总算可以用这个方法进行解题啦。

首先我们还是要引入几个概念。

  1. 因素集(评价指标集):U=\{u_1,u_2,u_3,...,u_n\}
  2. 评语集(评价的结果):V=\{v_1,v_2,v_3,...,v_m\}
  3. 权重集(指标的权重):A=\{a_1,a_2,a_3,...,a_n\}

举个例子说明,如果我们要评价一名学生的表现,按照之前提到的层次分析法或者TOPSIS法,都是找到指标后进行一个综合的打分,往往是用来比较多名同学的表现,给出排名。上述的评价指标,其实就对应着这里的因素集。我们可以令U=\{专业排名,课外实践,志愿服务,竞赛成绩\},使用因素集类的四个指标来评价一名学生的综合表现。

评语集,即是相应对象的评价结果,类似于上面提到的“打分结果”。不同之处在于,评语集并非是分数的集合,而是由模糊概念组成的评语。例如评定学生的表现,我们就可以把评语集设定为V=\{优秀,良好,差\}。评语集中的这三个评语,都是模糊的概念,不过在处理具体问题时,我们也可以把方案放在评语集中,以选择最佳的方案。

权重集,就是你想的那个权重,给每个指标进行赋权,用来进行综合评价,就不多说了。在这里,我们可以取权重集A=\{0.5,0.1,0.1,0.3\},作为因素集中四个指标的权重。

那模糊综合评价模型解决的是什么问题呢?嗯,其实就是给定对象,用因素集的指标一番评价之后,从评语集中找到一个最适合它的评语。如果评语集中是方案的话,就是选出一个最恰当的方案。那这种“合适”用什么来衡量呢?显而易见嘛,就是隶属度,隶属于某个模糊集合的程度。

ok,举例概括一下,我们现在有一个学生,有一个因素集U=\{专业排名,课外实践,志愿服务,竞赛成绩\},有一个权重集A=\{0.5,0.1,0.1,0.3\},有一个评语集V=\{优秀,良好,差\}。我们的目的就是一番操作之后,给学生一个合适的评语。明白了吧~

一级模糊综合评价模型

一级模糊综合评价模型,也就是因素集中的评价指标只有一层,不存在一层又嵌套一层的情况,也是最基本的情况。

解决这种问题,主要分为这么几步。

  1. 确定因素集U。也就是确定评价指标喽,这个在层次分析法中就提到过,不多说
  2. 确定各因素的权重A。就是赋权啦,结合生活常识,题目条件,使用之前提到的层次分析法,熵权法(回头提),或者是搜索相关论文,使用人家的权重向量给评价指标赋权,不多说。
  3. 确定评语集V。也就是要给出相应的评语,例如“好、较好、中等、差、很差”,或者“优秀、良好、差”。评语集中的评语往往是模糊概念,这也是使用模糊综合评价的原因。
  4. 确定模糊综合判断矩阵。判断矩阵我们在层次分析法也讲过,这里的判断矩阵有所不同。对于因素集中的某个指标u_i而言,我们想要得出研究对象依据u_i在评语集中各个评语的隶属度。举个例子,评价学生时不是有个指标叫专业排名吗。我们假设A同学的专业排名是10/50,那么单从专业排名这个指标来看,A同学相对于“优秀”的隶属度可能是0.8,相对于“良好”的隶属度可能是0.6,相对于“差”的隶属度可能是0.1。这样我们就得到专业排名这一指标相对于评语集的隶属度向量,R_1=[0.8,0.6,0.1]。这么说就明白了吧。
    类似的,我们也可以得到该同学在其他三个指标方面相对于评语集的隶属度向量,可以分别记为R_2,R_3,R_4。我们将这四个隶属度向量拼接起来,令R=[R_1,R_2,R_3,R_4]^T,R则是一个4×3的矩阵,四行代表着四个指标,三列代表着三个评语。而R中的任何一个元素r_{ij},则代表着,但从指标u_i的角度去看,我们的研究对象相对于评语v_j的隶属度。这么说,应该比较清楚了吧。
    嗯,R就是我们需要寻找的判断矩阵。
  5. 进行综合评判。我们已经得到了判断矩阵R,如果有n个评价指标,m个评语,则R是一个n×m的矩阵。其中,R的第j列,从上往下分别代表着,从不同指标的角度去看,研究对象相对于第j个评语v_j的隶属度。那如何得到研究对象相对于该评语的综合隶属度呢?相信你已经晓得了,加权求和呗,不然我们的权重集是干嘛的。因此,研究对象相对于评语v_j的综合隶属度,就是\sum_{i=1}^n (a_i*r_{ij})。是不是有种熟悉的感觉?
    其实就是这个样子,这几种评价类模型,说来说去都是加权求和打分,只不过这里的“分数”就是综合隶属度罢了。我们可以直接使用矩阵乘法求出相对于所有评语的综合隶属度,B=A*R,其中A1×n的矩阵,Rn×m的矩阵,那么B就是1×m的矩阵,其中的任意一个值b_j,其实也就是研究对象相对于评语集v_j的隶属度了。
    那如何找到最合适的评语呢?肯定就是找隶属度最大的那一个,作为最终的评语嘛。

嗯,到此为止,我们已经学会了一级模糊综合评价的解题步骤。那应该也意识到了,最重要的就是明确判断矩阵和权重向量,两个一乘,综合隶属度向量就出来了,选择最大的就是。权重向量之前已经说过,那判断矩阵,或者说判断矩阵中的n*m个隶属度,怎么求呢?上面也提到了确定隶属函数的方法。有了隶属函数,隶属度也就可以求出来了。实际建模中,我们常常使用“指派法”,指定一个符合实际问题的隶属函数,使用其他方法也是可以滴。只要知道判断矩阵和权重向量,评价问题就基本解决了。

其实解题步骤还蛮简单的吧,只不过前面铺垫的太多,所以我写的也比较多,真做起来倒也不是很复杂。下面我就找一个中国大学MOOC上的例子,展示一下解题过程。嗯,全部手打太浪费时间,我就贴图啦。
这个是题目,也就是给出了污染物的浓度以及每个污染物在空气质量等级评定时的权重,让我们确定这一天的空气质量等级。


下图是评价标准。



污染物的浓度就是本题的因素集,空气质量的四个等级就是评语集,也是一种模糊概念。例如当TSP的浓度为0.20时,我们无法确定单从TSP的角度,空气质量等级是一级还是二级,但我们可以确定相对于每个等级的隶属度。

隶属度如何确认呢?这里我们可以使用指派法,指定四个模糊集合的隶属函数,采用最常用也比较符合题意得梯形分布式隶属函数。可以发现,“一级”应该是一个偏小型的模糊概念,即污染物浓度越低,隶属于“一级”的程度越大;“二级”和“三级”应该是中间型的概念,污染物浓度处于中间的某个范围时,相应的隶属度越大;“四级”是个偏大型概念,污染物浓度越大,隶属于“四级”的程度也越大。我们确定了评语集中模糊概念的类型后,就可以给出相应的梯形分布隶属函数了。如下图。


这里\alpha_1,\alpha_2,\alpha_3,\alpha_4对应的就是上表中每个污染物浓度恰好在一二三四这四个等级时的数值。从隶属函数的角度来看,当污染物浓度等于这表中的数值时,相对于相应空气质量等级的隶属度刚好为1。应该不是很难理解,想一想就大概明白了。

确定了隶属函数,直接把这一天的每个污染物的浓度带进隶属函数,就可以求出隶属度,得到判断矩阵了。


有了判断矩阵,也有了权重向量,就可以直接计算综合隶属度向量B啦。

显而易见,这一天的空气质量隶属于二级的程度最大,所以我们认为这一天空气质量等级为二级。

嗯,例题也讲好了。大家可以去中国大学MOOC上搜华中农业大学的数学建模课,里面有模糊综合评价更加详细的讲解。这个例题也来自该课程。嗯,还有其他的建模方法。


多级模糊综合评价

多级模糊综合评价,其实就相当于多了几层因素集。例如我们同时要处理20个评价指标,确定权重会比较麻烦,那我们就可以把20个指标分为四类,在每个类之内确定一次指标的权重,之后再确定四个大类的权重。这样子就会比较方便。如果有很多指标,就可以多嵌几层,也就是多级模糊综合评价了。


看上图这个学生评价模型,就是一个二级的综合评价模型,指标后面的数字代表在相应那一层的权重。这个时候我们如何确定判断矩阵呢?肯定是不能一上来就确定第一层的判断矩阵,需要从最后一层,一步一步推上来。

例如我们考察学习成绩这一指标对应的隶属度向量时,就需要先考察它的下一层指标,也就是专业课成绩和非专业课成绩这两个指标。例如Z同学专业课成绩是90,那从这一指标来看,Z同学的隶属度向量是x_1=[0.8,0.2,0],评语集还是“优秀、良好、差”。之后再看看非专业课成绩,得到一个隶属度向量x_2=[0.7,0.3,0]。我们用这两个向量,就可以构造出一个矩阵X_1=[x_1,x_2]^T,这是一个2×3矩阵,代表着学习成绩这一指标下两个二级指标组成的判断矩阵。那如何得到学习成绩这个一级指标相对于评语集的隶属度向量呢?很简单呀,不是有权重向量A_1=[0.6,0.4]了吗。我们用A*X_1,就可以得到一个1×3的向量,自然就是从学习成绩这一指标来看,Z同学相对于评语集的隶属度向量了。嗯,拆开了看,就是把两个二级指标的隶属度加权求和罢了,应该不难理解。

类似的,求出其他一级指标的隶属度向量,组成一级指标的判断矩阵,再加权一次,就可以得到综合隶属度向量了。

嗯,其实就是先得到n级指标的判断矩阵,得到n-1级指标的隶属度向量,再用n-1级指标的隶属度向量组成判断矩阵,得到n-2级指标的隶属度向量……以此类推,得到一级指标的隶属度向量,也就是用来综合评价的隶属度向量了。

嗯,讲完啦~

至于局限性就不说了,知道使用的条件也就行了,我也不知道说些什么,那就这样,下次再见~

对了对了,最后提醒一下,如果想要代找pdf,就是类似于淘宝上的业务,直接在公众号推文里的留言小程序留言即可,也可以加我微信。后台回复的话,如果没能及时看到,48小时后就无法回复了。嗯,不收人工费,网站那三块钱得自己付。

以上。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,417评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,921评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,850评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,945评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,069评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,188评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,239评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,994评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,409评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,735评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,898评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,578评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,205评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,916评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,156评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,722评论 2 363
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,781评论 2 351