map集合修改其中元素 去除Map集合中所有具有相同值的元素 Properties長久保存的流操作 兩種用map記錄單詞或字母個數的方法

来源:https://www.cnblogs.com/qingyundian/archive/2018/03/02/8495079.html
-Advertisement-
Play Games

去除相同值的元素 Properties的流操作,長久保存 兩種用map記錄單詞或字母個數的方法 ...


package com.swift.lianxi;

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;

/*1.請簡述Map 的特點
2.請簡述HashMap的特點
3.請簡述LinkedHashMap的特點
4.使用代碼依次完成:
    a).將如下鍵值對信息存入Map集合中:
        "黃曉明", "Baby"
        "鄧超", "孫儷"
        "李晨", "範冰冰"
        "大黑牛", "範冰冰"
    b).將"李晨"對應的值替換成"白百合"
    c).獲取"大黑牛"對應的值,如果是"範冰冰"就刪除以"大黑牛"為鍵的元素

5.使用代碼完成:往一個Map集合中添加若幹元素.獲取Map中的所有key, 並使用增強for和迭代器遍歷輸出每個key
6.使用代碼完成:往一個Map集合中添加若幹元素.獲取Map集合中所有的鍵值對(Entry)對象, 並使用增強for和迭代器遍歷輸出每個key和value
7.使用代碼完成:將學員的信息作為元素存入HashMap中,
    提示:1.每位學生(姓名,年齡)都有自己的家庭住址
        2.將學生對象和家庭住址存儲到map集合中。學生作為鍵, 家庭住址作為值。
         3.學生姓名相同並且年齡相同視為同一名學生*/

public class Demo1 {

    public static void main(String[] args) {
        
        HashMap<String, String> map = new HashMap<String,String>();
        map.put("黃曉明", "Baby");
        map.put("鄧超", "孫儷");
        String str1=map.put("李晨", "範冰冰");
        map.put("大黑牛", "範冰冰");
        System.out.println(map);
        //如果鍵值相同,直接put就是替換
        String str2=map.put("李晨", "白百合");
        System.out.println(map);
        System.out.println(str1+"..."+str2);
        String str3=map.get("大黑牛");
        if("範冰冰".equals(str3)) {
            map.remove("大黑牛");
        }
        System.out.println(map);
        
        System.out.println("===========================================");
        //keySet使用增強for遍歷
        Set<String> keys = map.keySet();
        for(String key:keys) {
            System.out.println(key+"..."+map.get(key));
        }
        //keySet使用iterator遍歷
        System.out.println("===========================================");
        Set<String> set =map.keySet();
        Iterator<String> it=set.iterator();
        while(it.hasNext()) {
            String name = it.next();
            System.out.println(name+"..."+map.get(name));
        }
        //entrySet使用增強for遍歷
        System.out.println("===========================================");
        Set<Map.Entry<String,String>> entry = map.entrySet();
        for(Map.Entry<String, String> key:entry) {
            System.out.println(key.getKey()+"..."+key.getValue());
        }
        //entrySet使用iterator遍歷
        System.out.println("===========================================");
        Set<Map.Entry<String,String>> set1 =map.entrySet();
        Iterator<Map.Entry<String,String>> it1=set1.iterator();
        while(it1.hasNext()) {
            Map.Entry<String,String> entry1= it1.next();
            System.out.println(entry1.getKey()+"..."+entry1.getValue());
        }
        
        HashMap<Student, String> students = new HashMap<Student,String>();
        students.put(new Student("zhangsan",20), "北京");
        students.put(new Student("lisi",21), "上海");
        students.put(new Student("wangwu",22), "廣州");
        students.put(new Student("zhaoliu",23), "深圳");
        students.put(new Student("zhaoliu",23), "香港");
        for(Student stu:students.keySet()) {
            System.out.println(stu.toString()+"..."+students.get(stu));
        }
    }

}

class Student{
    
    private String name;
    private int age;
    private String address;
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
    public String getAddress() {
        return address;
    }
    public void setAddress(String address) {
        this.address = address;
    }
    public Student(String name, int age, String address) {
        super();
        this.name = name;
        this.age = age;
        this.address = address;
    }
    public Student(String name, int age) {
        super();
        this.name = name;
        this.age = age;
    }
    public Student() {
        super();
        // TODO Auto-generated constructor stub
    }
    @Override
    public int hashCode() {
        final int prime = 31;
        int result = 1;
        result = prime * result + ((address == null) ? 0 : address.hashCode());
        result = prime * result + age;
        result = prime * result + ((name == null) ? 0 : name.hashCode());
        return result;
    }
    @Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;
        if (getClass() != obj.getClass())
            return false;
        Student other = (Student) obj;
        if (address == null) {
            if (other.address != null)
                return false;
        } else if (!address.equals(other.address))
            return false;
        if (age != other.age)
            return false;
        if (name == null) {
            if (other.name != null)
                return false;
        } else if (!name.equals(other.name))
            return false;
        return true;
    }
    @Override
    public String toString() {
        return "Student [name=" + name + ", age=" + age + ", address=" + address + "]";
    }
    
}

 去除相同值的元素

