L2-023 图着色问题 (25 分) 详解 set+vector

#include <bits/stdc++.h>   
using namespace std; 
int main(int argc, char** argv) { 
       vector<int> maps[1001]; //存邻居
        int n,m,v[1001],u; 
        cin>>n>>m>>u;
	    for(int i=0;i<m;i++){ 
           int a,b;
		   cin>>a>>b; 
		   maps[a].push_back(b); 
		   maps[b].push_back(a); 
	   }   
	 int ii; 
	 cin>>ii;
	 while(ii--){ 
	 int kk=0;  
     set<int>xx;  //存颜色数 用set去重
	 for(int i=1;i<=n;i++){ 
	  		 cin>>v[i]; 
			  xx.insert(v[i]);    
	  } 
	  if(xx.size()!=u) cout<<"No"<<endl; //颜色数多或少都是错的 
	  else{
	   for(int i=1;i<=n;i++){ 
	      for(int j=0;j<maps[i].size();j++){ 
			  if(v[i]==v[maps[i][j]])     //遍历判断邻居颜色
			  {  
			      kk=1; 
				  i=n+1; 
			      cout<<"No"<<endl;
                      break;
 			   }     
		  }  
	    }  
	    if(kk==0) cout<<"Yes"<<endl;
       }  
	 }
}  
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值