201521123011 《Java程序设计》第8周学习总结
1. 本周學(xué)習(xí)總結(jié)
1.1 以你喜歡的方式(思維導(dǎo)圖或其他)歸納總結(jié)集合與泛型相關(guān)內(nèi)容。
2. 書(shū)面作業(yè)
本次作業(yè)題集集合
1.List中指定元素的刪除(題目4-1)
1.1 實(shí)驗(yàn)總結(jié)
答:實(shí)驗(yàn)中運(yùn)用到了equals方法和remove方法。當(dāng)使用了scanner方法時(shí),要使用sc.close()將其關(guān)閉。
2.統(tǒng)計(jì)文字中的單詞數(shù)量并按出現(xiàn)次數(shù)排序(題目5-3)
2.1 偽代碼(簡(jiǎn)單寫(xiě)出大體步驟)
2.2 實(shí)驗(yàn)總結(jié)
答:2.1
Map<String, Integer>map = new HashMap<String.Integer>();//用hashmap進(jìn)行鍵值對(duì)的放入 獲取輸入的英文單詞 while(sc,hasNext()) { if(get(str)==null)//如果為空 put(key,value);//就放入一對(duì)鍵值對(duì) else put(key,value+1); } 創(chuàng)造一個(gè)ArrayList<Map.Entry<String, Integer>> arrayList 和一個(gè)collection接口的比較方法,來(lái)比較Map.Entry<String, Integer for (Map.Entry<String, Integer> entry :arrayList) {if(i==10){break;}System.out.println(entry.getKey()+"="+entry.getValue());i++; }2.2
用hashmap的方法,hashmap用于儲(chǔ)存鍵值對(duì),用get()put()方法來(lái)獲取和放入鍵值對(duì)。用列表來(lái)實(shí)現(xiàn)排序。collection接口那里有點(diǎn)不會(huì)。
3.倒排索引(題目5-4)
3.1 截圖你的提交結(jié)果(出現(xiàn)學(xué)號(hào))
3.2 偽代碼(簡(jiǎn)單寫(xiě)出大體步驟)
3.3 實(shí)驗(yàn)總結(jié)
答:
3.1
3.2
Map<String, Set<Integer>>index = new TreeMap<String, Set<Integer>>(); ArrayList<String> wordlines=new ArrayList <String>(); 輸入的時(shí)候 if(!key.word) {put(key,value) } else//有key.word {get(key.word) } //關(guān)鍵句同理 輸出的時(shí)候 if(findword.length==1} {if(find key.word)System.out.println();else found 0 results; } else {if(find key.line)System.out.println();else found 0 results; }3.3
輸入輸出的時(shí)候要考慮很多種可能,尤其是輸出的時(shí)候,找不到時(shí)返回null。
4.Stream與Lambda
編寫(xiě)一個(gè)Student類(lèi),屬性為:
創(chuàng)建一集合對(duì)象,如List,內(nèi)有若干Student對(duì)象用于后面的測(cè)試。
4.1 使用傳統(tǒng)方法編寫(xiě)一個(gè)方法,將id>10,name為zhang, age>20, gender為女,參加過(guò)ACM比賽的學(xué)生篩選出來(lái),放入新的集合。在main中調(diào)用,然后輸出結(jié)果。
4.2 使用java8中的stream(), filter(), collect()編寫(xiě)功能同4.1的函數(shù),并測(cè)試。
4.3 構(gòu)建測(cè)試集合的時(shí)候,除了正常的Student對(duì)象,再往集合中添加一些null,然后重新改寫(xiě)4.2,使其不出現(xiàn)異常。
答:
4.1
4.2
ArrayList<a> arrayList2 = (ArrayList<a>) arrayList.parallelStream().filter(a->10<a.getId()&&a->"zhang".equals(a.getName())&&a->20<a.getAge()&&a->a.isJoinsACM()==true).collect(Collectors.toList());4.3
ArrayList<a> arrayList2 = (ArrayList<a>) arrayList.parallelStream().filter(a->a!=null&&a->10<a.getId()&&a->"zhang".equals(a.getName())&&a->20<a.getAge()&&a->a.isJoinsACM()==true).collect(Collectors.toList());5.泛型類(lèi):GeneralStack(題目5-5)
5.1 截圖你的提交結(jié)果(出現(xiàn)學(xué)號(hào))
5.2 GeneralStack接口的代碼
5.3 結(jié)合本題,說(shuō)明泛型有什么好處
答:
5.1
5.2
interface GeneralStack<T> {T push(T item); T pop(); T peek(); //獲取棧頂元素 public boolean empty();public int size(); }5.3
使用泛型就可以不用定義多個(gè)類(lèi),GeneralStack接口對(duì)任何引用類(lèi)型的數(shù)據(jù)都適用,泛型消除強(qiáng)制類(lèi)型轉(zhuǎn)換,錯(cuò)誤在編譯階段就能發(fā)現(xiàn)不用等到運(yùn)行的時(shí)候,這樣可以簡(jiǎn)化代碼同時(shí)減少了出錯(cuò)機(jī)會(huì)。
6.泛型方法
基礎(chǔ)參考文件GenericMain,在此文件上進(jìn)行修改。
6.1 編寫(xiě)方法max,該方法可以返回List中所有元素的最大值。List中的元素必須實(shí)現(xiàn)Comparable接口。編寫(xiě)的max方法需使得String max = max(strList)可以運(yùn)行成功,其中strList為L(zhǎng)ist。
3. 碼云上代碼提交記錄及PTA實(shí)驗(yàn)總結(jié)
題目集:jmu-Java-05-集合
3.1. 碼云代碼提交記錄
在碼云的項(xiàng)目中,依次選擇“統(tǒng)計(jì)-Commits歷史-設(shè)置時(shí)間段”, 然后搜索并截圖
轉(zhuǎn)載于:https://www.cnblogs.com/jiaowoxiaotiancai/p/6711112.html
總結(jié)
以上是生活随笔為你收集整理的201521123011 《Java程序设计》第8周学习总结的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 数据结构栈的构造
- 下一篇: Gradle在大型Java项目上的应用