久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

java算法之余弦相似度計(jì)算字符串相似率

瀏覽:83日期:2022-08-13 08:08:23
概述

功能需求:最近在做通過(guò)爬蟲(chóng)技術(shù)去爬取各大相關(guān)網(wǎng)站的新聞,儲(chǔ)存到公司數(shù)據(jù)中。這里面就有一個(gè)技術(shù)點(diǎn),就是如何保證你已爬取的新聞,再有相似的新聞

或者一樣的新聞,那就不存儲(chǔ)到數(shù)據(jù)庫(kù)中。(因?yàn)橛芯W(wǎng)站會(huì)去引用其它網(wǎng)站新聞,或者把其它網(wǎng)站新聞拿過(guò)來(lái)稍微改下內(nèi)容就發(fā)布到自己網(wǎng)站中)。

解析方案:最終就是采用余弦相似度算法,來(lái)計(jì)算兩個(gè)新聞?wù)牡南嗨贫取,F(xiàn)在自己寫(xiě)一篇博客總結(jié)下。

一、理論知識(shí)

先推薦一篇博客,對(duì)于余弦相似度算法的理論講的比較清晰,我們也是按照這個(gè)方式來(lái)計(jì)算相似度的。網(wǎng)址:相似度算法之余弦相似度。

1、說(shuō)重點(diǎn)

我這邊先把計(jì)算兩個(gè)字符串的相似度理論知識(shí)再梳理一遍。

(1)首先是要明白通過(guò)向量來(lái)計(jì)算相識(shí)度公式。

java算法之余弦相似度計(jì)算字符串相似率

(2)明白:余弦值越接近1,也就是兩個(gè)向量越相似,這就叫'余弦相似性',余弦值越接近0,也就是兩個(gè)向量越不相似,也就是這兩個(gè)字符串越不相似。

2、案例理論知識(shí)

舉一個(gè)例子來(lái)說(shuō)明,用上述理論計(jì)算文本的相似性。為了簡(jiǎn)單起見(jiàn),先從句子著手。

句子A:這只皮靴號(hào)碼大了。那只號(hào)碼合適。

句子B:這只皮靴號(hào)碼不小,那只更合適。

怎樣計(jì)算上面兩句話的相似程度?

基本思路是:如果這兩句話的用詞越相似,它們的內(nèi)容就應(yīng)該越相似。因此,可以從詞頻入手,計(jì)算它們的相似程度。

第一步,分詞。

句子A:這只/皮靴/號(hào)碼/大了。那只/號(hào)碼/合適。

句子B:這只/皮靴/號(hào)碼/不/小,那只/更/合適。

第二步,計(jì)算詞頻。(也就是每個(gè)詞語(yǔ)出現(xiàn)的頻率)

句子A:這只1,皮靴1,號(hào)碼2,大了1。那只1,合適1,不0,小0,更0

句子B:這只1,皮靴1,號(hào)碼1,大了0。那只1,合適1,不1,小1,更1

第三步,寫(xiě)出詞頻向量。

句子A:(1,1,2,1,1,1,0,0,0)

句子B:(1,1,1,0,1,1,1,1,1)

第四步:運(yùn)用上面的公式:計(jì)算如下:

java算法之余弦相似度計(jì)算字符串相似率

計(jì)算結(jié)果中夾角的余弦值為0.81非常接近于1,所以,上面的句子A和句子B是基本相似的

二、實(shí)際開(kāi)發(fā)案例

我把我們實(shí)際開(kāi)發(fā)過(guò)程中字符串相似率計(jì)算代碼分享出來(lái)。

1、pom.xml

展示一些主要jar包

<!--結(jié)合操作工具包--><dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-lang3</artifactId> <version>3.5</version></dependency><!--bean實(shí)體注解工具包--> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId></dependency><!--漢語(yǔ)言包,主要用于分詞--><dependency> <groupId>com.hankcs</groupId> <artifactId>hanlp</artifactId> <version>portable-1.6.5</version></dependency>2、main方法

/** * 計(jì)算兩個(gè)字符串的相識(shí)度 */public class Similarity { public static final String content1='今天小小和爸爸一起去摘草莓,小小說(shuō)今天的草莓特別的酸,而且特別的小,關(guān)鍵價(jià)格還貴'; public static final String content2='今天小小和媽媽一起去草原里采草莓,今天的草莓味道特別好,而且價(jià)格還挺實(shí)惠的'; public static void main(String[] args) {double score=CosineSimilarity.getSimilarity(content1,content2);System.out.println('相似度:'+score);score=CosineSimilarity.getSimilarity(content1,content1);System.out.println('相似度:'+score); } }

