题解 | #乘积为整数的最长连续子数组#

乘积为整数的最长连续子数组

http://www.nowcoder.com/practice/0112b9b5a09048d89309f55ea666db91

动态规划,同时维护最长连续正数和最长连续负数
import java.util.*;
public class Main{
    public static void main(String []args){
        Scanner input=new Scanner(System.in);
        int n=input.nextInt();
        int []num=new int[n];
        for(int i=0;i<n;i++){
            num[i]=input.nextInt();
        }
        int [][]dp=new int[n+1][2];
        int max=0;
        dp[0][0]=0;
        dp[0][1]=0;
        for(int i=1;i<=n;i++){
           int val=num[i-1];
            if(val>0){
                dp[i][0]=dp[i-1][0]+1;
                if(dp[i-1][1]==0){
                    dp[i][1]=0;
                }
                else{
                    dp[i][1]=dp[i-1][1]+1;
                }
            }
            else if(val<0){   //交叉更新
                dp[i][1]=dp[i-1][0]+1;
                if(dp[i-1][1]==0){
                    dp[i][0]=0;
                }
                else{
                    dp[i][0]=dp[i-1][1]+1;
                }
            }
        }
            
        for(int i=1;i<=n;i++){
            max=Math.max(max,dp[i][0]);
        }
         System.out.println(max);
    }
}


全部评论
妙啊
点赞 回复 分享
发布于 2024-04-09 01:37 广东
看不懂...
点赞 回复 分享
发布于 2022-03-29 18:10

相关推荐

代码飞升AL:同学院本 你这都是无效实习和跳槽 下一段底线是去一个稍微知名的公司 本质是骑驴找马 你这一直骑驴换来换去没什么区别
双非有机会进大厂吗
点赞 评论 收藏
分享
码客明:我教你个方法,你和你室友沟通一下告知他这个事情。然后就说导员问我就说,室友已经和导员提前沟通了。最后被查到你就说室友和我说了他已经和你沟通好了我没想到他是骗我的呀!把责任都甩给你室友,当然你出去实习的室友也肯定愿意承担这个责任。
点赞 评论 收藏
分享
评论
4
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务