java中如何求一个数组中元素的和.

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java中如何求一个数组中元素的和.相关的知识,希望对你有一定的参考价值。

问题为:怎么从一个数组中提取元素,求每个元素的和,平方,等等

import java.util.Scanner;

public class XiTi464 
    public static void main(String[] args) 
        Scanner sr = new Scanner(System.in);
        System.out.print("输入数组元素个数:");
        int a = sr.nextInt();
        int score[] = new int[a];
        for (int i = 0; i < a; i++) 
            System.out.print("输入第" + (i + 1) + "个值:");
            score[i] = sr.nextInt();
        
        int sum = arrSum(score);
        int max = arrMax(score);
        int min = arrMin(score);
        System.out.println("数组元素之和:" + sum);
        System.out.println("数组元素中最大值:" + max);
        System.out.println("数组元素中最小值:" + min);
        sr.close();
    
    public static int arrSum(int arr[]) 
        int temp = 0;
        for (int i = 0; i < arr.length; i++) 
            temp += arr[i];
        
        return temp;
    
    public static int arrMax(int arr[]) 
        int temp = arr[0];
        for (int i = 1; i < arr.length; i++) 
            if (temp < arr[i])
                temp = arr[i];
        
        return temp;
    
    public static int arrMin(int arr[]) 
        int temp = arr[0];
        for (int i = 1; i < arr.length; i++) 
            if (temp > arr[i])    
                temp = arr[i];
        
        return temp;
    

参考技术A int sum=0;
int sum1=0;
for(int i=0;i<数组.length;i++)
sum+=数组[i];

sum1=sum*sum;
System.out.print(sum);//和
System.out.print(sum1);//和的平方
参考技术B int sum=0;
int sum1=0;
for(int i=0;i<数组.length;i++)
sum+=数组[i];

sum1=sum*sum;
System.out.print(sum);//和
System.out.print(sum1);//和的平方
参考技术C int[] arr=1,2,3,4,5,6……;
for(int i:arr)

里面写求和,平方等等公式


注:JDK为5.0
参考技术D 这你都要问

返回一个整数数组中最大子数组的和

1、题目:返回一个整数数组中最大子数组的和。

 

2、要求:

  要求程序必须能处理1000 个元素;

  每个元素是int32 类型的;

  输入一个整形数组,数组里有正数也有负数。

  数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和。

  求所有子数组的和的最大值。要求时间复杂度为O(n)。 

3、设计思路:

  将数组大小定义为1000,对于每个元素定义为int32类型,当我们需要他整型数组越界即超过其最大的范围2^32=4294967296,我们便将数组乘以4294967296,使数组内的元素可以越界;当不需要越界时删掉它。

4、程序代码:

#include "stdafx.h"

 

int _tmain(int argc, _TCHAR* argv[])

{

 return 0;

}

 #include <iostream>

 #include<stdlib.h>

 #include<time.h>

 using namespace std;

 

 int main()

 {

     int i;

    int a[1000];

     int max = 0;

     int b = 0;

 

    srand(time(NULL));

     cout<<"数组为:"<<endl;

    for (i = 0; i<1000; i++)

     {

         a[i] = rand()*4294967296;

     }

     for (i = 0; i<1000; i++)

     {

         cout << a[i] << \'\\t\';

     }

     cout << endl;

 

     for (i = 0; i < 1000; i++)

     {

         b += a[i];

         if (b < 0)

             b = 0;

         if (b > max)

             max = b;

     }

     if (max == 0)

     {

         max = a[0];

         for (i = 0; i < 1000; i++)

         {

             if (max < a[i])

             {

                max = a[i];

             }

         }    

     }

     cout <<"最大子数组为:"<< max << endl;

     system("pause");

     return 0;

 }

5、运行结果

               当子数组之和超过int32最大范围时,其显示结果都为0.

            当不超过时,显示结果正常。

6、总结

         通过此次实验,我们得知了当元素数组越界时程序并不是不运行,而是显示的所有结果都为0.同时,由于此次只是用了简单的for循环,使得复杂度高,运行时间长,这也使我们认识到了算法的重要性。

7、照片

以上是关于java中如何求一个数组中元素的和.的主要内容,如果未能解决你的问题,请参考以下文章

一维数组求最大子数组的和(首位相邻32位)

用python 求一个数组中最大的三个元素及其所在位置

求一个整数数组中最大子数组的和

返回一个二维整数数组中最大子数组的和

返回一个二维整数数组中最大子数组的和

求一个有一千个元素的整数数组的最大子数组的和