筆試刷題-拼多多2018-08-17

題目描述:

給出一個(gè)是否為朋友的矩陣輸入用逗號(hào)分隔, isFriend[i][j]==1表示為朋友,否則不是朋友;

找出一對(duì)i, j使得i, j不是直接朋友,但是i,j有共同的朋友,求這種共同的朋友數(shù)量最多的情況即可。

思路:

簡(jiǎn)單枚舉計(jì)算即可。(這里用了split所以用了java)

代碼如下:

package fall_2018;
 
import java.util.*;
 
public class Test03 {
    public static void main(String[] args){
        Scanner sc=new Scanner(System.in);
        int N, targetId;
        N=sc.nextInt();
        targetId=sc.nextInt();
        //吃掉回車
        sc.nextLine();
        //構(gòu)建朋友矩陣
        boolean[][] isFriendMatrix=new boolean[N][N];
        for(int i=0; i<N; i++){
            String friendListStr = sc.nextLine();
            String[] friendIdStrArr=friendListStr.split("\\s+");
            for(String friendIdStr:friendIdStrArr){
                int friendId=Integer.parseInt(friendIdStr);
                isFriendMatrix[i][friendId]=true;
                isFriendMatrix[friendId][i]=true;
            }
        }
        //找出與targetId共同朋友最多的人
        int resultId=-1, resultMaxCommonFriendNum=0;
        for(int uId=0; uId<N; uId++){
            if(uId==targetId)
                continue;
            //若為朋友不用
            if(isFriendMatrix[targetId][uId])
                continue;
            int commonFriendNum=0;
            for(int vId=0; vId<N; vId++){
                if(isFriendMatrix[targetId][vId] && isFriendMatrix[uId][vId]){
                    commonFriendNum++;
                }
            }
            if(commonFriendNum>resultMaxCommonFriendNum){
                resultMaxCommonFriendNum=commonFriendNum;
                resultId=uId;
            }
        }
        //輸出結(jié)果
        System.out.println(resultId);
    }
}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法,內(nèi)部類的語法,繼承相關(guān)的語法,異常的語法,線程的語...
    子非魚_t_閱讀 34,753評(píng)論 18 399
  • 鼠標(biāo)粗描淡寫,人物在粗糙中也活靈活現(xiàn)。
    清秋朗月閱讀 571評(píng)論 0 2

友情鏈接更多精彩內(nèi)容