对给定正整数数列A进行重新排序,使得数列A满足所有的A[i]*A[i+1]都是4的倍数。
2017-09-10 09:08
267 查看
题目:对给定正整数数列A进行重新排序,使得数列A满足所有的A[i]*A[i+1]都是4的倍数。
判断一个数列是否可以重排之后满足要求。如果满足要求输出“Yes”,不满足要求时输出"No"。分析:首先统计数组中存在多少个4的倍数的个数,然后统计存在多少个2的倍数的个数(因为2的倍数和2的倍数相乘也可以整除4)。再采用插空法进行排列组合,若数组中不存在2的倍数,那么4的倍数的个数+1应该大于等于剩余的奇数的个数,则可以完成要求;若数组中存在2的倍数,不论存在多少个,4的倍数的个数都应该大于等于剩余奇数的个数,则可以完成要求,否则输出为No。
备注:网上笔试题,代码是参考网上别人的,具体出处找不到了,请谅解。摘抄记录下来方便日后学习。如果有问题尽请批评指正,希望可以和大神一起交流。
java代码如下:
import java.util.Scanner; public class Main09 { public static void main(String[] args) { Scanner in= new Scanner(System.in); int N=in.nextInt(); while(N-->0){ int x=in.nextInt(); int arr[]=new int[x]; for (int i = 0; i < x; i++) { arr[i]=in.nextInt(); } int count=0; int dou=0; 4000 for (int i = 0; i < x; i++) { if (arr[i]%4==0) count++; else if (arr[i]%2==0) dou++; } //temp为剩余的奇数个数 int temp=0; temp=x-count-dou; if (dou==0) { if (count+1>=temp) System.out.println("Yes"); else System.out.println("No"); }else { if (count>=temp) System.out.println("Yes"); else System.out.println("No"); } } } }
例如输入
2
3
1 10 100
4
1 2 3 4
输出
Yes
No
相关文章推荐
- n个实数(仅包含正实数和负实数)组成的数组A进行重新排序, //使得其中的所有的负实数都要在正实数之前
- 随机产生20个正整数存入数组a中,且每个数均在1000-9999之间(包含1000和9999)。对数组进行排序,要求按每个数的后三位的大小进行升序排列,然后取出满足此条件的前10个数放入数组b中,如
- 编写程序实现以下功能: 随机产生20个正整数存入数组a中,且每个数均在1000-9999之间(包含1000和9999)。对数组进行排序,要求按每个数的后三位的大小进行升序排列,然后取出满足此条
- 求出所有这些四位数是素数的个数cnt,再把所有满足此条件的四位数依次存入数组b中,然后对数组b中的四位数按从小到大的顺序进行排序
- Help Tomisu UVA - 11440 难推导+欧拉函数,给定正整数N和M, 统计2和N!之间有多少个整数x满足,x的所有素因子都大于M (2<=N<=1e7, 1<=M<=N, N-M<=1E5) 输出答案除以1e8+7的余数。
- 随机产生20个正整数存入数组a中,且每个数均在1000-9999之间(包含1000和9999)。对数组进行排序,要求按每个数的后三位的大小进行升序排列,然后取出满足此条件的前10个数放入数组b中,如果
- 给定一个链表和一个值x,对它进行分区,使得小于x的所有节点都在大于或等于x的节点之前.保留两个分区中的每一个节点的原始相对顺序。
- 随机产生20个正整数存入数组a中,且每个数均在1000-9999之间(包含1000和9999)。对数组进行排序,要求按每个数的后三位的大小进行升序排列,然后取出满足此条件的前10个数放入数组b中,如果
- 任意给定一个自然数N,要求M是N的倍数,且他的所有各位数字都是由0或1组成,并要求M尽可能小
- 求出千位数上的数加百位数上的数等于十位数上的数加个位数上的数的个数cnt,再把所有满足条件的四位数依次存入数组b中,然后对数组b中的四位数按从大到小的顺序进行排序。
- 随机产生20个正整数存入数组a中,且每个数均在1000-9999之间(包含1000和9999)。对数组进行排序,要求按每个数的后三位的大小进行升序排列,然后取出满足此条件的前10个数放入数组b中,如果
- 【codeforces 691 E】【矩阵快速幂 思维题】【给定序列,从序列中选择k个数(可以重复选择),使得得到的排列满足xi与xi+1异或的二进制表示中1的个数是3的倍数。问满足条件的序列个数】
- matlab如何循环读入某一文件夹下的所有图片 对某文件夹下的图片进行重新排序
- 随机产生20个正整数存入数组a中,且每个数均在1000-9999之间(包含1000和9999)。对数组进行排序,要求按每个数的后三位的大小进行升序排列,然后取出满足此条件的前10个数放入数组b中,如果
- C语随机产生20个正整数存入数组a中,且每个数均在1000-9999之间(包含1000和9999)。对数组进行排序,要求按每个数的后三位的大小进行升序排列,然后取出满足此条件的前10个数放入数组b中,
- Java类对象排序问题---如何对不同类的所有对象进行排序
- 以行为单位对字符串变量下标为奇数位置上的字符按其ASCii值从小到大的顺序进行排序,排序后的结果仍按行重新存入字符串数组xx中
- 给定2个数字,n,m,使得从1到n之间的数字组合,他们的和等于m,求所有组合
- 【练习】输入两个正整数n和m,从数列1,2,3.......n中随意取几个数,使其和等于m,要求将其中所有的可能组合列出来
- 3370 Halloween treats 抽屉原理 给定n个数,求其中的任意一个子集满足集合中的每个元素值加和正好是c的倍数