先看運(yùn)行結(jié)果:

java算法之余弦相似度計(jì)算字符串相似率

通過(guò)運(yùn)行結(jié)果得出:

(1)第一次比較相似率為:0.772853 (說(shuō)明這兩條句子還是挺相似的),第二次比較相似率為:1.0 (說(shuō)明一模一樣)。

(2)我們可以看到這個(gè)句子的分詞效果,后面是詞性。

3、Tokenizer(分詞工具類(lèi))

import com.hankcs.hanlp.HanLP;import com.hankcs.hanlp.seg.common.Term;import java.util.List;import java.util.stream.Collectors;/** * 中文分詞工具類(lèi)*/public class Tokenizer { /** * 分詞*/ public static List<Word> segment(String sentence) {//1、 采用HanLP中文自然語(yǔ)言處理中標(biāo)準(zhǔn)分詞進(jìn)行分詞List<Term> termList = HanLP.segment(sentence);//上面控制臺(tái)打印信息就是這里輸出的System.out.println(termList.toString());//2、重新封裝到Word對(duì)象中(term.word代表分詞后的詞語(yǔ),term.nature代表改詞的詞性)return termList.stream().map(term -> new Word(term.word, term.nature.toString())).collect(Collectors.toList()); }}4、Word(封裝分詞結(jié)果)

這里面真正用到的其實(shí)就詞名和權(quán)重。

import lombok.Data;import java.util.Objects;/** * 封裝分詞結(jié)果*/@Datapublic class Word implements Comparable { // 詞名 private String name; // 詞性 private String pos; // 權(quán)重,用于詞向量分析 private Float weight; public Word(String name, String pos) {this.name = name;this.pos = pos; } @Override public int hashCode() {return Objects.hashCode(this.name); } @Override public boolean equals(Object obj) {if (obj == null) { return false;}if (getClass() != obj.getClass()) { return false;}final Word other = (Word) obj;return Objects.equals(this.name, other.name); } @Override public String toString() {StringBuilder str = new StringBuilder();if (name != null) { str.append(name);}if (pos != null) { str.append('/').append(pos);}return str.toString(); } @Override public int compareTo(Object o) {if (this == o) { return 0;}if (this.name == null) { return -1;}if (o == null) { return 1;}if (!(o instanceof Word)) { return 1;}String t = ((Word) o).getName();if (t == null) { return 1;}return this.name.compareTo(t); }}5、CosineSimilarity(相似率具體實(shí)現(xiàn)工具類(lèi))

import com.jincou.algorithm.tokenizer.Tokenizer;import com.jincou.algorithm.tokenizer.Word;import org.apache.commons.lang3.StringUtils;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.util.CollectionUtils;import java.math.BigDecimal;import java.util.*;import java.util.concurrent.ConcurrentHashMap;import java.util.concurrent.atomic.AtomicInteger;/** * 判定方式:余弦相似度,通過(guò)計(jì)算兩個(gè)向量的夾角余弦值來(lái)評(píng)估他們的相似度 余弦?jiàn)A角原理: 向量a=(x1,y1),向量b=(x2,y2) similarity=a.b/|a|*|b| a.b=x1x2+y1y2 * |a|=根號(hào)[(x1)^2+(y1)^2],|b|=根號(hào)[(x2)^2+(y2)^2]*/public class CosineSimilarity { protected static final Logger LOGGER = LoggerFactory.getLogger(CosineSimilarity.class); /** * 1、計(jì)算兩個(gè)字符串的相似度 */ public static double getSimilarity(String text1, String text2) {//如果wei空,或者字符長(zhǎng)度為0,則代表完全相同if (StringUtils.isBlank(text1) && StringUtils.isBlank(text2)) { return 1.0;}//如果一個(gè)為0或者空,一個(gè)不為,那說(shuō)明完全不相似if (StringUtils.isBlank(text1) || StringUtils.isBlank(text2)) { return 0.0;}//這個(gè)代表如果兩個(gè)字符串相等那當(dāng)然返回1了(這個(gè)我為了讓它也分詞計(jì)算一下,所以注釋掉了)//if (text1.equalsIgnoreCase(text2)) {// return 1.0;//}//第一步:進(jìn)行分詞List<Word> words1 = Tokenizer.segment(text1);List<Word> words2 = Tokenizer.segment(text2);return getSimilarity(words1, words2); } /** * 2、對(duì)于計(jì)算出的相似度保留小數(shù)點(diǎn)后六位 */ public static double getSimilarity(List<Word> words1, List<Word> words2) {double score = getSimilarityImpl(words1, words2);//(int) (score * 1000000 + 0.5)其實(shí)代表保留小數(shù)點(diǎn)后六位 ,因?yàn)?034234.213強(qiáng)制轉(zhuǎn)換不就是1034234。對(duì)于強(qiáng)制轉(zhuǎn)換添加0.5就等于四舍五入score = (int) (score * 1000000 + 0.5) / (double) 1000000;return score; } /** * 文本相似度計(jì)算 判定方式:余弦相似度,通過(guò)計(jì)算兩個(gè)向量的夾角余弦值來(lái)評(píng)估他們的相似度 余弦?jiàn)A角原理: 向量a=(x1,y1),向量b=(x2,y2) similarity=a.b/|a|*|b| a.b=x1x2+y1y2 * |a|=根號(hào)[(x1)^2+(y1)^2],|b|=根號(hào)[(x2)^2+(y2)^2] */ public static double getSimilarityImpl(List<Word> words1, List<Word> words2) {// 向每一個(gè)Word對(duì)象的屬性都注入weight(權(quán)重)屬性值taggingWeightByFrequency(words1, words2);//第二步:計(jì)算詞頻//通過(guò)上一步讓每個(gè)Word對(duì)象都有權(quán)重值,那么在封裝到map中(key是詞,value是該詞出現(xiàn)的次數(shù)(即權(quán)重))Map<String, Float> weightMap1 = getFastSearchMap(words1);Map<String, Float> weightMap2 = getFastSearchMap(words2);//將所有詞都裝入set容器中Set<Word> words = new HashSet<>();words.addAll(words1);words.addAll(words2);AtomicFloat ab = new AtomicFloat();// a.bAtomicFloat aa = new AtomicFloat();// |a|的平方AtomicFloat bb = new AtomicFloat();// |b|的平方// 第三步:寫(xiě)出詞頻向量,后進(jìn)行計(jì)算words.parallelStream().forEach(word -> { //看同一詞在a、b兩個(gè)集合出現(xiàn)的此次 Float x1 = weightMap1.get(word.getName()); Float x2 = weightMap2.get(word.getName()); if (x1 != null && x2 != null) {//x1x2float oneOfTheDimension = x1 * x2;//+ab.addAndGet(oneOfTheDimension); } if (x1 != null) {//(x1)^2float oneOfTheDimension = x1 * x1;//+aa.addAndGet(oneOfTheDimension); } if (x2 != null) {//(x2)^2float oneOfTheDimension = x2 * x2;//+bb.addAndGet(oneOfTheDimension); }});//|a| 對(duì)aa開(kāi)方double aaa = Math.sqrt(aa.doubleValue());//|b| 對(duì)bb開(kāi)方double bbb = Math.sqrt(bb.doubleValue());//使用BigDecimal保證精確計(jì)算浮點(diǎn)數(shù)//double aabb = aaa * bbb;BigDecimal aabb = BigDecimal.valueOf(aaa).multiply(BigDecimal.valueOf(bbb));//similarity=a.b/|a|*|b|//divide參數(shù)說(shuō)明:aabb被除數(shù),9表示小數(shù)點(diǎn)后保留9位,最后一個(gè)表示用標(biāo)準(zhǔn)的四舍五入法double cos = BigDecimal.valueOf(ab.get()).divide(aabb, 9, BigDecimal.ROUND_HALF_UP).doubleValue();return cos; } /** * 向每一個(gè)Word對(duì)象的屬性都注入weight(權(quán)重)屬性值 */ protected static void taggingWeightByFrequency(List<Word> words1, List<Word> words2) {if (words1.get(0).getWeight() != null && words2.get(0).getWeight() != null) { return;}//詞頻統(tǒng)計(jì)(key是詞,value是該詞在這段句子中出現(xiàn)的次數(shù))Map<String, AtomicInteger> frequency1 = getFrequency(words1);Map<String, AtomicInteger> frequency2 = getFrequency(words2);//如果是DEBUG模式輸出詞頻統(tǒng)計(jì)信息//if (LOGGER.isDebugEnabled()) {// LOGGER.debug('詞頻統(tǒng)計(jì)1:n{}', getWordsFrequencyString(frequency1));// LOGGER.debug('詞頻統(tǒng)計(jì)2:n{}', getWordsFrequencyString(frequency2));//}// 標(biāo)注權(quán)重(該詞出現(xiàn)的次數(shù))words1.parallelStream().forEach(word -> word.setWeight(frequency1.get(word.getName()).floatValue()));words2.parallelStream().forEach(word -> word.setWeight(frequency2.get(word.getName()).floatValue())); } /** * 統(tǒng)計(jì)詞頻 * @return 詞頻統(tǒng)計(jì)圖 */ private static Map<String, AtomicInteger> getFrequency(List<Word> words) {Map<String, AtomicInteger> freq = new HashMap<>();//這步很帥哦words.forEach(i -> freq.computeIfAbsent(i.getName(), k -> new AtomicInteger()).incrementAndGet());return freq; } /** * 輸出:詞頻統(tǒng)計(jì)信息 */ private static String getWordsFrequencyString(Map<String, AtomicInteger> frequency) {StringBuilder str = new StringBuilder();if (frequency != null && !frequency.isEmpty()) { AtomicInteger integer = new AtomicInteger(); frequency.entrySet().stream().sorted((a, b) -> b.getValue().get() - a.getValue().get()).forEach( i -> str.append('t').append(integer.incrementAndGet()).append('、').append(i.getKey()).append('=') .append(i.getValue()).append('n'));}str.setLength(str.length() - 1);return str.toString(); } /** * 構(gòu)造權(quán)重快速搜索容器 */ protected static Map<String, Float> getFastSearchMap(List<Word> words) {if (CollectionUtils.isEmpty(words)) { return Collections.emptyMap();}Map<String, Float> weightMap = new ConcurrentHashMap<>(words.size());words.parallelStream().forEach(i -> { if (i.getWeight() != null) {weightMap.put(i.getName(), i.getWeight()); } else {LOGGER.error('no word weight info:' + i.getName()); }});return weightMap; }}

這個(gè)具體實(shí)現(xiàn)代碼因?yàn)樗季S很緊密所以有些地方寫(xiě)的比較繞,同時(shí)還手寫(xiě)了AtomicFloat原子類(lèi)。

6、AtomicFloat原子類(lèi)

import java.util.concurrent.atomic.AtomicInteger;/** * jdk沒(méi)有AtomicFloat,寫(xiě)一個(gè) */public class AtomicFloat extends Number { private AtomicInteger bits; public AtomicFloat() {this(0f); } public AtomicFloat(float initialValue) {bits = new AtomicInteger(Float.floatToIntBits(initialValue)); } //疊加 public final float addAndGet(float delta) {float expect;float update;do { expect = get(); update = expect + delta;} while (!this.compareAndSet(expect, update));return update; } public final float getAndAdd(float delta) {float expect;float update;do { expect = get(); update = expect + delta;} while (!this.compareAndSet(expect, update));return expect; } public final float getAndDecrement() {return getAndAdd(-1); } public final float decrementAndGet() {return addAndGet(-1); } public final float getAndIncrement() {return getAndAdd(1); } public final float incrementAndGet() {return addAndGet(1); } public final float getAndSet(float newValue) {float expect;do { expect = get();} while (!this.compareAndSet(expect, newValue));return expect; } public final boolean compareAndSet(float expect, float update) {return bits.compareAndSet(Float.floatToIntBits(expect), Float.floatToIntBits(update)); } public final void set(float newValue) {bits.set(Float.floatToIntBits(newValue)); } public final float get() {return Float.intBitsToFloat(bits.get()); } @Override public float floatValue() {return get(); } @Override public double doubleValue() {return (double) floatValue(); } @Override public int intValue() {return (int) get(); } @Override public long longValue() {return (long) get(); } @Override public String toString() {return Float.toString(get()); }}三、總結(jié)

把大致思路再捋一下:

(1)先分詞:分詞當(dāng)然要按一定規(guī)則,不然隨便分那也沒(méi)有意義,那這里通過(guò)采用HanLP中文自然語(yǔ)言處理中標(biāo)準(zhǔn)分詞進(jìn)行分詞。

(2)統(tǒng)計(jì)詞頻:就統(tǒng)計(jì)上面詞出現(xiàn)的次數(shù)。

(3)通過(guò)每一個(gè)詞出現(xiàn)的次數(shù),變成一個(gè)向量,通過(guò)向量公式計(jì)算相似率。

以上就是java算法之余弦相似度計(jì)算字符串相似率的詳細(xì)內(nèi)容,更多關(guān)于java算法的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 成人精品视频在线观看 | 国产欧美在线观看 | 欧美xxxx色视频在线观看免费 | 99re久久| 国产精品色一区二区三区 | 国产精品久久久久久久午夜片 | 天天干夜夜拍 | 国产一区视频在线 | 久久五月视频 | 日韩高清不卡一区二区三区 | 蜜臀精品久久久久久蜜臀 | 九九热免费精品视频 | 国内精品三级 | av在线免费观看一区二区 | 国产一区不卡 | 亚洲精品aaa | 国产九九av| 午夜精品久久久久久久久久久久久 | 国产精品久久久久无码av | 青青久久久 | 中文字幕在线一区二区三区 | 免费看的毛片 | 欧美日韩一区二区在线播放 | 玖玖国产精品视频 | 亚洲精品视频在线免费 | 国产精品日韩欧美一区二区三区 | 亚洲www永久成人夜色 | 久久99精品视频 | 99色播 | 国产小视频在线观看 | 在线观看国产一区 | 国产精品久久久久久久久久久杏吧 | 日韩在线视频第一页 | www久久精品 | 久久伊| 亚洲一区二区三区在线 | 久久久精品 | 欧美成视频 | 一二区视频 | 国产精品一二 | 欧美日韩视频一区二区 | 日韩欧美一区二区在线 | 国产一区二区三区精品久久久 | av网站观看| 久久中文网 | 亚洲国产精品一区二区第一页 | а√天堂中文在线资源8 | 亚洲一区二区在线 | 日韩精品观看 | 激情欧美一区二区三区中文字幕 | 精品国产一区三区 | 亚洲毛片在线观看 | 亚洲另类视频 | 久久久精品久久久久久 | av在线国产精品 | 欧美精品成人一区二区三区四区 | 一区二区在线 | 91av在线播放 | 久热精品在线视频 | 日韩欧美国产一区二区 | 免费一区 | 国产成人一区二区三区 | 国产美女永久免费无遮挡 | 天堂久久一区 | 欧美自拍视频 | 视频精品一区二区三区 | 日韩免费一区二区 | 嫩草影院黄色 | 一区二区在线视频 | 成人免费视频网址 | 亚洲人成人一区二区在线观看 | 国产欧美一区二区三区在线看 | 国产人免费人成免费视频 | 亚洲精品片 | 亚洲精品www | 亚洲人成在线播放 | 精品国产一区二区三区成人影院 | 国产精品国产精品国产专区不片 | 日本中文字幕一区二区 | 欧美日韩国产一区二区三区 | 国产综合精品视频 | 99精品欧美一区二区蜜桃免费 | 国产成人激情 | 国产九九九 | 欧美日韩一二三 | 免费午夜电影 | 欧美亚洲专区 | 噜噜噜噜噜在线视频 | 91嫩草在线 | 91影院在线观看 | 亚洲一区二区三区四区五区中文 | 中文字幕高清视频 | 国产无套丰满白嫩对白 | 国产精品视频入口 | 国产精品久久久久久久午夜片 | 国产中文区二幕区2012 | 天天夜碰日日摸日日澡 | 国产乱码精品1区2区3区 | 久久电影一区 | 久久久一区二区 | 黄色大片在线 | 色无欲天天天影视综合网 | 久久亚洲国产精品 | 色婷婷综合久久久久中文一区二区 | 国产视频久久 | 欧美一二区 | 欧美日韩免费看 | 日日做夜夜爱 | 国产日韩在线播放 | 国内精品视频一区国产 | 成人一级片 | 国产老女人精品毛片久久 | 久久久久久一区 | 亚洲日本韩国在线观看 | 久久成人一区 | 北条麻妃一区二区在线 | 国产免费一区二区三区 | 99草免费视频 | 九九av| 久久久av | 99pao成人国产永久免费视频 | 国产精品欧美久久久久一区二区 | 欧美视频一级 | 69热在线观看 | 亚洲精品久久久久久久久久久 | 最新日韩av网址 | 一区二区精品在线 | 中文字幕电影在线 | 91精品国产乱码久久久久久久久 | www.视频在线观看 | 成人免费毛片嘿嘿连载视频 | 欧美日韩精品在线观看 | 九九热有精品 | 免费一级毛片 | 午夜久久久久 | 黄色官网在线观看 | 中文字幕最新在线 | 亚洲在线一区二区 | 亚洲激情 欧美 | 国产成人一区二区三区 | 美国黄色毛片女人性生活片 | 久久久久久亚洲精品 | 亚洲免费a| cao视频| 四虎欧美 | 欧美日韩在线免费观看 | 在线电影亚洲 | 一区二区亚洲 | 国产精品成人一区二区三区夜夜夜 | 午夜男人免费视频 | 色小妹一二三区 | 亚洲综合精品久久 | 久久99国产精品久久99果冻传媒 | 精品久久亚洲 | 日韩欧美一区二区在线观看 | 欧美精品久久久久久久久 | av福利网站 | 日韩性精品 | 日韩精品av一区二区三区 | 日韩精品免费在线观看 | 久久99精品视频在线观看 | 伊人狠狠干| 日日做夜夜爽毛片麻豆 | 欧美一区二区在线播放 | 色狠狠一区 | 精品福利av导航 | 亚洲天堂av网 | 色网在线| 91一区 | 久久精品免费 | 欧美在线一区二区三区 | 欧美日韩成人在线观看 | 日韩欧美国产电影 | 成人高清 | 亚洲夜幕久久日韩精品一区 | 狠狠色综合久久丁香婷婷 | 欧美日本韩国一区二区三区 | 欧美激情一区二区 | 日韩视频中文字幕在线观看 | 久久久久久久久久久久久av | 99国产精品久久久久老师 | 黑人巨大精品欧美一区二区小视频 | 色综合激情 | 欧美日韩一级二级三级 | 国产精品久久久久久吹潮 | 欧美aⅴ| 国产精品久久久久久 | 亚洲国产成人av | 黄视频在线播放 | 国产黄色大片 | 久久精品国产99国产 | 亚洲国产精品一区二区久久,亚洲午夜 | 欧美精品一区二区三区在线 | 成人深夜在线观看 | 亚洲欧美中文日韩在线v日本 | 欧美一区二区三区 | 久久久久国产 | 97色免费视频 | 国产精品久久久久久久久免费丝袜 | 午夜日韩 | 国产成人午夜高潮毛片 | 日韩性欧美 | 国产精品视频久久久 | 成人亚洲精品 | 欧美精品一 | 伊人99 | 日韩久久一区 | 成人久久久久久久久 | 日本成人黄色网址 | 看a网址| 国产综合视频 | 日日精品| 求av网站 | 中文字幕 国产 | 婷婷丁香综合 | 中文字幕一页二页 | 欧美日韩国产在线观看 | 欧美日韩精品一区二区 | 91在线资源 | 国产男女爽爽爽免费视频 | 日本在线一区二区三区 | 欧美中文字幕在线 | 亚洲一区二区在线视频 | 久久久久久亚洲国产 | 一区二区在线不卡 | 成人在线播放网站 | eeuss国产一区二区三区四区 | 91久久久久久久久 | 在线观看www| 亚洲男人的天堂在线播放 | 99爱视频 | 国内精品视频一区二区三区八戒 | 韩国一区二区视频 | 久久久久久久久中文字幕 | 午夜电影网址 | 激情久久久 | 毛片黄色| 黄色片在线免费观看 | 欧美精品一区二区三区四区 | 日韩aaa久久蜜桃av | 97超碰在线免费 | 亚洲一区二区三区观看 | 国产精品久久久久久久久久10秀 | 免费午夜电影 | 亚洲欧美日韩在线一区二区三区 | 人人草视频在线观看 | 激情欧美一区二区 | 欧美日韩在线免费观看 | 一级片在线观看 | 精品99久久久久久 | 久久久久久国产精品高清 | 久久久久久久久久久久久久久久久久久 | 午夜免费片 | 91国产精品 | 精品国产青草久久久久福利 | 亚洲国产欧美一区二区三区久久 | 草草成人 | 欧美www. | 亚洲wu码 | 中文字幕一区二区三区在线视频 | 日本网站在线免费观看 | 国产高清久久 | 狠狠亚洲 | 免费三片在线观看网站 | 国产成人精品一区二区三区视频 | av在线国产精品 | 日日干夜夜干 | 少妇黄色一级片 | 久久精品久久久 | 日本免费在线视频 | 欧美一级黄带 | 天天操天天摸天天干 | 中文字幕一二三区 | 国产精品久久久久毛片软件 | 欧美激情| 亚洲激情在线播放 | 日日操天天操 | 高清国产午夜精品久久久久久 | 久久久久久久一区 | 中文字幕精品三区 | 欧美一级在线观看视频 | 国产a免费| 91久久精品国产91久久性色tv | 狠狠91| 亚洲精品专区 | 91在线看片 | 国产女爽爽视频精品免费 | 欧美视频免费看 | 国产精品视频一二三区 | 亚洲综合精品 | 国产精品一区二区三区99 | 精品久久久久一区二区国产 | 国产精品久久久久久久久软件 | 精品一区二区久久久久久久网站 | 丝袜美腿一区二区三区 | 北条麻妃99精品青青久久主播 | 亚洲成人1区 | 91精品国产欧美一区二区成人 | 国产午夜手机精彩视频 | 日本一区二区三区中文字幕 | 先锋资源av在线 | 亚洲精品一二三区 | 国产激情视频 | 国产成人综合在线 | 亚洲国产成人av | 久久中文字幕一区 | 午夜天堂精品久久久久 | av网站在线免费观看 | 免费看片一区二区三区 | 视频国产一区 | 成人高清视频免费观看 | 国产三级电影 | 日本黄色影片在线观看 | 国产成人一区二区三区 | 国产精品99久久久久久久vr | 亚洲一区二区视频在线观看 | 久久久精品久久久 | 免费观看h视频 | 欧美一区日韩一区 | 色毛片 | 老熟女毛片 | 日韩欧美国产精品 | 黄色片免费看 | 韩日精品视频 | 欧美在线xxx | 精品一区二区三区在线视频 | 九一亚洲精品 | 国产片淫级awww | 国产亚洲女人久久久久毛片 | 久久久久久九九九九九九 | 午夜私人影院 | 欧美日韩成人在线视频 | 一区二区三区成人久久爱 | 九色在线视频 | 日本中文字幕一区 | 91视频在线看 | 日韩精品视频免费专区在线播放 | 婷婷成人免费视频 | 国产精品美女久久久久aⅴ国产馆 | 欧美男人天堂网 | 久久久天堂 | 亚洲综合网站 | 久久综合九色综合欧美狠狠 | 欧美一区不卡 | 亚洲人成中文字幕在线观看 | 国产精品免费一区二区三区四区 | 久久亚洲一区 | 日本黄色一级电影 | 日本一区二区三区四区 | 久久综合久久综合久久综合 | 欧美黄色一区 | 欧美性猛交一区二区三区精品 | 亚洲国产日本 | 亚洲成人网一区 | 中文字幕在线免费视频 | 99爱免费观看国语 | 成人高清视频在线观看 | 日日爱视频| 成人一级黄色大片 | 精品一区二区视频 | 91在线免费视频 | 国产黄色一级大片 | 欧美一区二区三区四区不卡 | 欧美中文在线 | 国产成人黄色 | 久久99精品国产99久久6男男 | 国产在线综合网 | 亚洲区在线 | 国产一区91 | 亚洲福利一区 | 国产亚洲精品久久久456 | 日韩1区3区4区第一页 | 日韩欧美视频一区 | 国产成人精品免高潮在线观看 | 91亚色| 日韩高清一区二区 | 国产高清一级片 | 国产一区二区三区久久久久久久久 | 五月婷婷在线观看视频 | 冷水浴在线观看 | 久久亚洲国产精品 | 久久久久久久久久久久久av | 久久久99精品免费观看 | 成人1区| 国产一级一级特黄女人精品毛片 | 91精品在线观看入口 | 欧美淫视频 | 一级毛片视频 | 日韩一级电影在线 | 亚洲精品一区二区三区麻豆 | 中国妞xxxhd露脸偷拍视频 | 国产一区二区免费电影 | 仙人掌旅馆在线观看 | 国产乱码精品一区二区三区手机版 | 蜜桃视频精品 | 亚洲免费资源 | 久久久久久a女人 | 久久9999久久 | 日日操天天操 | 中文字幕日韩在线 | www.午夜视频 | 日本黄色免费播放 | 91在线免费看 | 久草观看 | 97视频人人澡人人爽 | 国产精品第一区 | 久久综合九九 | 欧美综合成人网 | 亚洲电影中文字幕 | 色婷婷亚洲一区二区三区 | 免费激情网站 | 亚洲免费视频大全 | 五月婷婷导航 | 一道本一区二区三区 | 天堂久久久久 | 国产精品一区二区三区免费 | 国产精品成人国产乱一区 | a毛片在线免费观看 | 国产精品视频区 | 国产精品久久久久9999 | 91麻豆精品国产91久久久更新资源速度超快 | 美女视频一区 | 精品国产一区二区三区久久久蜜月 | 亚洲成人网在线 | 日韩福利在线观看 | 欧美三级免费观看 | 国产精品毛片一区二区三区 | 一级免费视频 | 开操网 | 精品成人网| 夜夜操天天干, | 久久九九视频 | 欧美日本韩国一区二区三区 | 日本综合久久 | 久久av网址| 狠狠干av| 999国产在线视频 | 成人毛片在线视频 | 日韩超碰 | 日韩毛片 | 亚洲日本欧美日韩高观看 | 中文字幕欧美日韩 | 午夜电影网址 | 成人一区二区三区 | 九九成人 | 天天草天天干天天 | 欧美一区二区三区在线观看视频 | 少妇淫片aaaaa毛片叫床爽 | 有码在线 | 欧美精品在线观看 | 最新国产在线 | 99精品久久久久久久免费 | 欧美日韩视频在线第一区 | 天堂资源av | 91短视频版在线观看www免费 | 天天操天天插 | 欧美成人免费视频 | 日狠狠| 国产精品高潮呻吟久久av野狼 | 毛片久久久| 色吊丝在线永久观看最新版本 | 成人免费毛片aaaaaa片 | 五月激情综合 | 午夜国产影院 | 亚洲精品18 | 天天操天天干天天 | av在线第一页 | 国产成人中文字幕 | 成人午夜免费网站 | 亚洲视频一区二区三区四区 | 亚洲风情在线观看 | 日本久久久久久 | 精品国产一区二区在线 | www.国产在线| 日韩在线视频观看 | 欧美精品在线观看 | 九九视频在线 | 久久无码精品一区二区三区 | 久久久免费精品 | 中文字幕国产在线视频 | 日韩电影三级 | 亚洲嫩草 | 亚洲免费在线 | 亚洲成人在线视频播放 | 久热中文字幕 | 性色爽爱 | 国产成人涩涩涩视频在线观看 | 中文字幕在线第一页 | 国产乱码精品一区二区三区忘忧草 | 九九视频这里只有精品 | 国产一级在线观看 | 欧美日韩高清不卡 | 一级黄色录像免费观看 | 一级黄色片aaa| 欧美日韩高清 | 亚洲一区精品在线 | 第一福利丝瓜av导航 | 久草网在线视频 | 天天干,夜夜操 | av男人的天堂在线 | 日本伊人网站 | 国产拍揄自揄精品视频麻豆 | 亚洲一区二区久久 | 日韩欧美网址 | 久久国产精品免费一区二区三区 | 欧美日韩国产一区二区 | 黄色一级视频 | 国产偷录视频叫床高潮对白 | 欧美日韩亚洲二区 | 成年人网站在线免费观看 | 国产精品18hdxxxⅹ在线 | 国产专区在线 | 91在线视频免费观看 | 欧美一级免费高清 | 伊人看片| 日韩在线一区二区三区 | 精品久久中文字幕 | 亚欧洲精品视频在线观看 | 国产区视频 | 亚洲在线免费观看 | 国产欧美综合一区二区三区 | 色香阁99久久精品久久久 | 日韩视频不卡 | 亚洲 欧美 精品 | 欧美精品一区二区三区在线四季 | 大胸av | 九九久久精品视频 | 成人一区二区三区在线 | 青青久久北条麻妃 | 欧美久久一区 | 欧美日韩一区二区电影 | 久久成人精品 | 伊人av在线免费观看 | 国产精品一二三 | 欧美 亚洲 另类 激情 另类 | www.日韩三级 | 欧美精品欧美精品系列 | 日韩色视频 | 春色av| 国产精品资源在线 | 九色 在线| 搡女人真爽免费午夜网站 | 国产高清免费视频 | 成人午夜视频在线观看 | 亚洲精品国产区 | 婷婷丁香六月天 | 中文字幕在线观看 | 精品国产一区二区三区不卡蜜臂 | 在线播放国产视频 | 久久精品久久久 | 久久久久久久久久一区二区 | 成人国产精品久久久 | 亚洲毛片在线 | 97精品| 亚洲精品第一区在线观看 | 香蕉久久久久久 | 在线播放91 | 91精品国产一区二区三区蜜臀 | 九九热精品视频 | 欧美一a一片一级一片 | 姐姐在线观看动漫第二集免费 | 国产视频成人 | 中文字幕久久精品 | 一区二区亚洲 | 亚洲欧美日韩国产综合 | 韩国精品一区二区三区 | 久久久久亚洲一区二区三区 | 国产不卡一区 | 精品国产成人 | 国产日韩欧美一区 | 日韩午夜视频在线观看 | 国产单男 | 日日日日干干干干 | 日韩国产在线 | 中文字幕在线网址 | 毛片黄色 | 天天精品 | 日韩婷婷 | 男女羞羞视频在线免费观看 | 国产一区二区三区视频在线观看 | 午夜国产精品视频 | 国产精品18久久久久久首页狼 | 在线观看成人小视频 | 日本一二三区视频 | 91精品国产综合久久久久久丝袜 | 二区在线观看 | 国产欧精精久久久久久久 | 日本精a在线观看 | 亚洲黄色国产 | 亚洲免费在线视频 | 亚洲欧美网址 | 色婷婷国产精品综合在线观看 | 成人深夜福利视频 | 天天躁日日躁aaaaxxxx | 亚洲国产精品一区二区久久 | 九九热在线视频 | 成人日韩| 91.成人天堂一区 | 欧美国产伦久久久久久 | h网站在线观看 | 亚洲精品视频在线免费 | 亚洲国产高清视频 | 看毛片网 | 爱爱视频网站 | 激情小视频在线观看 | 欧美激情精品久久久久久变态 | 在线观看国精产品二区1819 | 欧美黄视频在线观看 | 男女做爰高清无遮挡免费视频 | av大全在线 | 久草视频免费在线播放 | 欧美一区二区三区 | 神马香蕉久久 | 青青草视频网站 | 热久久免费视频 |