【刷题系列】 Java数组小题(一)

简介: 【刷题系列】 Java数组小题(一)

1. 改变原有数组元素的值

实现一个方法 , 以数组为参数, 循环将数组中的每个元素 乘以 2 , 并设置到对应的数组元素上. 例如 原数组为 {1, 2, 3}, 修改之后为 {2, 4, 6}
public class Main{
    public static void main(String[] args) {
          int[] array ={1,2,3};
         func(array);
         System.out.println(Arrays.toString(array));
    }
    public static void func(int[] array) {

        for (int i = 0; i < array.length; i++) {
            array[i] = array[i]*2;
        }

    }
}

img

编辑

2. 求数组的平均值

实现一个方法 avg, 以数组为参数, 求数组中所有元素的平均值(注意方法的返回值类型).
public class Main{
    public static double avg(int[] array) {
       int sum = 0;
       for (int i : array) {
           sum = sum + i;
      }
       return sum * 1.0 / array.length;
    }
public static void main(String[] args) {
       int[] arr1 = {1, 2, 5, 6, 8, 9, 11};
       System.out.println(avg(arr1));
  }
}

img

编辑

3. 奇数位于偶数之前

调整数组顺序使得奇数位于偶数之前。调整之后,不关心大小顺序。

如数组:[1,2,3,4,5,6]

调整后可能是:[1, 5, 3, 4, 2, 6]

public static void func(int[] array){
    int i= 0;
    int j =array.length-1;
    while(i<j){
        while(i<j && array[i] % 2 != 0){
            i++;
        }
        while(i<j && array[j] %2 == 0){
            j--;
        }
        int tmp = array[i];
        array[i] = array[j];
        array[j] =tmp;
    }
}

img

编辑

4. 二分/折半查找

/**
 * 实现二分查找
 * 前提:数组需要排序为有序数组
 * 效率较高
 * 可使用Arrays工具类
 * @param array
 * @param key
 * @return
 */
public static int binSearch(int[] array,int key){
    int mid = 0;
    int left = 0;
    int right = array.length-1;
    while (left<=right){
        mid =(left +right)>>>1;
        if(key>array[mid]){
            left = mid+1;
        }else{
            if(key<array[mid]){
                right = mid -1;
            }else {
                return mid;
            }
        }
    }
        return -1;
}
public static void main(String[] args) {
    int[] arr2 = {1, 2, 5, 6, 8, 9, 11};
     Arrays.sort(arr2);//默认升序,底层快排
    System.out.println(Arrays.binarySearch(arr2, 9));
    //使用Arrays工具类
    System.out.println(binSearch(arr2, 9));
}

img

5. 两数之和

class Solution{
  public static int[] func3(int[] array, int target) {
    int[] ret = new int[2];
    for (int i = 0; i < array.length; i++) {
        for (int j = 0; j < array.length; j++) {
            if (array[i] + array[j] == target&&i!=j) {
                ret[0] = i;
                ret[1] = j;

            }
        }
    }
    return ret;
   }
}

6. 只出现一次的数字

class Solution{
  public static int  fun(int[] array) {
    int ret = 0;
    for (int i = 0; i < array.length; i++) {
          ret = ret ^array[i];
    }
    return ret;
  }
}

相关文章
|
28天前
|
Java
|
2天前
|
存储 Java 数据处理
Java 数组的高级用法
在 Java 中,数组不仅可以存储同类型的数据,还支持多种高级用法,如多维数组(常用于矩阵)、动态创建数组、克隆数组、使用 `java.util.Arrays` 进行排序和搜索、与集合相互转换、增强 for 循环遍历、匿名数组传递以及利用 `Arrays.equals()` 比较数组内容。这些技巧能提升代码的灵活性和可读性,适用于更复杂的数据处理场景。
|
2天前
|
存储 Java
java的Excel导出,数组与业务字典匹配并去掉最后一个逗号
java的Excel导出,数组与业务字典匹配并去掉最后一个逗号
18 2
|
23天前
|
Java
Java数组的应用场景
Java数组的应用场景
28 1
|
23天前
|
存储 机器学习/深度学习 Java
Java数组
Java数组
25 1
|
20天前
|
存储 开发者 C#
WPF与邮件发送:教你如何在Windows Presentation Foundation应用中无缝集成电子邮件功能——从界面设计到代码实现,全面解析邮件发送的每一个细节密武器!
【8月更文挑战第31天】本文探讨了如何在Windows Presentation Foundation(WPF)应用中集成电子邮件发送功能,详细介绍了从创建WPF项目到设计用户界面的全过程,并通过具体示例代码展示了如何使用`System.Net.Mail`命名空间中的`SmtpClient`和`MailMessage`类来实现邮件发送逻辑。文章还强调了安全性和错误处理的重要性,提供了实用的异常捕获代码片段,旨在帮助WPF开发者更好地掌握邮件发送技术,提升应用程序的功能性与用户体验。
23 0
|
27天前
|
存储 Java 开发者
揭秘!HashMap底层结构大起底:从数组到链表,再到红黑树,Java性能优化的秘密武器!
【8月更文挑战第24天】HashMap是Java集合框架中的核心组件,以其高效的键值对存储和快速访问能力广受开发者欢迎。在JDK 1.8及以后版本中,HashMap采用了数组+链表+红黑树的混合结构,实现了高性能的同时解决了哈希冲突问题。数组作为基石确保了快速定位;链表则用于处理哈希冲突;而当链表长度达到一定阈值时,通过转换为红黑树进一步提升性能。此外,HashMap还具备动态扩容机制,当负载因子超过预设值时自动扩大容量并重新哈希,确保整体性能。通过对HashMap底层结构的深入了解,我们可以更好地利用其优势解决实际开发中的问题。
47 0
|
28天前
|
存储 搜索推荐 算法
在 Java 中如何更改数组列表的顺序
【8月更文挑战第23天】
14 0
|
28天前
|
存储 安全 Java
在 Java 中如何存储数组列表
【8月更文挑战第23天】
22 0
|
28天前
|
Java API
如何在 Java 中将 Arraylist 变成数组?
【8月更文挑战第23天】
22 0