黄a在线观看-黄a在线-黄a大片-黄色片在线看-黄色毛片免费-黄色大片网站

您的位置:首頁技術文章
文章詳情頁

java算法之余弦相似度計算字符串相似率

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

功能需求:最近在做通過爬蟲技術去爬取各大相關網站的新聞,儲存到公司數據中。這里面就有一個技術點,就是如何保證你已爬取的新聞,再有相似的新聞

或者一樣的新聞,那就不存儲到數據庫中。(因為有網站會去引用其它網站新聞,或者把其它網站新聞拿過來稍微改下內容就發布到自己網站中)。

解析方案:最終就是采用余弦相似度算法,來計算兩個新聞正文的相似度。現在自己寫一篇博客總結下。

一、理論知識

先推薦一篇博客,對于余弦相似度算法的理論講的比較清晰,我們也是按照這個方式來計算相似度的。網址:相似度算法之余弦相似度。

1、說重點

我這邊先把計算兩個字符串的相似度理論知識再梳理一遍。

(1)首先是要明白通過向量來計算相識度公式。

java算法之余弦相似度計算字符串相似率

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

2、案例理論知識

舉一個例子來說明,用上述理論計算文本的相似性。為了簡單起見,先從句子著手。

句子A:這只皮靴號碼大了。那只號碼合適。

句子B:這只皮靴號碼不小,那只更合適。

怎樣計算上面兩句話的相似程度?

基本思路是:如果這兩句話的用詞越相似,它們的內容就應該越相似。因此,可以從詞頻入手,計算它們的相似程度。

第一步,分詞。

句子A:這只/皮靴/號碼/大了。那只/號碼/合適。

句子B:這只/皮靴/號碼/不/小,那只/更/合適。

第二步,計算詞頻。(也就是每個詞語出現的頻率)

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

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

第三步,寫出詞頻向量。

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

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

第四步:運用上面的公式:計算如下:

java算法之余弦相似度計算字符串相似率

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

二、實際開發案例

我把我們實際開發過程中字符串相似率計算代碼分享出來。

1、pom.xml

展示一些主要jar包

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

/** * 計算兩個字符串的相識度 */public class Similarity { public static final String content1='今天小小和爸爸一起去摘草莓,小小說今天的草莓特別的酸,而且特別的小,關鍵價格還貴'; public static final String content2='今天小小和媽媽一起去草原里采草莓,今天的草莓味道特別好,而且價格還挺實惠的'; 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); } }

先看運行結果:

java算法之余弦相似度計算字符串相似率

通過運行結果得出:

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

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

3、Tokenizer(分詞工具類)

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

這里面真正用到的其實就詞名和權重。

