需要将Median和Standard Deviation添加到以下程序中,但我不知道从哪里开始,我知道我想要它做什么,但我不知道如何实现它,特别是因为中位数必须在排序的数字,但如果我把它作为void Median(),我松散排序的数组。请帮忙!非常感谢任何帮助:
import java.util.Scanner;
import javax.swing.*;
public class JScannerO
{
public JScannerO(){}
public JScannerO(int A)
{
HowMuch = A;
}
void GenerateNumbers()
{
int k,Hide;
k = 0;
while ( k < HowMuch )
{
Hide = (int) (Math.random() * 100);
if ( Hide > 9 && Hide < 100 )
{
Hanson[k] = Hide;
k++;
}
}
}
void DisplayNumbers()
{
int k;
for ( k = 0; k < HowMuch; k++)
{
System.out.println("\t\tThe numbers are : " + Hanson[k]);
}
}
void BiggestNumber()
{
int k,Biggest;
Biggest = Hanson[0];
for ( k = 0; k < HowMuch; k++)
{
if ( Biggest < Hanson[k] ) Biggest = Hanson[k];
}
System.out.println("\n\n\t\tThe biggest number is : " + Biggest);
}
void SmallestNumber()
{
int k,Smallest;
Smallest = Hanson[0];
for ( k = 0; k < HowMuch; k++)
{
if ( Smallest > Hanson[k] ) Smallest = Hanson[k];
}
System.out.println("\n\n\t\tThe Smallest number is : " + Smallest);
}
void Average()
{
int k,Sum;
double Average;
Sum = 0;
for ( k = 0; k < HowMuch; k++)
{
Sum = Sum + Hanson[k];
}
Average = 1.0 * Sum / HowMuch;
System.out.format("\n\n\t\tThe Average number is : %7.2f",Average);
}
void Sort()
{
int k,Hide;
boolean DidISwap;
DidISwap = true;
while (DidISwap)
{
DidISwap = false;
for ( k = 0; k < HowMuch - 1; k++)
{
if ( Hanson[k] > Hanson[k+1] )
{
Hide = Hanson[k ];
Hanson[k] = Hanson[k+1];
Hanson[k+1] = Hide ;
DidISwap = true;
}
}
}
System.out.println("\n\n\n\t\tThe Sorted Numbers : \n");
}
private int HowMuch;
private int[] Hanson = new int[100];
}
这是通过使用调用程序
运行的答案 0 :(得分:0)
我不明白你的问题。
你有一个排序算法可以帮你完成工作!
你不能只写一个
public int median() {
Sort();
return Hanson[Math.floor(Hanson/2)];
}
这将花费你O(N)而不是O(1),但它不容易出错并做你需要做的事 - 特别是因为你的“Hanson”阵列只有100,所以我们可以不关心在这一点上。
作为最后的评论:函数名总是在较低的camelCase中,即它是sort()而不是Sort(),它是calculateSomething()而不是Calculate_Something()或任何其他变体。
此规则没有例外,这将使您的代码(更多)更具可读性。考虑在Eclipse中安装CheckStyle(http://eclipse-cs.sourceforge.net/),以便在编写时提供样式的交互式指南: - )