zoukankan      html  css  js  c++  java
  • Java实现第八届蓝桥杯国赛 数字划分

    标题:数字划分

    w星球的长老交给小明一个任务:
    1,2,3…16 这16个数字分为两组。
    要求:
    这两组数字的和相同,
    并且,两组数字的平方和也相同,
    并且,两组数字的立方和也相同。

    请你利用计算机的强大搜索能力解决这个问题。
    并提交1所在的那个分组的所有数字。

    这些数字要从小到大排列,两个数字间用一个空格分开。
    即类似:1 4 5 8 … 这样的答案。

    注意,只提交这一组数字,不要填写任何多余的内容。

    import java.util.Vector;
    
    
    public class shuzihuafen {
    	   public static void main(String[] args) {  
    	        for(int w=1;w<=(1<<16)-1;w+=2){//枚举有1出现的数组的所有情况,将其表示成十进制和的形式  
    	            Vector<Integer>group1=new Vector<Integer>();  
    	            Vector<Integer>group2=new Vector<Integer>();  
    	            int k;  
    	            int s1[]=new int[2];//s[1]表示1所在分组的和,s[0]表示1不在分组的和  
    	            int s2[]=new int[2];//s2[1]表示1所在组的平方和,s2[0]表示1不在组的平方和  
    	            int s3[]=new int[2];//s3[1]表示1所在组的立方和,s3[0]表示1不在组的立方和  
    	              
    	            //将w十进制转为二进制  
    	            for(int i=0;i<16;i++){  
    	                int m=1<<i;  
    	                if((w&m)!=0){//按位与判断当前数字是否在1分组中  
    	                    k=1;  
    	                }else  
    	                    k=0;  
    	                if(k==1) group1.add(i+1);  
    	                else group2.add(i+1);  
    	                s1[k]+=i+1;  
    	                s2[k]+=(i+1)*(i+1);  
    	                s3[k]+=(i+1)*(i+1)*(i+1);  
    	            }  
    	              
    	            if(s1[0]==s1[1]&&s2[0]==s2[1]&&s3[0]==s3[1]){  
    	                for(int i=0;i<group1.size();i++)   
    	                    System.out.print(group1.get(i)+" ");  
    	                System.out.println();  
    	            }  
    	        }  
    	    }  
    
    	   
    
    }
    
    
  • 相关阅读:
    VB6SP6极度精简兼容绿色版
    Upnp资料整理
    RevMan简单入门指南
    小程序 --flex
    IV
    2017-10-27错误日志
    170616_2
    170616
    2017-06-07
    111111112222
  • 原文地址:https://www.cnblogs.com/a1439775520/p/13079242.html
Copyright © 2011-2022 走看看