京东java编程第一题,ac代码

//京东笔试第一题,ac代码
//思路为先将图反转,将反转后的图分为几个完全连通部件,
//此时用BFS或DFS找出所有的连通部件,判断每个连通部件是否为完全图

import java.util.*;

public class Main {

public static boolean[][] matrix =null;

public static boolean[] visited = null;

public static ArrayList<Integer> dgroup=null;

public static void main(String[]args)

{

Scanner sc = new Scanner(System.in);

int T = sc.nextInt();

while(T--!=0) {

int n,m;

int s,t;

n=sc.nextInt(); m=sc.nextInt();

if(m==0) {

System.out.println("Yes");

continue;

}

matrix= new boolean[n][n];

visited = new boolean[n];

for(boolean e: visited) {

e = false;

}

for(int i=0; i<n; i++) {

for(int j=0; j<n; j++) {

matrix[i][j]=false;

}

}

for(int i=0; i<m; i++) {

s=sc.nextInt(); t=sc.nextInt();

matrix[s-1][t-1] = true;

matrix[t-1][s-1] = true;

}

boolean flag = true;

for(int i=0; i<n; i++) {

if(visited[i] == false) {

dgroup = new ArrayList<Integer>();

Divide(n,i);

if(!check(dgroup)) {

flag = false;

}

}

}

if(!flag) {

System.out.println("No");

} else {

System.out.println("Yes");

}

}

}

public static void Divide(int n, int s) {

visited[s] = true;

dgroup.add(s);

for(int i=0; i<n ; i++)

{

if(visited[i] == false && i != s) {

if(!matrix[i][s]) {

Divide(n, i);

}

}

}

}

public static boolean check(ArrayList<Integer> group) {

for(int i=0; i<group.size()-1; i++) {

for(int j=i+1; j<group.size(); j++) {

if(matrix[group.get(i)][group.get(j)]) {

return false;

}

}

}

return true;

}

}


#京东##笔试题目#
全部评论
大佬AC了几道?我的第一题没这么复杂,之类两个for循环。第二题没时间做了,选择题差不多对25个,这样能过吗?
点赞 回复 分享
发布于 2018-09-09 23:21
/* JD 多部图 AC 100  找一个节点,和它不相连的节点都划到一个集合里面,然后验证一下这个集合和剩下的节点之间是否满足要求,如果满足,在考虑剩下的节点,先选一个出来,不相连的划分到一个集合中...循环操作直到所有的节点都划分完就可以了 */ import java.util.*; public class JD1 {     public static class Node{         public int value;         public ArrayList<Node> nexts;         public boolean pass;         public Node(int value){             this.value = value;             nexts = new ArrayList<>();             pass = false;         }     }     public static void process(Scanner in){         int n = in.nextInt();         int m = in.nextInt();         HashMap<Integer, Node> map = new HashMap<>();         for(int i = 0; i < n; i++){             map.put(i+1, new Node(i+1));         }         for(int i = 0; i < m; i++){             int f = in.nextInt();             int s = in.nextInt();             Node nf = map.get(f);             Node ns = map.get(s);             nf.nexts.add(ns);             ns.nexts.add(nf);         }         Node n1 = map.get(1);         map.remove(1);         List<Node> xl = n1.nexts;         List<Node> nxl = new ArrayList<>();         for (Map.Entry<Integer, Node> entry : map.entrySet()) {             if(!xl.contains(entry.getValue())){                 nxl.add(entry.getValue());             }         }         boolean pan = false;         for(Node node : nxl){             for(Node node1: xl){                 if(!node.nexts.contains(node1)){                     pan = true;                     break;                 }             }         }         if(pan){             System.out.println("No");         }else{             System.out.println("Yes");         }     }     public static void main(String[] args){         Scanner in = new Scanner(System.in);         int n = in.nextInt();         for(int i = 0; i < n; i++){             process(in);         }     } }
点赞 回复 分享
发布于 2018-09-10 07:08

相关推荐

不愿透露姓名的神秘牛友
11-27 10:48
点赞 评论 收藏
分享
球球别再泡了:坏,我单9要了14
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务