Prime Solutions
以下是一段中学时代的惨痛回忆…每当学到排列组合的单元时,最痛苦的不是分析题目,也不是带错公式或计算错误,而是所谓的「苦工题」,以下这题是个例子:
给定正整数N与S,求出方程式(1)的所有质数解(全为质数)。

遇到这题,通常只能硬着头皮将每一组以「土法炼钢」的方式一一列出,然而到了大学修过程式设计与演算法课,俾使我们能在电脑上撰写程式轻松解决此问题。

INPUT
第一行一样为测资个数
每一行输入正整数与正整数,N与S之间相隔一个空白键。
(提示: 计算之前先考虑方程式有没有解可以加速程式执行。)

OUTPUT
N个质数相加刚好等於S有哪些可能的组合,质数可以重复,但请由小到大排列,若无解(例如100个质数相加等於23无解)则输出0,解可能不只一组,若有多组解时,靠左边的数字较小的那组解则优先输出,请参照SAMPLE OUTPUT。每一笔测资的输出之间也换一行。

SAMPLE INPUT
4
2 5
100 23
3 8
4 25

SAMPLE OUTPUT
2 3

0

2 3 3

2 2 2 19
2 3 3 17
2 3 7 13
2 5 5 13
2 5 7 11


答案

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.Iterator;
import java.util.List;
import java.util.Scanner;
import java.util.Stack; public class Prime {
static List<Integer> primeList = new ArrayList<Integer>(); static List<Integer> starttList = new ArrayList<Integer>();
static List<Integer[]> engtList = new ArrayList<Integer[]>(); static Integer[] iArr ;
static boolean flage; //static int a;
static int size; static Stack<Integer> stack = new Stack<Integer>(); static Stack<Integer> stackResult = new Stack<Integer>();
public static void main(String[] args) {
Scanner scan = new Scanner(System.in);
int z = scan.nextInt();
while(z>0){
flage = false;
stack.clear();
stackResult.clear();
iArr =null;
primeList =new ArrayList<Integer>();
engtList = new ArrayList<Integer[]>(); // System.out.println("请输入您要结果的size:"); size = scan.nextInt(); // System.out.println("请输入您要结果数为:");
int num = scan.nextInt(); for(int i=2;i<=num;i++){
if(isPrime(i)){
primeList.add(i);
}
} iArr = primeList.toArray(new Integer[0]);
sort(iArr); Calc(num, iArr);
int j=0;
if(!flage){
System.out.println(j);
}
z--; Comparator<Integer[]> comparator = new Comparator<Integer[]>() {
public int compare(Integer[] s1, Integer[] s2) {
for(int i=0;i<s1.length;i++){
if(s1[i]!=s2[i]){
return s1[i]-s2[i];
}
}
return 1; }
}; //这里就会自动根据规则进行排序
Collections.sort(engtList,comparator);
for(int i=0;i<engtList.size();i++){
Integer[] stu=engtList.get(i);
for(int ii:stu){
System.out.print(ii+" ");
}
System.out.println();
}
if(z>0){
System.out.println();
} } } private static void Calc(int a,Integer[] iArr)
{
for (int i = 0; i < iArr.length; i++)
{
if (iArr[i] == a && size==1)
{
//输出这个数
System.out.println(iArr[i]);
flage=true;
continue;
}
// else if (iArr[i] > a)
// {
// continue;
// }
if (iArr[i] > a)
{
continue;
}
stack.clear();
stack.push(iArr[i]);
Func(i, a - iArr[i]);
}
} private static void Func(int i, int iValue)
{
for (int j = i ; j < iArr.length; j++)
{
if (iArr[j] > iValue)
{
continue;
}
else if (iValue == iArr[j])
{
stack.push(iArr[j]);
//输出stack 这一步略..
if(stack.size()==size){
iteratorThroughIterator(stack); }
stack.pop();
}
else if (iValue > iArr[j])
{ stack.push(iArr[j]);
Func(j, iValue - iArr[j]);
stack.pop();
}
}
} /**
* 通过迭代器遍历Stack
*/
public static void iteratorThroughIterator(List list) { Integer val = null;
for(Iterator iter = list.iterator(); iter.hasNext(); ) {
val = (Integer) iter.next();
stackResult.push(val);
// System.out.print(val+" ");
}
// System.out.println();
playResult(stackResult);
stackResult.clear();
} /**
* 通过迭代器遍历Stack
*/
public static void playResult(Stack stack) {
flage = true;
while(!stack.empty()){ starttList.add((Integer) stack.pop());
}
Integer[] a= starttList.toArray(new Integer[0]);
starttList.clear();
engtList.add(a.clone());
a=null; // System.out.println(); } public static boolean isPrime(int num){ for (int i = 2; i < num; i++) {//运行效率不高
if ((num % i) == 0) { return false;
}
}
return true;
}