import lombok.Data;import java.util.Objects;/** * 封裝分詞結果*/@Datapublic class Word implements Comparable { // 詞名 private String name; // 詞性 private String pos; // 權重,用于詞向量分析 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(相似率具體實現工具類)

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;/** * 判定方式:余弦相似度,通過計算兩個向量的夾角余弦值來評估他們的相似度 余弦夾角原理: 向量a=(x1,y1),向量b=(x2,y2) similarity=a.b/|a|*|b| a.b=x1x2+y1y2 * |a|=根號[(x1)^2+(y1)^2],|b|=根號[(x2)^2+(y2)^2]*/public class CosineSimilarity { protected static final Logger LOGGER = LoggerFactory.getLogger(CosineSimilarity.class); /** * 1、計算兩個字符串的相似度 */ public static double getSimilarity(String text1, String text2) {//如果wei空,或者字符長度為0,則代表完全相同if (StringUtils.isBlank(text1) && StringUtils.isBlank(text2)) { return 1.0;}//如果一個為0或者空,一個不為,那說明完全不相似if (StringUtils.isBlank(text1) || StringUtils.isBlank(text2)) { return 0.0;}//這個代表如果兩個字符串相等那當然返回1了(這個我為了讓它也分詞計算一下,所以注釋掉了)//if (text1.equalsIgnoreCase(text2)) {// return 1.0;//}//第一步:進行分詞List<Word> words1 = Tokenizer.segment(text1);List<Word> words2 = Tokenizer.segment(text2);return getSimilarity(words1, words2); } /** * 2、對于計算出的相似度保留小數點后六位 */ public static double getSimilarity(List<Word> words1, List<Word> words2) {double score = getSimilarityImpl(words1, words2);//(int) (score * 1000000 + 0.5)其實代表保留小數點后六位 ,因為1034234.213強制轉換不就是1034234。對于強制轉換添加0.5就等于四舍五入score = (int) (score * 1000000 + 0.5) / (double) 1000000;return score; } /** * 文本相似度計算 判定方式:余弦相似度,通過計算兩個向量的夾角余弦值來評估他們的相似度 余弦夾角原理: 向量a=(x1,y1),向量b=(x2,y2) similarity=a.b/|a|*|b| a.b=x1x2+y1y2 * |a|=根號[(x1)^2+(y1)^2],|b|=根號[(x2)^2+(y2)^2] */ public static double getSimilarityImpl(List<Word> words1, List<Word> words2) {// 向每一個Word對象的屬性都注入weight(權重)屬性值taggingWeightByFrequency(words1, words2);//第二步:計算詞頻//通過上一步讓每個Word對象都有權重值,那么在封裝到map中(key是詞,value是該詞出現的次數(即權重))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|的平方// 第三步:寫出詞頻向量,后進行計算words.parallelStream().forEach(word -> { //看同一詞在a、b兩個集合出現的此次 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| 對aa開方double aaa = Math.sqrt(aa.doubleValue());//|b| 對bb開方double bbb = Math.sqrt(bb.doubleValue());//使用BigDecimal保證精確計算浮點數//double aabb = aaa * bbb;BigDecimal aabb = BigDecimal.valueOf(aaa).multiply(BigDecimal.valueOf(bbb));//similarity=a.b/|a|*|b|//divide參數說明:aabb被除數,9表示小數點后保留9位,最后一個表示用標準的四舍五入法double cos = BigDecimal.valueOf(ab.get()).divide(aabb, 9, BigDecimal.ROUND_HALF_UP).doubleValue();return cos; } /** * 向每一個Word對象的屬性都注入weight(權重)屬性值 */ protected static void taggingWeightByFrequency(List<Word> words1, List<Word> words2) {if (words1.get(0).getWeight() != null && words2.get(0).getWeight() != null) { return;}//詞頻統計(key是詞,value是該詞在這段句子中出現的次數)Map<String, AtomicInteger> frequency1 = getFrequency(words1);Map<String, AtomicInteger> frequency2 = getFrequency(words2);//如果是DEBUG模式輸出詞頻統計信息//if (LOGGER.isDebugEnabled()) {// LOGGER.debug('詞頻統計1:n{}', getWordsFrequencyString(frequency1));// LOGGER.debug('詞頻統計2:n{}', getWordsFrequencyString(frequency2));//}// 標注權重(該詞出現的次數)words1.parallelStream().forEach(word -> word.setWeight(frequency1.get(word.getName()).floatValue()));words2.parallelStream().forEach(word -> word.setWeight(frequency2.get(word.getName()).floatValue())); } /** * 統計詞頻 * @return 詞頻統計圖 */ 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; } /** * 輸出:詞頻統計信息 */ 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(); } /** * 構造權重快速搜索容器 */ 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; }}

這個具體實現代碼因為思維很緊密所以有些地方寫的比較繞,同時還手寫了AtomicFloat原子類。

6、AtomicFloat原子類

import java.util.concurrent.atomic.AtomicInteger;/** * jdk沒有AtomicFloat,寫一個 */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()); }}三、總結

把大致思路再捋一下:

(1)先分詞:分詞當然要按一定規則,不然隨便分那也沒有意義,那這里通過采用HanLP中文自然語言處理中標準分詞進行分詞。

(2)統計詞頻:就統計上面詞出現的次數。

(3)通過每一個詞出現的次數,變成一個向量,通過向量公式計算相似率。

以上就是java算法之余弦相似度計算字符串相似率的詳細內容,更多關于java算法的資料請關注好吧啦網其它相關文章!

