华为OJ平台——整形数组合并
题目描述:
将两个整型数组按照升序合并,并且过滤掉重复数组元素
输入:
输入说明,按下列顺序输入:
1 输入第一个数组的个数
2 输入第一个数组的数值
3 输入第二个数组的个数
4 输入第二个数组的数值
输出:
输出合并之后的数组
输入样例:
3 1 2 5 4 -1 0 3 2
输出样例:
-101235
思路:
先将两个数组合并到一个中,然后对这个完整的数组进行排序,最后剔除重复的数据并输出
import java.util.Scanner; public class ArrayMerge { public static void main(String[] args) {
//输入,按输入的标准输入两个数组的数据
Scanner cin = new Scanner(System.in) ;
int len1 = cin.nextInt() ;
if(len1 < 1){
System.exit(-1);
}
int [] arr1 = new int [len1] ;
for(int i = 0 ; i < len1 ; i++){
arr1[i] = cin.nextInt() ;
}
int len2 = cin.nextInt() ;
if(len2 < 1){
System.exit(-1);
}
int [] arr2 = new int [len2] ;
for(int i = 0 ; i < len2 ; i++){
arr2[i] = cin.nextInt() ;
}
cin.close() ; System.out.print(intArrayMergeASC(arr1,arr2)) ;
} /**
* 进行合并,然后将输出结果存放到一个字符串中返回
* @param arr1
* @param arr2
* @return
*/
private static String intArrayMergeASC(int[] arr1, int[] arr2) {
//将两个数组合并到一个较大的数组中
int [] total = new int [arr1.length + arr2.length] ;
for(int i = 0 ; i < arr1.length ; i++){
total[i] = arr1[i] ;
}
for(int i = 0 ; i < arr2.length ; i++){
total[i+arr1.length] = arr2[i] ;
}
//对合并后的数组排序
sort(total) ;
//保存在结果在字符串中
String res = total[0]+"" ;
int last = total[0] ;
for(int i = 1 ; i < total.length ; i++){
//不相同的则添加到字符串中,相同的则直接下一个
if(total[i] != last){
last = total[i] ;
res += total[i] + "" ;
}
} return res; } /**
* 简单选择排序算法对数组进行排序
* @param arr
*/
private static void sort(int[] arr) {
int min ;
int index ;
for(int i = 0 ; i < arr.length-1 ; i++){
min = arr[i] ;
index = i ;
for(int j = i+1 ; j < arr.length ; j++){
if(min > arr[j]){
min = arr[j] ;
index = j ;
}
}
if(index != i){
arr[index] = arr[i] ;
arr[i] = min ;
}
}
} }
Code
华为OJ平台——整形数组合并的更多相关文章
- 华为OJ平台试题 ——数组:整形数组合并
代码: /* * 将两个整型数组依照升序合并,而且过滤掉反复数组元素 */ #include <stdio.h> #define N 256 #define M 512 /* * 合并数组 ...
- 华为OJ平台试题 —— 数组:输入n个整数,输出当中最小的k个
输入n个整数.输出当中最小的k个: 代码: /* * 输入n个整数,输出当中最小的k个. * 输入说明:1.输入两个整数:2.输入一个整数数组 * 输出说明:输出一个整数数组 */ <p ...
- 华为OJ平台——字符串分隔
题目描述: 连续输入字符串,请按长度为8拆分每个字符创 后输出到新的字符串数组: 长度不是8整数倍的字符串请在后面补数字0,空字符串不处理 输入 连续输入字符串(输入两次,每个字符长长度小于100)输 ...
- 华为OJ平台——输出最小的k个数
输入n个整数,输出其中最小的k个. 详细描述: 接口说明 原型: bool GetMinK(unsignedint uiInputNum, int *pInputArray, unsignedint ...
- 华为OJ平台——矩阵乘法
题目描述: 如果A是个x行y列的矩阵,B是个y行z列的矩阵,把A和B相乘,其结果将是另一个x行z列的矩阵C. 输入: 1.第一个矩阵的行数 2.第一个矩阵的列数(也是第二个矩阵的行数) 3.第二个矩阵 ...
- 华为OJ平台——密码强度等级
题目描述: 密码按如下规则进行计分,并根据不同的得分为密码进行安全等级划分. 一.密码长度: 5 分: 小于等于4 个字符 10 分: 5 到7 字符 25 分: 大于等于8 个字符 二.字母: 0 ...
- 华为OJ平台——求最大连续bit数
题目描述: 求一个byte数字对应的二进制数字中1的最大连续数,例如3的二进制为00000011,最大连续2个1 输入: 一个byte型的数字 输出: 对应的二进制数字中1的最大连续数 思路: ...
- 华为OJ平台——统计字符串中的大写字母
题目描述: 统计字符串中的大写字母的个数 输入: 一行字符串 输出: 字符串中大写字母的个数(当空串时输出0) 思路: 这一题很简单,直接判断字符串中的每一个字符即可,唯一要注意的一点是输入的字符串可 ...
- 华为OJ平台——将真分数分解为埃及分数
题目描述: 分子为1的分数称为埃及分数.现输入一个真分数(分子比分母小的分数,叫做真分数),请将该分数分解为埃及分数.如:8/11 = 1/2+1/5+1/55+1/110. 输入: 输入一个真分数, ...
随机推荐
- 用C#将输入的小写字母转化为大写字母
string A = "adsaf"; string B =""; B=A.ToUper();
- hadoop作业调优参数整理及原理(转)
1 Map side tuning参数 1.1 MapTask运行内部原理 当map task开始运算,并产生中间数据时,其产生的中间结果并非直接就简单的写入磁盘.这中间的过程比较复杂,并且利用到了内 ...
- zookeeper进行leader选举
一.如何进行leader选举 创建 /lj/producer和/lj/master/producer外层节点 创建临时顺序节点 判断自己是否是master节点(判断流程:遍历/lj/producer节 ...
- Navicat(连接) -1之Navicat Cloud
Navicat Cloud Navicat Cloud 提供一个云服务,同步不同机器和平台的 Navicat 连接.查询.模型和虚拟组.当添加一个连接到 Navicat Cloud,它的连接设置和查询 ...
- [JS]鼠标事件穿透的问题
今天制作登陆窗口的效果时碰到的一个问题,如下: 标签结构如下: <div id="loginFrame"> <form class="loginFram ...
- Mongodb(1)如何存储以及简介
在学习一个数据库之前应该了解这个数据库是如何存储的,是不是适合你所需要的存储方式. 如果上来就说命令,理解起来似乎有点麻烦. 不管学习什么数据库都应该学习其中的基础概念,在mongodb中基本的概念是 ...
- HTML5与HTML4的区别
一.推出的理由及目标 web浏览器之间的兼容性很低 文档结构不够明确 web应用程序的功能受到了限制 二.语法的改变 内容类型 文件扩展名html htm 内容类型 texthtml 二者不变 ...
- 编译器错误消息: CS0234: 命名空间“Purple”中不存在类型或命名空间名称“Model”(是否缺少程序集引用?)
编译错误 “/storeimg”应用程序中的服务器错误. 编译错误 说明: 在编译向该请求提供服务所需资源的过程中出现错误.请检查下列特定错误详细信息并适当地修改源代码. 编译器错误消息: CS023 ...
- JAVA 匿名对象
/* 匿名对象: 没有名字的对象 匿名对象的使用方式之一: 当对对象方法只调用一次时,我们可以用匿名对象来完成,比较简化. 匿名对象的使用方式之二: 匿名对象可以被当做实参传递 */ class Ca ...
- JAVA if条件语句,switch多分支结构,与逻辑运算符
一.if条件语句 示例: import java.util.Scanner; public class Test{ public static void main(String[] args){ Sc ...