package com.swift.tuozhan;

import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Set;

/*Map中有{張三=3,李四=4,王五=5,趙六=6,孫七=7,田七=7,周八=5}這些元素.
將Map中value相同的元素從Map中去除(value為7和5是相同的,都要刪除).
再將Map中剩餘元素的key存放到一個ArrayLis中,並列印到控制臺上*/

public class Tuozhan1 {

    public static void main(String[] args) {
        
        Map<String,Integer> map=new HashMap<String,Integer>();
        List<Integer> chongfulie = new ArrayList<Integer>();
        map.put("張三",3);
        map.put("李四",4);
        map.put("王五",5);
        map.put("趙六",6);
        map.put("孫七",7);
        map.put("田七",7);
        map.put("周八",5);
        for(String str:map.keySet()) {
            int n=map.get(str);
            chongfulie.add(n);
        }
        System.out.println(chongfulie);
        //也可以下麵這樣做,得到重覆值
        Collection<Integer> x = map.values();
        ArrayList<Integer> a=new ArrayList<Integer>(x);
        System.out.println(a);
        //得到重覆值
        List<Integer> chongfuzhi= new ArrayList<Integer>();
        for(int i=0;i<chongfulie.size();i++) {
            int zhi=chongfulie.get(i);
            for(int j=i+1;j<chongfulie.size();j++) {
                if(zhi==chongfulie.get(j)) {
                    chongfuzhi.add(zhi);
                }
            }
        }
        System.out.println(chongfuzhi);
        //得到重覆鍵
        List<String> chongfujian= new ArrayList<String>();
        for(String str:map.keySet()) {
            Integer n1 = map.get(str);
            if(chongfuzhi.contains(n1)) {
                chongfujian.add(str);
            }
        }
        //遍歷重覆鍵,將他們都刪掉
        for(String str:chongfujian) {
            map.remove(str);
        }
        System.out.println(map);
        //剩餘的key 列印
        Set<String> key=map.keySet();
        ArrayList<String> arr=new ArrayList<>();
        arr.addAll(key);
        System.out.println(arr);
        
    }

}

 去除相同值,又敲了一遍,看看有什麼不同

package com.swift.tuozhan;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;

/*Map中有{張三=3,李四=4,王五=5,趙六=6,孫七=7,田七=7,周八=5}這些元素.
將Map中value相同的元素從Map中去除(value為7和5是相同的,都要刪除).
再將Map中剩餘元素的key存放到一個ArrayLis中,並列印到控制臺上*/

public class Tuozhan1 {

    public static void main(String[] args) {

        Map<String, Integer> map = new HashMap<>();
        map.put("張三", 3);
        map.put("李四", 4);
        map.put("王五", 5);
        map.put("趙六", 6);
        map.put("孫七", 7);
        map.put("田七", 7);
        map.put("周八", 5);
        //得到相同的值
        Set<Integer> set=sameValue(map);
        //想成迴圈中迴圈時,想一下contains
        List<String> list=new ArrayList<>();
        for(String str:map.keySet()) {
            if(set.contains(map.get(str))){
                list.add(str);
            }
        }
        System.out.println(list);
        //list中是要幹掉的鍵值key
        for(String str:list) {
            map.remove(str);
        }
        System.out.println(map);
    }

    private static Set<Integer> sameValue(Map<String, Integer> map) {

        List<Integer> list = new ArrayList<>();
        for (String str : map.keySet()) {
            int n = map.get(str);
            list.add(n);
        }
        System.out.println(list);
        Set<Integer> set = new HashSet<>();
        for (int i = 0; i < list.size(); i++)
            for (int j = i + 1; j < list.size(); j++) {
                if (list.get(i) == list.get(j)) {
                    set.add(list.get(i));
                }
            }
        System.out.println(set);
        return set;
    }

}

 

 

Properties的流操作,長久保存

package com.swift.lianxi;

import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.util.Properties;
import java.util.Set;

/*1.請簡述下Properties的特點 不能放null 線程安全,速度慢
2.使用代碼完成:使用Properties集合,完成把集合內容存儲到IO流所對應文件中的操作
3.使用代碼完成:從屬性集文件prop.properties中取出數據,保存到集合中
4.簡述可變參數的作用
5.使用代碼完成:
    a).ArrayList集合中依次添加元素:1,2,3,4,5;
    b).使用Collections工具類將元素順序打亂後列印所有元素
    c).使用Collections工具類將元素順序排序後列印所有元素*/

