package web;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class FindPlusEqFix {
public static void main(String args[]) {
int arr[] = { 4, -1, 5, -4, 7, 9, 8, -3, 6, 3 };
//int sum = 8;
//getRes(arr, sum);
//System.out.println(getResult(arr, sum));
for (int j = 0; j < arr.length; j++) {
System.out.print(arr[j] + "\t");
}
System.out.println();
insertSort(arr);
}
// 求数组里任意两数相加为一固定值的数
public static void getRes(int[] arr, int sum) {
int arrLen = arr.length;
for (int i = 0; i < arrLen; i++) {
int temp = sum - arr[i];
for (int j = 0; j < arrLen; j++) {
int res = arr[j];
if ((res == temp) && (arr[i] != temp)) {
System.out.println(res);
}
}
}
}
// 求数组里任意两数相加为一固定值的数.这里是空间换时间
public static Map<Integer, Integer> getResult(int[] values, int sum) {
Map<Integer, Integer> map = new HashMap<Integer, Integer>();
if (values == null || values.length == 0 || values.length == 1)
return map;
List<Integer> list = new ArrayList<Integer>();
for (int value : values) {
list.add(value);
}
for (int value : values) {
int result = sum - value;
if (!list.contains(result))
continue;
int key = value <= result ? value : result;// 把数组小的值作为key
int val = value > result ? value : result;// 把数组大的值作为value
map.put(key, val);
}
return map;
}
// 找一个数组重复的数
private static int getResult2(int[] values) {
if (values == null || values.length == 0) {
throw new RuntimeException("数组不能为空");
}
Map<Integer, Boolean> map = new HashMap<Integer, Boolean>();
for (int value : values) {
if (map.get(value) != null && map.get(value) == true) {
return value;
} else {
map.put(value, true);
}
}
throw new RuntimeException("不能存在重复数字");
}
// 负数一块,正数一块,相对位置不变
private static Integer[] getResult(Integer[] values) {
if (values == null || values.length == 0 || values.length == 1)
return values;
List<Integer> leftList = new ArrayList<Integer>();
List<Integer> rightList = new ArrayList<Integer>();
for (Integer value : values) {
if (value <= 0) {
leftList.add(value);
} else {
rightList.add(value);
}
}
leftList.addAll(rightList);
return leftList.toArray(new Integer[0]);
}
static void insertSort(int arr[]) {
int minus = -1, plus = -1;
int tmp = 0;
for (int i = 0; i < arr.length; i++) {
if (minus == -1) {
if (arr[i] < 0 && plus >= 0) {
minus = i;// 用来寻找第一个负数
}
if (arr[i] > 0 && plus < 0) {
plus = i;// 用来寻找第一个正数
}
}
if (minus >= 0 && plus >= 0)// 都找到之后进行交换
{
tmp = arr[plus];
arr[plus++] = arr[minus];
for (int k = minus; k > plus; k--) {
arr[k] = arr[k - 1];
}
arr[plus] = tmp;
minus = -1;
//每次排完序,就打印一下结果
for (int j = 0; j < arr.length; j++) {
System.out.print(arr[j] + "\t");
}
System.out.println();
}
}
}
}
相关推荐
国民经济非垂直管理行业或领域建立大数据中心,需要配备能大规模云同步归集行业数据的软件系统,“行业数据云通用的同步枢纽与大数据联合体平台”(GSMS)就是为此而研制的。GSMS主要用于通过互联网大规模同步采集...
多EXCEL文件的数据自动归集与汇总多EXCEL文件的数据自动归集与汇总多EXCEL文件的数据自动归集与汇总
数据归集的内容及数据标准要求.pdf
电力行业量测数据归集专项模型及标准表设计成果
电梯应急处置平台数据归集规则.doc
商务数据归集和应用系统建设项目.docx
为全市“一网统管”建设、水务数字化转型工作提供了数据支撑。 在防御2018-2020年“安比”、“云雀”、“利奇马”、“黑格比”等台风暴雨中,服务于市、区和街镇的水资源管理、水环境治理中发挥重要作用,提高了工作...
软件工程毕业设计—食品安全领域信用数据归集系统,已获通过高分项目。 内含全部项目文档。 0_软件项目实践报告.doc 1_项目可行性研究报告.doc 2_进度计划 .mpp 3_软件需求说明书.doc 4_系统设计说明书.doc 5_数据库...
java毕业设计—基于java的食品安全领域信用数据归集系统。已获通过高分项目。也可作为课程设计,期末大作业等。 内含全部项目文档。 0_软件项目实践报告.doc 1_项目可行性研究报告.doc 2_进度计划 .mpp 3_软件需求...
目前,国家电网公司拥有海量的历史...基于对云计算技术架构的研究,提出一种基于云存储的数据归集体系架构,该体系可以稳定、高效地解决全量业务数据归集过程中的海量数据存储问题,为全量业务数据归集提供可靠保障。
数据归集 :实现相关的2 数据可视化:直观呈现分布、快速了解质量 数据可视化:直观呈现分布、快速了解质量 数据可视化:直观呈现分布、快速了解质量 数据可视化:直观呈现分布、快速了解质量 3 数据清洗:处理...
省公共信用信息系统第一批归集数据项.doc
数据归集平台原型图_recovered.rp
电梯应急处置平台数据归集规则.pdf
随着资讯科技的发展,服装企业对营销数据的归集、整理、分析能力将不断增强。某些经营理念好的品牌已经对所有终端店铺安装了专业的服装销售软件并进行联网,在公司营销中心还配备了专业的数据分析员进行及时的数据...
省级数据中心建设方案
(信用管理)省公共信用信息系统第一批归集数据项.pdf
制定与人口综合库建设、数据共享、数据应用相 关的标准规范,以人口库标准规范为导向,完成 人口综合库的库表设计及数据的归集、清洗、关 联与加载,建成全市统一规范化、标准化的人口 综合数据库。各单位需确保提交...
【财务管理信用管理 】省公共信用信息系统第批归集数据项.pdf
提供数据工厂能力,实现对归集的数据进行清洗、加工,支撑业务的数据应用需求。具体,在本次区级大数据资源平台建设项目中,数据治理子平台的建设内容包括: 资源目录管理:提供资源目录管理功能,包括:资源编目...