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中如何求一个数组中元素的和.的主要内容,如果未能解决你的问题,请参考以下文章