[学习报告]《LeetCode零基础指南》(第五讲) 指针(上)

简介: 第一题:1470. 重新排列数组 第二题:1929. 数组串联 第三题:1920. 基于排列构建数组 第四题:1480. 一维数组的动态和 第五题:剑指 Offer 58 - II. 左旋转字符串

第一题:1470. 重新排列数组


class Solution {
    public int[] shuffle(int[] nums, int n) {
        //只需两个数的步长为n就在一起,在新的数组,因为一次加了两个元素,
        //所以每一次下来都得加2
          int arr[]=new int[2*n];
          for(int i=0,j=0;i<n;i++,j+=2){
             arr[j]=nums[i];
             arr[j+1]=nums[i+n];
          }
          return arr;
    }
}


image.png


第二题:1929. 数组串联


class Solution {
    public int[] getConcatenation(int[] nums) {
        //在n和2n分别弄两个索引进行拷贝就可以了
        int n=nums.length;
         int arr[]=new int [2*n];
         int j=0;
         for(int i=0;i<2*n;i++){
             if(i<n){
                 arr[i]=nums[i];
             }else{
                 arr[i]=nums[j];
                 j++;
             }
         }
         return arr;
    }
}


微信图片_20220106112928.png


第三题:1920. 基于排列构建数组


这题按照题目的意思就可以了


class Solution {
    public int[] buildArray(int[] nums) {
        int n= nums.length;
        int []arr=new int[n];
        for(int i=0;i<n;i++){
            arr[i]=nums[nums[i]];
        }
        return arr;
    }
}


微信图片_20220106112951.png


第四题:1480. 一维数组的动态和


第一想法就是创建一个方法实现前几项的和。


class Solution {
    public int[] runningSum(int[] nums) {
             int count=0;
             int n=nums.length;
                int arr[]=new int[n];
             for(int i=0;i<nums.length;i++){
                  count=soul(nums,i+1);
                  arr[i]=count;
             }   
             return arr; 
    }
  public static int soul(int nums[],int n){
      int sum=0;
        for(int i=0;i<n;i++){
             sum+=nums[i];
        }
         return sum;
  }
}


微信图片_20220106113023.png


第五题:剑指 Offer 58 - II. 左旋转字符串


这题参考了一下评论区的想法


class Solution {
    public String reverseLeftWords(String s, int n) {
            StringBuilder sb=new StringBuilder();
            for(int i=n;i<s.length();i++){
                  sb.append(s.charAt(i));//从n开始得到每个字符
            }
            for(int i=0;i<n;i++){
                sb.append(s.charAt(i));//将第一个到n依次加到之前的后面
            }
            return sb.toString();//转为字符串后返回
    }
}


微信图片_20220106113051.png

目录
相关文章
|
1月前
|
算法
LeetCode刷题---21.合并两个有序链表(双指针)
LeetCode刷题---21.合并两个有序链表(双指针)
|
1月前
|
算法
LeetCode刷题---19. 删除链表的倒数第 N 个结点(双指针-快慢指针)
LeetCode刷题---19. 删除链表的倒数第 N 个结点(双指针-快慢指针)
|
1月前
|
存储 算法
LeetCode刷题--- 61. 旋转链表(快慢指针+闭合为环)
LeetCode刷题--- 61. 旋转链表(快慢指针+闭合为环)
|
1月前
|
算法 索引
LeetCode刷题--- 138. 复制带随机指针的链表(哈希表+迭代)
LeetCode刷题--- 138. 复制带随机指针的链表(哈希表+迭代)
|
1月前
|
存储 算法 索引
LeetCode刷题---链表经典问题(双指针)
LeetCode刷题---链表经典问题(双指针)
|
1月前
|
机器学习/深度学习 算法
力扣刷题日常(一)
力扣刷题日常(一)
20 2
|
1月前
|
存储 索引
《LeetCode》—— LeetCode刷题日记
《LeetCode》—— LeetCode刷题日记
|
1月前
|
搜索推荐
《LeetCode》——LeetCode刷题日记3
《LeetCode》——LeetCode刷题日记3
|
1月前
|
容器
《LeetCode》——LeetCode刷题日记1
《LeetCode》——LeetCode刷题日记1
|
1月前
|
算法 测试技术
LeetCode刷题--- 430. 扁平化多级双向链表(深度优先搜索)
LeetCode刷题--- 430. 扁平化多级双向链表(深度优先搜索)

热门文章

最新文章