zoukankan      html  css  js  c++  java
  • 课堂练习

    思路:

             求循环数组的最大子数组,相当于将数组重复两遍,然后再求出这个重复两遍的数组求出它的最大子数组即可。这个题目的实质是弄清楚循环数组求最大子数组即是讲所有数组重复一遍然后再用一般的方法求最大子数组。

    具体代码:

    package example1;
    
    import java.util.Scanner;
    public class example1 {
        public static void main(String args[]){
            int num;
            Scanner in = new Scanner(System.in);
            System.out.println("输入数组中元素的个数:");
            num = in.nextInt();
            int []a = new int[num]; //定义数组a
            for(int i = 0;i < num;i ++)
            {
                a[i] = (int)(Math.random()*30 - 10); //产生的随机数范围在-10 - 10
            }
            System.out.println("产生的数组元素的值为:");  
            for(int i = 0;i < num;i ++){
                System.out.print(a[i] + " ");
            }
            System.out.print("
    ");
            int []b = new int[a.length*2];  //定义一个数组b,b中的元素为a中元素重复两次
            System.out.println("生成的环形数组为:");
            for(int i = 0;i < b.length;i ++){
                b[i] = a[i % a.length];
                System.out.print(b[i] + " ");
            }
            System.out.print("
    ");
             
            int sum = b[0],temp = b[0];//将数组最大值初始为b数组中第一个元素
            int s = 0;
            int i = 1;
            while(i < b.length / 2 + s)
            { 
                temp = temp + b[i];
                if(temp < b[i])
                {
                    temp = b[i];
                    s = i;
                }
                if(temp > sum)
                {
                    sum = temp;
                }
                i ++;
            }
            System.out.println("最大的子数组为:" + sum);
        }  
    }

    运行截图:

                                                                        

  • 相关阅读:
    asp.net中插件开发模式说明
    Url路径重写的原理
    Linux上搭建各种环境(一)
    常见Post提交数据方式接口测试
    Jmeter4.0----CSV Data Set Config_使用表格进行参数化(22)
    弱网测试----App
    性能测试基础
    使用fiddler实现手机抓包
    Jmeter4.0----发送邮箱之SMTP Sampler(21)
    Jmeter4.0----发送测试结果到邮箱之邮件观察仪(20)
  • 原文地址:https://www.cnblogs.com/overs/p/6652992.html
Copyright © 2011-2022 走看看