Day 2

这篇博客主要介绍了字符串和数组的处理方法。首先,通过一个示例展示了如何使用双指针技术实现字符串的整体逆置和逐个单词逆置,注意处理边界条件和特殊情况。接着,另一段代码演示了如何统计数组中升序子数组的个数,同样需要考虑不同情况的边界处理。这两部分代码都涉及到常见的编程问题和解决策略。
摘要由CSDN通过智能技术生成

在这里插入图片描述
只要产生新的对象,==一定不成立
在这里插入图片描述

在这里插入图片描述
引用对象test为null,直接调用成员方法会报错,但此时方法是一个静态方法,不依赖于对象,所以能编译通过
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
必须放在子类构造方法的第一行,否则会报错
在这里插入图片描述
在这里插入图片描述
this和super是绝对不能出现在同一个构造方法中的,因为他们都要在第一行
在这里插入图片描述
this和super都和对象有关,static是不依赖于对象的,所以肯定不能在静态环境下使用this和super关键字
在这里插入图片描述
在这里插入图片描述
不管是静态方法还是普通方法都不能定义静态变量。静态变量只能定义在类中
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
可以修饰类和方法,但不能修饰字段
在这里插入图片描述
不可以加{},{}大括号代表已经实现了方法,必须没有{}大括号。普通方法可以加大括号
在这里插入图片描述
可以省略编译器默认是无参构造
构造方法也是一种方法,所以是可以与类同名(易错点)
构造方法可以重载
在这里插入图片描述
A:抽象方法正确
B:运算只能在方法中进行
C:是普通方法,且没加{}
D:抽象方法不可以加{}

编程题

在这里插入图片描述
思路:
1.整体逆置
2.逐个单词逆置
在这里插入图片描述
边界条件:
1.当j走到最后一个单词如何处理
2.当逆置的单词只有一个时如何处理
在这里插入图片描述
易错点:
最后的输出格式是String类型,不能直接把数组toString,否则报错
在这里插入图片描述

import java.util.*;
public class Main {
    public static void reverse(char[] c,int left,int right){
        while(left<right){
            char tmp=c[left];
            c[left]=c[right];
            c[right]=tmp;
            left++;
            right--;
        }
    }

    public static void main(String[] args){
        Scanner sc=new Scanner(System.in);
        String s=sc.nextLine();
        //1.字符串整体逆置
        char[] c=s.toCharArray();
        int len=c.length;
        reverse(c,0,len-1);
        //2.对每个单词逆置
        //用于遍历数组
        int i=0;
        while(i<c.length){
            //易错点,每次逆置完一个单词一定要让j=i,否则j一直位于空格处死循环
            int j=i;
            while(j<c.length&&c[j]!=' '){
                j++;
            }
            //此时j索引一定位于空格处或者整个数组的length位置(数组的末尾)
            //所以有两种情况的处理
            if(j<c.length){
                reverse(c,i,j-1);
                i=j+1;
            }else{
                reverse(c,i,j-1);
                //退出循环的条件,此时j一定位于length
                i=j;
            }
        }
        String str=new String(c);
        System.out.println(str);
    }
}

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

import java.util.*;
public class Main {
    public static void main(String[] args){
        Scanner sc=new Scanner(System.in);
        int num=sc.nextInt();
        //防止数组越界,长度+1
        int[] data=new int[num+1];
        for(int i=0;i<num;i++){
            data[i]=sc.nextInt();
        }
        int count=0;
        int i=0;
        //遍历数组,可能出现三种情况
        //大于 等于 小于
        while(i<num){
            if(data[i]<data[i+1]){
                //可能出现前一个元素一直大于后一个元素
                //需要控制i的取值,防止越界
                while(i<num&&data[i]<data[i+1]){
                    i++;
                }
                //出现反例,子数组+1
                count++;
                i++;
            }else if(data[i]==data[i+1]){
                i++;
            }else{
                while(i<num&&data[i]>data[i+1]){
                    i++;
                }
                //同理,出现反例
                count++;
                i++;
            }
        }
        System.out.print(count);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值