標簽: Java
相關文章:
主站蜘蛛池模板: 伊人久久一区二区 | 天天爱天天做天天爽 | 精品人伦一区二区三电影 | 国产69精品久久久久久久 | 美女中文字幕 | 中文字幕av久久 | 引诱漂亮新婚少妇 | 国产超碰人人爽人人做人人添 | 精品va久久久噜噜久久软件 | 欧洲高潮视频在线看 | av自拍一区 | 自拍亚洲欧美 | 久久嗨 | 亚洲免费成人av | 日本高清视频www夜色资源 | 公侵犯一区二区三区四区中文字幕 | 色www亚洲国产阿娇yao | 国产欧美精品一区二区 | 亚洲一区不卡 | 欧美99| 光棍影院av | 一区二区三区四区免费 | 99热热99| 国产经典久久 | 大肉大捧一进一出好爽视色大师 | 日韩人妻无码一区二区三区综合部 | 一级作爱片 | 国产精品久久久影视青草 | 欧美精品第一页 | 尤物视频在线看 | 69成人网 | 香蕉一级片| 一级免费黄色片 | 青青操影院 | 亚洲一区二区三区影视 | 91精品国产二区在线看大桥未久 | 99ri视频| 国产女人呻吟高潮抽搐声 | 夜夜爽8888| 视频一区二区在线 | 成人免费视频网站在线观看 | 玩弄丰满少妇人妻视频 | 亚洲成人免费在线 | 久久亚洲国产成人影院 | 国产亲子乱xxxx | a天堂视频在线观看 | 日韩中文人妻无码不卡 | 破了亲妺妺的处免费视频国产 | 国产第一页浮力影院入口 | 后宫一级淫片免费放 | 欧洲午夜精品久久久久久 | 色欲色av免费观看 | 精品国产免费一区二区三区香蕉 | 日韩欧美成人一区二区三区 | 亚洲九九九 | 椎名由奈在线观看 | 国产国拍亚洲精品av在线 | 国产周晓琳在线另类视频 | 思思久久99热久久精品66 | 亚洲天堂av一区二区 | 久久精品视频一区二区三区 | 国产精品99久久久久 | 日韩视频一区在线观看 | 一级做a爱视频 | 国偷自产一区二区免费视频 | aaaa大片少妇高潮免费看 | 欧洲高潮三级做爰 | 色婷婷综合成人 | 一区二区三区四区产品乱 | 国产成人高清精品免费 | 中文字幕第23页在线 | 国产av一区二区三区无码野战 | 国产乱码精品一区二区三区爽爽爽 | 欧美性色网 | 亚洲熟妇无码久久精品 | 波多av在线 | 久久| 风流僵尸艳片a级 | 亚洲天堂三区 | 精品少妇theporn | 中文字幕无码不卡在线 | 中国美女毛片 | 久久精品免费网站 | 国产天堂第一区 | 久久久亚洲色 | 国产精品成色www | 成人天堂视频在线观看软件 | 国产精品av久久久久久小说 | 日韩网站视频 | 黄色动漫在线免费观看 | 欧美激情乱人伦 | 无限看片在线版免费视频大全 | 精品国产一区二区三区久久 | 看全色黄大色黄大片大学生图片 | 国产欧美精品一区二区三区-老狼 | 亚洲欧洲国产综合 | 好吊色综合 | 久久伊人色 | 黄色一级视频网站 | 小鲜肉自慰网站xnxx | 欧美做爰xxxⅹ性欧美大片 | 草草影院在线免费观看 | 亚洲女同另类 | 少妇交换浪荡h肉辣文视频 少妇交换做爰中文字幕 | 一区二区三区激情 | 成人国产欧美大片一区 | 国产亚洲精品久久久久久 | 亚洲第一激情 | 性chinese天美传媒麻 | 99久久精品国产同性同志 | 清朝荒淫性艳史 | 欧美 丝袜 自拍 制服 另类 | 久久精品无码中文字幕 | 亚洲女人av | 中文字幕无线精品亚洲乱码一区 | 亚洲精品久久久久久国 | 国产黄色在线免费观看 | 东京一本一道一二三区 | 91亚洲精品在线观看 | jizz亚洲女人高潮大叫 | 99久久亚洲精品日本无码 | 女儿的朋友4在线观看 | 亚洲天堂偷拍 | 性感少妇av | 大尺度激情吻胸视频 | 亚洲色欲久久久久综合网 | 韩国久久久久 | 国产肉体xxx裸体312大胆 | 99久久国产福利自产拍 | av观看网 | 久久九九热re6这里有精品 | 久久免费福利视频 | 无码av中文一区二区三区桃花岛 | 岛国av毛片 | 天堂男人网 | 久久er99热精品一区二区 | 丰满少妇高潮在线播放不卡 | 18禁无遮挡啪啪无码网站 | 强开乳罩摸双乳吃奶羞羞www | 久久美女免费视频 | 加勒比精品 | 亚洲天堂麻豆 | 久久久久久久久久久久久久免费看 | 日韩在线不卡视频 | 国产高清一区 | 亚洲熟女综合色一区二区三区 | 不卡视频一区二区 | 国产精品视频在线观看免费 | 青娱乐超碰 | 亚洲一区久久 | 午夜精品久久久久久久99老熟妇 | 97超碰站| 国产一级视频在线播放 | www黄色一片 | 99国产精品久久久久久 | 又色又湿又黄又爽又免费视频 | 香蕉伊人网 | 亚洲va久久久噜噜噜久久男同 | 午夜寂寞少妇aaa片毛片 | av永久免费在线观看 | 亚洲精品无码国产 | 92看片淫黄大片看国产片图片 | 女av在线| 日韩美女视频网站 | 日本高清不卡aⅴ免费网站 久久精品国产av一区二区三区 | 成人小视频在线观看 | 国产乱人伦无无码视频试看 | aaaaa少妇高潮大片 | 疯狂做受xxxx高潮欧美日本 | 亚洲国产成人无码av在线 | 色在线免费视频 | 日本少妇爱做按摩xxxⅹ | 欧美精品一卡二卡 | 爱丝aiss无内高清丝袜视频 | 国产日韩欧美日韩大片 | 91制服诱惑 | 精品国产不卡一区二区三区 | 国产免费不卡 | 亚欧无线一线二线三线区别 | 亚洲黄色av| 成人美女黄网站色大免费的88 | 欧美综合一区 | 日本三级午夜理伦三级三 | 少妇性饥渴无码a区免费 | 国产亚洲无线码一区二区 | 免费观看一级黄色片 | 日韩精品内射视频免费观看 | 国产中文字幕三区 | 成人毛片100部免费看 | av色区| www.精品在线 | 老妇裸体性激交老太视频 | 国产一级特黄,真人毛片 | 成人天堂网 | 日韩作爱| 国产女同疯狂作爱系列2 | 老色鬼在线精品视频在线观看 | 国产一区二区三区视频播放 | 18pao国产成人免费视频 | 国产jizz视频全部免费软件 | 中文精品欧美无线码一区 | 噜噜噜狠狠夜夜躁精品仙踪林 | 狠狠色狠狠色综合 | 精品伦一区二区三区免费视频 | 男女做爰猛烈叫床无遮挡 | 日本一区二区三区中文字幕 | 人妖一区 | 日b免费视频| 亚一区| 国产精品揄拍500视频 | 久久精品夜色噜噜亚洲a∨ 国产精品人人做人人爽 | 白洁乱淫76集 | 巨大荫蒂视频欧美大片 | 91久久夜色精品国产九色 | 熟妇高潮精品一区二区三区 | 亚洲性色av | 国产做受69 | 男人天堂免费视频 | 性生活一区 | 5个黑人躁我一个视频 | 五月天婷婷导航 | 在线免费观看av网 | 无码人妻丰满熟妇啪啪 | 草色噜噜噜av在线观看香蕉 | 人妻与老人中文字幕 | 拍拍拍无挡免费视频 | 特大黑人娇小亚洲女 | 九九九伊在人现综合 | 你懂的网址在线 | 欧美最猛性xxxⅹ丝袜 | 国产精品自产拍在线观看 | 四虎国产精品永久免费观看视频 | 成人黄色a| 99国产超薄肉色丝袜交足的后果 | 视频一区国产 | 国产精品无码专区在线播放 | 天堂乱码一二三区 | 99精品国产高清一区二区麻豆 | 亚洲欧洲无码一区二区三区 | 99精品在线 | 67194熟妇在线直接进入 | 日本黄色片视频 | 青青草无码精品伊人久久 | 国产欧美日韩精品专区黑人 | 欧美大胆a视频 | 99精品欧美一区二区三区小说 | 国产高清成人 | 婷婷在线播放 | av片免费看 | 精品无码国产一区二区三区av | 午夜精品福利一区二区 | 在线人人车操人人看视频 | 又黄又爽又色又刺激的视频 | jizzxxxx18高清喷水 | 国产一区二区三区小说 | 在线不卡日本v二区到六区 免费又黄又爽又猛的毛片 特级西西人体444www高清大胆 | 天天做天天爱夜夜爽导航 | 福利二区视频 | 九一亚洲精品 | 人人澡人人草 | 日本久久一区二区 | 日日摸日日碰夜夜爽久久四季 | √最新版天堂资源在线 | 日韩亚洲精品视频 | 四季av中文字幕 | 在线一区二区三区做爰视频网站 | 高潮一区| 日韩欧美一级片 | 亚洲欧洲美洲精品一区二区三区 | www.亚洲天堂.com | 日韩免费在线观看视频 | 一本一道久久a久久精品蜜桃 | 性夜影院午夜看片 | 美女又爽又黄视频毛茸茸 | 日本国产在线播放 | 国产精品v欧美精品v日韩精品v | 国产在线视频一区二区董小宛性色 | 丰满人妻中伦妇伦精品app | 婷婷中文字幕 | 成年网站在线免费观看 | 欧美亚洲国产精品久久蜜芽直播 | 麻豆一区二区三区四区 | 日韩国产精品久久久久久亚洲 | h片网站在线观看 | 97免费人妻在线视频 | 在线亚洲高清揄拍自拍一品区 | 久久久久久a亚洲欧洲av | 久久久久久无码午夜精品直播 | 女人喷液抽搐高潮视频 | 毛片大片 | 美国伦理3野性 | 国产女同疯狂互摸系列3 | 人妻少妇精品中文字幕av蜜桃 | 麻豆秘密入口a毛片 | 欧美比基尼 | 一本色道久久综合亚洲精品高清 | 老妇肥熟凸凹丰满刺激 | jzjzz成人免费视频 | 色欧美在线 | 久久人人爽av亚洲精品天堂 | 91成人网在线播放 | 久久狠狠高潮亚洲精品 | 欧美日韩午夜 | 午夜视频在线观看一区二区 | 精品久久久久久久久午夜福利 | 黄色免费片 | 寡妇毛片一区二区三区 | 日本午夜免费 | 国产 日韩 欧美 一区 | 欧美肥妇bwbwbwbxx | 7777kkk亚洲综合欧美网站 | 成人小视频在线看 | 亚洲激情专区 | 色久av| 久久大香焦 | 人人妻在人人 | 97色伦97色伦国产欧美空 | 亚洲va在线观看 | 999国产精品视频 | 国产精品美女久久久久av超清 | 中文字幕天堂网 | 亚洲精品系列 | 粗暴video蹂躏hd | 婷婷亚洲一区 | 免费黄色三级网站 | 成人羞羞国产免费网站 | 久热这里只有 | 欧美精品福利视频 | 久久久www成人免费无遮挡大片 | 18禁高潮出水呻吟娇喘蜜芽 | 日韩免费在线视频观看 | 最新日本黄色网址 | 147人体做爰大胆图片成人 | 丁香花开心四播房麻豆 | 国产高清自拍av | 在线亚洲+欧美+日本专区 | 97这里只有精品 | 麻豆最新 | 国产肉体xxxx裸体视频 | 欧美色图17p | 国产又粗又猛又爽又黄的免费视频 | 免费观看一区二区三区 | 成人一二三四区 | 久久国产avjust麻豆 | 国产精品视频啪啪 | 欧美91精品久久久久国产性生爱 | 青青草成人免费视频 | 99精品视频99 | 伊人网综合在线 | 亚洲精品二 | 天堂在线免费观看视频 | 蜜桃视频插满18在线观看 | 精品国精品国产自在久国产应用 | 精品蜜桃一区二区三区 | 天天拍夜夜添久久精品 | 亚洲 欧美 综合 | 久久久久无码精品国产h动漫 | 97夜夜澡人人爽人人喊中国片 | 精品无码人妻一区二区三区不卡 | 欧美中文视频 | 羞羞视频在线观看免费 | 少妇哺乳期在线喷奶 | 国产在线日本 | 国产亚av手机在线观看 | 五月天中文字幕在线 | 91精品国自产拍天天拍 | 久久久无码一区二区三区 | 国模私拍av | 亚洲国产精品成人久久 | 国内精品久久久久久99蜜桃 | 国产精品午夜一区 | 四川少妇xxxx内谢欧美 | 丰满人妻妇伦又伦精品国产 | 青青草视频免费看 | 亚洲色大成网站www久久九九 | 免费中文熟妇在线影片 | 国产你懂得 | 日韩九九九 | 免费在线成人 | 奇米影视7777| 亚洲欧美乱综合图片区小说区 | 波多野结衣二区 | 一级生性活片免费视频片 | 波多野结衣一区二区三区在线观看 | 乱子伦一区二区三区 | 区美成人aaaaa | www色涩涩com网站 | 久久久久久久少妇 | 国产91区| 国产成人免费av | 女同互慰高潮呻吟免费播放 | 欧美性淫爽ww久久久久无 | 国产精品综合av一区二区国产馆 | 九色福利视频 | 艳妇臀荡乳欲伦69调教视频 | 在线观看国产午夜福利片 | 久久777国产线看观看精品 | 伊人影院久久 | 亚洲欧洲日产国码久在线 | 无码人妻毛片丰满熟妇区毛片 | 国产熟妇高潮叫床视频播放 | 亚洲色图一区二区 | 免费性色视频 | 国产又黄又硬又粗 | 国产午夜大片 | 免费播放毛片 | 亚洲精品乱码久久久久久国产主播 | 亚洲成aⅴ人片久青草影院 亚洲无av码一区二区三区 | 2019午夜福利不卡片在线 | 国产在线激情 | 日本久久久网站 | 日韩图片一区 | 成人动漫在线观看免费 | 成人涩涩日本国产一区 | 日本一区二区在线播放 | 国产馆在线观看 | 欧美老妇交乱视频在线观看 | 成人国内精品久久久久一区 | 国产精品 欧美 日韩 | 冲田杏梨 在线 | 爱情岛论坛亚洲品质自拍视频 | 日韩免费一区二区 | 黄色爱爱视频 | 欧美久久久久久久 | 六月婷婷久久 | 久久午夜羞羞影院免费观看 | 国产精品久久久久久久毛片明星 | 国产成人在线精品 | 亚洲在线国产日韩欧美 | 日韩精品视频在线观看一区二区 | 色婷婷婷婷 | 欧美性猛交xxxx乱大交 | 中国xxx农村性视频 欧美寡妇xxxx黑人猛交 | 欧美无人区码suv | 永久免费未满男 | 国产精品美女久久久久久久久久久 | 国产精品一卡二卡三卡四卡 | 五十路亲子中出在线观看 | 乱女伦露脸对白在线播放 | 欧美午夜精品久久久久久蜜 | h片观看 | 三级毛片在线播放 | 婷婷色视频 | 国产口爆吞精在线视频2020版 | 国产丝袜在线视频 | 台湾佬自拍偷区亚洲综合 | 国产成人三级在线播放 | h成人在线 | 777色狠狠一区二区三区 | 一区二区三区高清在线观看 | 亚洲欧美日本另类 | 三级av在线 | 老头老太吃奶xb视频 | 日本国产亚洲 | 中国一级大黄大黄大色毛片 | 午夜视频免费在线观看 | 国产精品中文久久久久久久 | 26uuu成人网 2级黄色片 | 狠狠操一区二区 | 波多野结衣一区二区三区免费视频 | 国产国模在线观看免费 | 特级a毛片 | 日韩欧美字幕 | 日本久久丰满的少妇三区 | 久久精品人人做人人爱爱站长工具 | 国产又白又嫩又紧又爽18p | 蜜桃视频一区 | 少妇搡bbbb爽毛片无 | 久久久国产精品视频 | 九色91蝌蚪 | 91精品国产综合久久香蕉最新版 | 中文字幕在线网站 | 国产一区二区在线免费 | 逼逼爱插插网站 | 97超碰超碰久久福利超碰 | 在线精品一区二区三区 | 麻豆久久久久久 | 27美女少妇洗澡偷拍 | 二级黄色片 | 精品超清无码视频在线观看 | 国产va免费精品高清在线观看 | 青青青青青手机视频在线观看视频 | 精品一卡二卡三卡四卡 | 伊人亚洲天堂 | 秋霞成人午夜鲁丝一区二区三区 | 蜜臀久久99精品久久久无需会员 | 日韩av手机在线播放 | 久久韩国 | 国产高清在线观看 | 免费又黄又爽又猛的毛片 | 国产美女在线播放 | 爱丝aiss无内高清丝袜视频 | 亚洲天堂黄 | 成人黄色在线 | 大岛优香中文av在线字幕 | 青青青国产精品一区二区 | 999精彩视频 | 一级淫片免费 | av黄色在线免费观看 | 夜夜操网| 蜜桃成熟时李丽珍在线观看 | 黄色三级av| 色香蕉网站| 国产超碰在线 | 色爽爽爽爽爽爽爽爽 | 动漫女女吸乳舌吻羞羞 | 亚洲欧洲自拍偷拍 | 婷婷久久综合网 | 国产精品久久久久久久久潘金莲 | 国产精品偷乱一区二区三区 | k频道国产在线观看 | 丁香激情六月 | 国产福利视频一区二区 | 一级做性色a爱片久久毛片欧 | 免费看黄色一级大片 | 男女又爽又黄激情免费视频大 | 国产公共场合大胆露出 | 亚洲人成色7777在线观看不卡 | 日日摸夜夜添夜夜添毛片av | 亚洲区视频 | 中文字幕日韩精品无码内射 | 肉欲性毛片交19 | 国产又色又爽又黄的免费软件 | 天天视频色 | 97av麻豆蜜桃一区二区 | 亚洲精品毛片av | 97超碰人 | aaaa视频| 中文字幕免费在线看线人动作大片 | 成色网| 日本一区二区网站 | 欧美a级理论片 | 天天艹天天 | 国产精品白嫩极品美女 | 久久国产经典 | 性av网| 国产一区精品在线观看 | 波多野结衣一区二区三区四区 | 暖暖视频日本在线观看 | 精品国产百合女同互慰 | 亚洲a成人片在线观看 | 麻豆精品久久 | 免费污网站在线观看 | 粉嫩av免费一区二区三区 | 手机av网址| 午夜视频黄色 | 免费人成视频在线观看网站 | 青青操免费在线视频 | 丁香六月婷婷 | 国产在线播 | 深夜视频免费在线观看 | 婷婷激情丁香 | 黄色在线视频网址 | 亚洲2022国产成人精品无码区 | 99久久国产露脸国语对白 | 99色综合| 日韩精品免费在线视频 | 欲妇荡岳丰满少妇岳 | 性生活在线视频 | 国产精品亚洲а∨天堂2021 | 在线免费看av网站 | 色欲狠狠躁天天躁无码中文字幕 | 老汉老妇姓交视频 | 亚洲深夜在线 | 国产99在线 | 亚洲 | 无码专区天天躁天天躁在线 | 中文字幕www | 92久久精品一区二区 | 亚洲国产三级在线观看 | 51精品国产人成在线观看 | 日日干天天操 | 中文字幕在线色 | 国产在线精品一区二区三区不卡 | 国产欧美日韩综合精品二区 | 日日日人人人 | 无套内谢的新婚少妇国语播放 | av无码电影一区二区三区 | 波兰性xxxxx极品hd | 日本免费视频 | 91久久久久久久一区二区 | 国产成人精品久久综合 | 亚洲国产又黄又爽女人高潮的 | 免费无码又爽又刺激高潮视频 | 日本黄视频网站 | 久久视频免费观看 | 亚洲精品888 | 亚洲老女人 | blacked精品一区国产在线观看 | 久草在线这里只有精品 | 日韩av成人在线 | 亚洲一区二区三区四区不卡 | 国产亚洲精品久久久ai换 | 日韩av一区二区三区在线 | 天海翼一区二区三区免费 | 午夜视频福利在线 | 一级黄色片网址 | 国产3p在线播放 | 免费看欧美一级特黄a大片 免费看欧美中韩毛片影院 免费看片91 | 国产黄色片av | 在线视频你懂得 | 欧美性猛交xxx乱大交3蜜桃 | 玖玖国产 | 你懂的欧美| 国产精品正在播放 | av天堂午夜精品一区 | 亚洲自拍激情 | 天天做天天爱天天爽综合网 | 午夜视频在线观看吗 | 在厨房拨开内裤进入在线视频 | 午夜亚洲福利在线老司机 | 都市激情av | 色老头在线视频 | aa视频免费观看 | 国产欧美一区二区精品秋霞影院 | 思思久久99热久久精品66 |