public static void sort(Integer[] iArr){
for (int i = 0; i < iArr.length -1; i++){
for(int j = 0 ;j < iArr.length - i - 1; j++){
if(iArr[j] < iArr[j + 1]){
int temp = iArr[j];
iArr[j] = iArr[j + 1];
iArr[j + 1] = temp;
}
}
}
}
}

Prime Solutions的更多相关文章

  1. SPOJ Prime or Not - 快速乘 - 快速幂

    Given the number, you are to answer the question: "Is it prime?" Solutions to this problem ...

  2. Prime Ring Problem

    Problem Description A ring is compose of n circles as shown in diagram. Put natural number 1, 2, ... ...

  3. hdoj 1016 Prime Ring Problem

    Problem Description A ring is compose of n circles as shown in diagram. Put natural number 1, 2, ... ...

  4. hdu 1016 Prime Ring Problem(DFS)

    Prime Ring Problem Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  5. HDU 1016 Prime Ring Problem(经典DFS+回溯)

    Prime Ring Problem Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  6. 杭电oj 1016 Prime Ring Problem

    Prime Ring Problem Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  7. hdu 1016 Prime Ring Problem(深度优先搜索)

    Prime Ring Problem Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  8. HDU1016 Prime Ring Problem(DFS回溯)

    Prime Ring Problem Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  9. HDU 1016 Prime Ring Problem (DFS)

    Prime Ring Problem Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  10. Jordan Lecture Note-6: The Solutions of Nonlinear Equation.

    The Solutions of Nonlinear Equation 本文主要介绍几种用于解非线性方程$f(x)=0$的一些方法. (1) Bisection Method. 算法: step 1: ...

随机推荐

  1. dotnet C# 只创建对象不调用构造函数方法

    有时我期望只是创建出对象,但是不要调用对象的构造方法,可以通过使用 FormatterServices 的 GetUninitializedObject 函数来实现只创建对象不调用构造函数方法 这个 ...

  2. 安装petalinux

    1.petalinux工具下载,下载地址: https://china.xilinx.com/support/download/index.html/content/xilinx/zh/downloa ...

  3. 【学习笔记】Python 使用 matplotlib 画图

    目录 安装 中文显示 折线图.点线图 柱状图.堆积柱状图 坐标轴断点 参考资料 本文将介绍如何使用 Python 的 matplotlib 库画图,记录一些常用的画图 demo 代码 安装 # 建议先 ...

  4. docker-compose安装EFK

    一.环境 IP 系统 配置 版本 192.168.10.100 Centos7.9 2核4G Docker Compose version v2.19.1.EFK-7.17.11 EFK版本是试用版本 ...

  5. .NET开源、功能强大、跨平台的图表库 - LiveCharts2

    前言 今天大姚给大家分享一个.NET开源(MIT License).功能强大.简单.灵活.跨平台的图表.地图和仪表库:LiveCharts2.   项目介绍 LiveCharts2是一个.NET开源. ...

  6. c#胖东来小程序自动购物程序(接单,windows桌面程序、linux程序、网络应用等等)

    一.程序效果 自动打开胖东来小程序,自动购物 二.实现 先截屏,然后利用opencv库识别下一步按键所在位置,然后使用mouse_event控制鼠标,模拟人的动作 第一步,截取屏幕 static Bi ...

  7. Premiere cc 2019之声音处理

    目录 deepin录视频 调整声道 查看声音轨道 转化格式 提取二声道的台词音,或者背景音 降噪 1.无需AU!PR自带音频模块完美实现降噪.增强人声.模拟环境 2.Adobe audition中降噪 ...

  8. JDK源码阅读-------自学笔记(二十二)(java.util.ArrayList自定义晋级,ArrayList实战详解)

    简介(Introduction)   上篇文章主要介绍了ArrayList自行模仿建立的方式,那么,其实这个类不是一次性就那么完美的,现在做一个一步步变成那样完整的ArrayList的版本升级测试. ...

  9. C 语言编程 — 宏定义与预处理器指令

    目录 文章目录 目录 前文列表 宏 预处理器 预处理器指令 预处理器指令示例 预定义宏 预处理器指令运算符 宏延续运算符 字符串常量化运算符 标记(Token)粘贴运算符 defined() 运算符 ...

  10. ReplayKit2采用端口转发数据时不能终止的问题

    一.现象描述 测试发现在进行USB连接数据投屏中,如果点击屏幕红条进行结束ReplayKit2投屏或者通知栏点击停止录制按钮,大概率出现已经停止录屏,但是通知栏中的录屏按钮还在继续录制的问题 这个现象 ...