public class Demo2 {

    public static void main(String[] args) throws FileNotFoundException, IOException {
        
        //將數據添加到Properties集合
        Properties pro = new Properties();
        pro.setProperty("zhangsan", "beijing");
        pro.setProperty("lisi", "shanghai");
        pro.setProperty("wangwu", "tianjin");
        pro.setProperty("zhaoliu", "shenzhen");
        //Properties集合內容存儲到文件
        pro.store(new FileWriter("mingzhi.txt"),"a");
        
        pro.load(new FileReader("prop.properties"));
        Set<String> names = pro.stringPropertyNames();
        for(String str:names) {
            System.out.println(str+"..."+pro.getProperty(str));
        }
        
    }

}

 兩種用map記錄單詞或字母個數的方法

package com.swift.kaoshi;

import java.util.HashMap;

//If you want to change your fate I think you must come to the dark horse to learn java 統計單詞個數

public class Count {

    public static void main(String[] args) {

        String str = "If you want to change your  fate I think you must come to the dark horse to learn java ";
        str.trim();
        String[] words = str.split("\\s+");
        //兩遍法,第一遍放到map中去重,第二遍放到map中計數
        for (String word : words) {

            System.out.println(word);
        }
        HashMap<String, Integer> map = new HashMap<String, Integer>();
//        for (String word : words) {
//
//            map.put(word, 0);
//        }
//        System.out.println(map);
//        for (String s : words) {
//            int num = map.get(s) + 1;
//            map.put(s, num);
//        }
//        System.out.println(map);
        //另一種方法 遍歷一遍,如果值為空則放1,如果值不為空則取出加一
        for(String word:words) {
            if(map.get(word)==null) {
                map.put(word, 1);
            }else {
                map.put(word,map.get(word)+1);
            }
        }
        System.out.println(map);
    }

}

 另一種方法可以使用map的containsKey方法,先判斷map集合中是否有這個單詞或字母,如果沒有,則把他的值放入1,如果有則把他的值取出並加1

變為如下代碼:

if(!map.containsKey(word)){

  map.put(word,1);

}else{

  map.put(word,map.get(word)+1);

}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 因為JS可以多層嵌套代碼可能下麵還可以再嵌一個方法引用this就會變成子方法控制的對象如果需要上級的對象在沒有參數的情況下前面前提做了一個臨時變數_this可以保存上級對象子方法中就可以用_this來調用了,這才是目的。摘自百度問答:https://zhidao.baidu.com/question ...
  • 什麼是DOM? DOM(Document Object Model)文檔對象模型,是 語言和平臺的中立介面。。 允許程式和腳本動態地訪問和更新文檔的內容 。 為什麼要使用DOM? Dom技術使得 用戶頁面可以動態地變化,如可以動態地顯示或隱藏一個元素,改變它們的屬性,增加一個元素等 ,Dom技術使得 ...
  • 一、JS中for迴圈遍歷測試 for迴圈遍歷有兩種 第一種:是有條件的那種,例如 for(var i = 0;i<ele.length;i++){} 第二種:for (var i in li ){} 現在我們來說一下測試一下第二種(數組和obj的) 1 <!DOCTYPE html> 2 <html ...
  • 原文鏈接 :http://blog.csdn.net/qq_38646470/article/details/79427038 `[1.什麼是點陣圖? 2.點陣圖的用處? 3.點陣圖的結構 4.點陣圖題目操練 5.總結(優缺點分析)]` 1.什麼是點陣圖? 點陣圖就是bitmap的縮寫。所謂bitmap,就是用 ...
  • Java作為一種通用的編程語言可以做很多事情,但怎麼學Java就看怎麼用了,很多初學者想通過埋頭苦學、馬不停蹄的敲著代碼記住Java基本原理,但一遇到困難便會讓自己發狂,種種坎坷將自己打回原形。 為了排除大家的困惑,小編精心準備Java學習路線圖,建議你耐心的讀完此篇,保你在學Java的道路上能事半 ...
  • 程式目標:輸入一個字元串,豎向輸出該字元串。使用string和動態分配記憶體機制。代碼如下: #include<iostream>#include "stdafx.h"#include<cstring>int main(){ using namespace std; string s= cin.get ...
  • 基於互動式視窗下的文件操作(文件名為user_list.cfg): >>> print (open('user_list.cfg','r').read())user1:password1user2:password2 >>> print (open('user_list.cfg','r').read ...
  • 在一個"tarball"中(經過 tar 和 gzip 處理過的文件)備份最後 24 小時之內當前目錄下所有修改的文件。 程式代碼如下: ~~~~ !/bin/bash BACKUPFILE=backup $(date +%y %m %d) 在備份文件中嵌入時間。 archive=${1: $BAC ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...