initial setup
This commit is contained in:
commit
9b58a62f9e
57
README.md
Normal file
57
README.md
Normal file
@ -0,0 +1,57 @@
|
||||
# README #
|
||||
|
||||
See on esimese kodutöö failide hoidla, mida saab kasutada ainult algseks lugemiseks.
|
||||
Töötamiseks looge endale isiklik repositoorium, näiteks (privaatne) 'fork' bitbucket serverisse, millest saate luua klooni oma arvutisse.
|
||||
|
||||
## Näidete kasutamine käsurealt ##
|
||||
#### Kompileerimine: ####
|
||||
|
||||
```
|
||||
#!bash
|
||||
|
||||
javac -cp src src/Balls.java
|
||||
```
|
||||
|
||||
#### Käivitamine: ####
|
||||
|
||||
```
|
||||
#!bash
|
||||
|
||||
java -cp src Balls
|
||||
```
|
||||
|
||||
|
||||
### Testide kasutamine ###
|
||||
#### Testi kompileerimine: ####
|
||||
|
||||
```
|
||||
#!bash
|
||||
|
||||
javac -encoding utf8 -cp 'src:test:test/junit-4.12.jar:test/hamcrest-core-1.3.jar' test/BallsTest.java
|
||||
|
||||
```
|
||||
Sama Windows aknas (koolonite asemel peavad olema semikoolonid):
|
||||
|
||||
```
|
||||
#!bash
|
||||
|
||||
javac -encoding utf8 -cp 'src;test;test/junit-4.12.jar;test/hamcrest-core-1.3.jar' test/BallsTest.java
|
||||
|
||||
|
||||
```
|
||||
|
||||
#### Testi käivitamine: ####
|
||||
|
||||
```
|
||||
#!bash
|
||||
|
||||
java -cp 'src:test:test/junit-4.12.jar:test/hamcrest-core-1.3.jar' org.junit.runner.JUnitCore BallsTest
|
||||
```
|
||||
|
||||
Sama Windows aknas (koolonite asemel semikoolonid):
|
||||
|
||||
```
|
||||
#!bash
|
||||
|
||||
java -cp 'src;test;test/junit-4.12.jar;test/hamcrest-core-1.3.jar' org.junit.runner.JUnitCore BallsTest
|
||||
```
|
21
description.html
Normal file
21
description.html
Normal file
@ -0,0 +1,21 @@
|
||||
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
|
||||
<html>
|
||||
<head>
|
||||
<meta content="text/html; charset=UTF-8" http-equiv="Content-Type">
|
||||
<title>Balls</title>
|
||||
</head>
|
||||
<body>
|
||||
<p>
|
||||
Olgu massiivis juhuslikult läbisegi punased ja rohelised pallid. Koostage võimalikult kiire meetod, mis järjestaks massiivi ümber nii, et kõik punased pallid oleksid massiivi alguses ja kõik rohelised pallid lõpus. Arvestage ka piirjuhtumiga, et kõik pallid on üht värvi.
|
||||
</p>
|
||||
<p>
|
||||
An array contains red and green balls in random order. Write a possibly fast method to rearrange the array, so that all red balls are at the beginning and all green balls are at the end of the array. Consider the case when all balls have the same color.
|
||||
</p>
|
||||
<pre>
|
||||
enum Color {green, red};
|
||||
</pre>
|
||||
<pre>
|
||||
public static void reorder (Color[] balls)
|
||||
</pre>
|
||||
</body>
|
||||
</html>
|
19
git_eclipse.txt
Normal file
19
git_eclipse.txt
Normal file
@ -0,0 +1,19 @@
|
||||
|
||||
Ava Eclipse ja veendu, et egit-moodul on olemas, vajadusel lisa see Eclipse Marketplace kaudu.
|
||||
|
||||
Lisa projekti vaatesse git repositooriumite aken:
|
||||
Window -> Show View -> Other... -> Git -> Git Repositories
|
||||
|
||||
Git Repositories aknas klooni vajalik repositoorium bitbucket-ist.
|
||||
|
||||
Loo Java projekt.
|
||||
|
||||
Kustuta src kataloog.
|
||||
|
||||
vali "Build Path -> Link Source" ja seo projekti source kloonimisest tekkinud
|
||||
lokaalse repositooriumiga, pane Eclipse projektis selle kataloogi nimeks src.
|
||||
|
||||
kui on kasutusel test-kataloog, siis lingi ka see ja pane nimeks test.
|
||||
|
||||
Majanda versioonihaldusega ainult git repositooriumite aknas.
|
||||
|
14
src/Balls.java
Normal file
14
src/Balls.java
Normal file
@ -0,0 +1,14 @@
|
||||
|
||||
public class Balls {
|
||||
|
||||
enum Color {green, red};
|
||||
|
||||
public static void main (String[] param) {
|
||||
// for debugging
|
||||
}
|
||||
|
||||
public static void reorder (Color[] balls) {
|
||||
// TODO!!! Your program here
|
||||
}
|
||||
}
|
||||
|
552
src/TextIO.java
Normal file
552
src/TextIO.java
Normal file
@ -0,0 +1,552 @@
|
||||
|
||||
/*
|
||||
The file defines a class TextIO, which provides a simple interface
|
||||
to Java's standard console input and output. This class defines
|
||||
several static methods for reading and writing
|
||||
values of various type.
|
||||
|
||||
This class will only work with standard, interactive applications.
|
||||
When it is used in such an application, System.out and System.in
|
||||
should not be used directly, since the TextIO class thinks it has
|
||||
exclusive control of System.out and System.in. (Actually, using
|
||||
System.out will probably not cause any problems, but don't use
|
||||
System.in.)
|
||||
|
||||
To use this class in your program, simply include the compiled class
|
||||
file TextIO.class in the same directory with the class file for your
|
||||
main program. (If you are using a development environment such as
|
||||
CodeWarrior or Visual J++, you can include the source file,
|
||||
TextIO.java in your project.) You can then use all the public static methods
|
||||
from the TextIO class in your program. (In your programs, the names
|
||||
of the methods must be prefaced with "TextIO." For example, you should
|
||||
use the name TextIO.getln() rather than simply getln().)
|
||||
|
||||
(This class is for use with my on-line introductory java textbook,
|
||||
which is available at http://math.hws.edu/eck/cs124/notes/index.html.)
|
||||
|
||||
Written by: David Eck
|
||||
Department of Mathematics and Computer Science
|
||||
Hobart and William Smith Colleges
|
||||
Geneva, NY 14456
|
||||
Email: eck@hws.edu
|
||||
WWW: http://math.hws.edu/eck/
|
||||
|
||||
July 16, 1998
|
||||
|
||||
Modified February, 2000; getChar() now skips blanks and CR's, and getAnyChar()
|
||||
can be used to read the next char even if it's a blank or CR.
|
||||
|
||||
*/
|
||||
import java.io.*;
|
||||
|
||||
public class TextIO {
|
||||
|
||||
// *************************** I/O Methods *********************************
|
||||
|
||||
// Methods for writing the primitive types, plus type String,
|
||||
// to the console, with no extra spaces.
|
||||
//
|
||||
// Note that the real-number data types, float
|
||||
// and double, a rounded version is output that will
|
||||
// use at most 10 or 11 characters. If you want to
|
||||
// output a real number with full accuracy, use
|
||||
// "TextIO.put(String.valueOf(x))", for example.
|
||||
|
||||
public static void put(int x) { put(x,0); } // Note: also handles byte and short!
|
||||
public static void put(long x) { put(x,0); }
|
||||
public static void put(double x) { put(x,0); } // Also handles float.
|
||||
public static void put(char x) { put(x,0); }
|
||||
public static void put(boolean x) { put(x,0); }
|
||||
public static void put(String x) { put(x,0); }
|
||||
|
||||
|
||||
// Methods for writing the primitive types, plus type String,
|
||||
// to the console,followed by a carriage return, with
|
||||
// no extra spaces.
|
||||
|
||||
public static void putln(int x) { put(x,0); newLine(); } // Note: also handles byte and short!
|
||||
public static void putln(long x) { put(x,0); newLine(); }
|
||||
public static void putln(double x) { put(x,0); newLine(); } // Also handles float.
|
||||
public static void putln(char x) { put(x,0); newLine(); }
|
||||
public static void putln(boolean x) { put(x,0); newLine(); }
|
||||
public static void putln(String x) { put(x,0); newLine(); }
|
||||
|
||||
|
||||
// Methods for writing the primitive types, plus type String,
|
||||
// to the console, with a minimum field width of w,
|
||||
// and followed by a carriage return.
|
||||
// If output value is less than w characters, it is padded
|
||||
// with extra spaces in front of the value.
|
||||
|
||||
public static void putln(int x, int w) { put(x,w); newLine(); } // Note: also handles byte and short!
|
||||
public static void putln(long x, int w) { put(x,w); newLine(); }
|
||||
public static void putln(double x, int w) { put(x,w); newLine(); } // Also handles float.
|
||||
public static void putln(char x, int w) { put(x,w); newLine(); }
|
||||
public static void putln(boolean x, int w) { put(x,w); newLine(); }
|
||||
public static void putln(String x, int w) { put(x,w); newLine(); }
|
||||
|
||||
|
||||
// Method for outputting a carriage return
|
||||
|
||||
public static void putln() { newLine(); }
|
||||
|
||||
|
||||
// Methods for writing the primitive types, plus type String,
|
||||
// to the console, with minimum field width w.
|
||||
|
||||
public static void put(int x, int w) { dumpString(String.valueOf(x), w); } // Note: also handles byte and short!
|
||||
public static void put(long x, int w) { dumpString(String.valueOf(x), w); }
|
||||
public static void put(double x, int w) { dumpString(realToString(x), w); } // Also handles float.
|
||||
public static void put(char x, int w) { dumpString(String.valueOf(x), w); }
|
||||
public static void put(boolean x, int w) { dumpString(String.valueOf(x), w); }
|
||||
public static void put(String x, int w) { dumpString(x, w); }
|
||||
|
||||
|
||||
// Methods for reading in the primitive types, plus "words" and "lines".
|
||||
// The "getln..." methods discard any extra input, up to and including
|
||||
// the next carriage return.
|
||||
// A "word" read by getlnWord() is any sequence of non-blank characters.
|
||||
// A "line" read by getlnString() or getln() is everything up to next CR;
|
||||
// the carriage return is not part of the returned value, but it is
|
||||
// read and discarded.
|
||||
// Note that all input methods except getAnyChar(), peek(), the ones for lines
|
||||
// skip past any blanks and carriage returns to find a non-blank value.
|
||||
// getln() can return an empty string; getChar() and getlnChar() can
|
||||
// return a space or a linefeed ('\n') character.
|
||||
// peek() allows you to look at the next character in input, without
|
||||
// removing it from the input stream. (Note that using this
|
||||
// routine might force the user to enter a line, in order to
|
||||
// check what the next character is.)
|
||||
// Acceptable boolean values are the "words": true, false, t, f, yes,
|
||||
// no, y, n, 0, or 1; uppercase letters are OK.
|
||||
// None of these can produce an error; if an error is found in input,
|
||||
// the user is forced to re-enter.
|
||||
// Available input routines are:
|
||||
//
|
||||
// getByte() getlnByte() getShort() getlnShort()
|
||||
// getInt() getlnInt() getLong() getlnLong()
|
||||
// getFloat() getlnFloat() getDouble() getlnDouble()
|
||||
// getChar() getlnChar() peek() getAnyChar()
|
||||
// getWord() getlnWord() getln() getString() getlnString()
|
||||
//
|
||||
// (getlnString is the same as getln and is only provided for consistency.)
|
||||
|
||||
public static byte getlnByte() { byte x=getByte(); emptyBuffer(); return x; }
|
||||
public static short getlnShort() { short x=getShort(); emptyBuffer(); return x; }
|
||||
public static int getlnInt() { int x=getInt(); emptyBuffer(); return x; }
|
||||
public static long getlnLong() { long x=getLong(); emptyBuffer(); return x; }
|
||||
public static float getlnFloat() { float x=getFloat(); emptyBuffer(); return x; }
|
||||
public static double getlnDouble() { double x=getDouble(); emptyBuffer(); return x; }
|
||||
public static char getlnChar() { char x=getChar(); emptyBuffer(); return x; }
|
||||
public static boolean getlnBoolean() { boolean x=getBoolean(); emptyBuffer(); return x; }
|
||||
public static String getlnWord() { String x=getWord(); emptyBuffer(); return x; }
|
||||
public static String getlnString() { return getln(); } // same as getln()
|
||||
public static String getln() {
|
||||
StringBuffer s = new StringBuffer(100);
|
||||
char ch = readChar();
|
||||
while (ch != '\n') {
|
||||
s.append(ch);
|
||||
ch = readChar();
|
||||
}
|
||||
return s.toString();
|
||||
}
|
||||
|
||||
|
||||
public static byte getByte() { return (byte)readInteger(-128L,127L); }
|
||||
public static short getShort() { return (short)readInteger(-32768L,32767L); }
|
||||
public static int getInt() { return (int)readInteger((long)Integer.MIN_VALUE, (long)Integer.MAX_VALUE); }
|
||||
public static long getLong() { return readInteger(Long.MIN_VALUE, Long.MAX_VALUE); }
|
||||
|
||||
public static char getAnyChar(){ return readChar(); }
|
||||
public static char peek() { return lookChar(); }
|
||||
|
||||
public static char getChar() { // skip spaces & cr's, then return next char
|
||||
char ch = lookChar();
|
||||
while (ch == ' ' || ch == '\n') {
|
||||
readChar();
|
||||
if (ch == '\n')
|
||||
dumpString("? ",0);
|
||||
ch = lookChar();
|
||||
}
|
||||
return readChar();
|
||||
}
|
||||
|
||||
public static float getFloat() {
|
||||
float x = 0.0F;
|
||||
while (true) {
|
||||
String str = readRealString();
|
||||
if (str.equals("")) {
|
||||
errorMessage("Illegal floating point input.",
|
||||
"Real number in the range " + Float.MIN_VALUE + " to " + Float.MAX_VALUE);
|
||||
}
|
||||
else {
|
||||
Float f = null;
|
||||
try { f = Float.valueOf(str); }
|
||||
catch (NumberFormatException e) {
|
||||
errorMessage("Illegal floating point input.",
|
||||
"Real number in the range " + Float.MIN_VALUE + " to " + Float.MAX_VALUE);
|
||||
continue;
|
||||
}
|
||||
if (f.isInfinite()) {
|
||||
errorMessage("Floating point input outside of legal range.",
|
||||
"Real number in the range " + Float.MIN_VALUE + " to " + Float.MAX_VALUE);
|
||||
continue;
|
||||
}
|
||||
x = f.floatValue();
|
||||
break;
|
||||
}
|
||||
}
|
||||
return x;
|
||||
}
|
||||
|
||||
public static double getDouble() {
|
||||
double x = 0.0;
|
||||
while (true) {
|
||||
String str = readRealString();
|
||||
if (str.equals("")) {
|
||||
errorMessage("Illegal floating point input",
|
||||
"Real number in the range " + Double.MIN_VALUE + " to " + Double.MAX_VALUE);
|
||||
}
|
||||
else {
|
||||
Double f = null;
|
||||
try { f = Double.valueOf(str); }
|
||||
catch (NumberFormatException e) {
|
||||
errorMessage("Illegal floating point input",
|
||||
"Real number in the range " + Double.MIN_VALUE + " to " + Double.MAX_VALUE);
|
||||
continue;
|
||||
}
|
||||
if (f.isInfinite()) {
|
||||
errorMessage("Floating point input outside of legal range.",
|
||||
"Real number in the range " + Double.MIN_VALUE + " to " + Double.MAX_VALUE);
|
||||
continue;
|
||||
}
|
||||
x = f.doubleValue();
|
||||
break;
|
||||
}
|
||||
}
|
||||
return x;
|
||||
}
|
||||
|
||||
public static String getWord() {
|
||||
char ch = lookChar();
|
||||
while (ch == ' ' || ch == '\n') {
|
||||
readChar();
|
||||
if (ch == '\n')
|
||||
dumpString("? ",0);
|
||||
ch = lookChar();
|
||||
}
|
||||
StringBuffer str = new StringBuffer(50);
|
||||
while (ch != ' ' && ch != '\n') {
|
||||
str.append(readChar());
|
||||
ch = lookChar();
|
||||
}
|
||||
return str.toString();
|
||||
}
|
||||
|
||||
public static boolean getBoolean() {
|
||||
boolean ans = false;
|
||||
while (true) {
|
||||
String s = getWord();
|
||||
if ( s.equalsIgnoreCase("true") || s.equalsIgnoreCase("t") ||
|
||||
s.equalsIgnoreCase("yes") || s.equalsIgnoreCase("y") ||
|
||||
s.equals("1") ) {
|
||||
ans = true;
|
||||
break;
|
||||
}
|
||||
else if ( s.equalsIgnoreCase("false") || s.equalsIgnoreCase("f") ||
|
||||
s.equalsIgnoreCase("no") || s.equalsIgnoreCase("n") ||
|
||||
s.equals("0") ) {
|
||||
ans = false;
|
||||
break;
|
||||
}
|
||||
else
|
||||
errorMessage("Illegal boolean input value.",
|
||||
"one of: true, false, t, f, yes, no, y, n, 0, or 1");
|
||||
}
|
||||
return ans;
|
||||
}
|
||||
|
||||
// ***************** Everything beyond this point is private *******************
|
||||
|
||||
// ********************** Utility routines for input/output ********************
|
||||
|
||||
private static InputStream in = System.in; // rename standard input stream
|
||||
private static PrintStream out = System.out; // rename standard output stream
|
||||
|
||||
private static String buffer = null; // one line read from input
|
||||
private static int pos = 0; // position of next char in input line that has
|
||||
// not yet been processed
|
||||
|
||||
|
||||
private static String readRealString() { // read chars from input following syntax of real numbers
|
||||
StringBuffer s=new StringBuffer(50);
|
||||
char ch=lookChar();
|
||||
while (ch == ' ' || ch == '\n') {
|
||||
readChar();
|
||||
if (ch == '\n')
|
||||
dumpString("? ",0);
|
||||
ch = lookChar();
|
||||
}
|
||||
if (ch == '-' || ch == '+') {
|
||||
s.append(readChar());
|
||||
ch = lookChar();
|
||||
while (ch == ' ') {
|
||||
readChar();
|
||||
ch = lookChar();
|
||||
}
|
||||
}
|
||||
while (ch >= '0' && ch <= '9') {
|
||||
s.append(readChar());
|
||||
ch = lookChar();
|
||||
}
|
||||
if (ch == '.') {
|
||||
s.append(readChar());
|
||||
ch = lookChar();
|
||||
while (ch >= '0' && ch <= '9') {
|
||||
s.append(readChar());
|
||||
ch = lookChar();
|
||||
}
|
||||
}
|
||||
if (ch == 'E' || ch == 'e') {
|
||||
s.append(readChar());
|
||||
ch = lookChar();
|
||||
if (ch == '-' || ch == '+') {
|
||||
s.append(readChar());
|
||||
ch = lookChar();
|
||||
}
|
||||
while (ch >= '0' && ch <= '9') {
|
||||
s.append(readChar());
|
||||
ch = lookChar();
|
||||
}
|
||||
}
|
||||
return s.toString();
|
||||
}
|
||||
|
||||
private static long readInteger(long min, long max) { // read long integer, limited to specified range
|
||||
long x=0;
|
||||
while (true) {
|
||||
StringBuffer s=new StringBuffer(34);
|
||||
char ch=lookChar();
|
||||
while (ch == ' ' || ch == '\n') {
|
||||
readChar();
|
||||
if (ch == '\n')
|
||||
dumpString("? ",0);
|
||||
ch = lookChar();
|
||||
}
|
||||
if (ch == '-' || ch == '+') {
|
||||
s.append(readChar());
|
||||
ch = lookChar();
|
||||
while (ch == ' ') {
|
||||
readChar();
|
||||
ch = lookChar();
|
||||
}
|
||||
}
|
||||
while (ch >= '0' && ch <= '9') {
|
||||
s.append(readChar());
|
||||
ch = lookChar();
|
||||
}
|
||||
if (s.equals("")){
|
||||
errorMessage("Illegal integer input.",
|
||||
"Integer in the range " + min + " to " + max);
|
||||
}
|
||||
else {
|
||||
String str = s.toString();
|
||||
try {
|
||||
x = Long.parseLong(str);
|
||||
}
|
||||
catch (NumberFormatException e) {
|
||||
errorMessage("Illegal integer input.",
|
||||
"Integer in the range " + min + " to " + max);
|
||||
continue;
|
||||
}
|
||||
if (x < min || x > max) {
|
||||
errorMessage("Integer input outside of legal range.",
|
||||
"Integer in the range " + min + " to " + max);
|
||||
continue;
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
return x;
|
||||
}
|
||||
|
||||
private static String realToString(double x) {
|
||||
// Goal is to get a reasonable representation of x in at most
|
||||
// 10 characters, or 11 characters if x is negative.
|
||||
if (Double.isNaN(x))
|
||||
return "undefined";
|
||||
if (Double.isInfinite(x))
|
||||
if (x < 0)
|
||||
return "-INF";
|
||||
else
|
||||
return "INF";
|
||||
if (Math.abs(x) <= 5000000000.0 && Math.rint(x) == x)
|
||||
return String.valueOf( (long)x );
|
||||
String s = String.valueOf(x);
|
||||
if (s.length() <= 10)
|
||||
return s;
|
||||
boolean neg = false;
|
||||
if (x < 0) {
|
||||
neg = true;
|
||||
x = -x;
|
||||
s = String.valueOf(x);
|
||||
}
|
||||
if (x >= 0.00005 && x <= 50000000 && (s.indexOf('E') == -1 && s.indexOf('e') == -1)) { // trim x to 10 chars max
|
||||
s = round(s,10);
|
||||
s = trimZeros(s);
|
||||
}
|
||||
else if (x > 1) { // construct exponential form with positive exponent
|
||||
long power = (long)Math.floor(Math.log(x)/Math.log(10));
|
||||
String exp = "E" + power;
|
||||
int numlength = 10 - exp.length();
|
||||
x = x / Math.pow(10,power);
|
||||
s = String.valueOf(x);
|
||||
s = round(s,numlength);
|
||||
s = trimZeros(s);
|
||||
s += exp;
|
||||
}
|
||||
else { // constuct exponential form
|
||||
long power = (long)Math.ceil(-Math.log(x)/Math.log(10));
|
||||
String exp = "E-" + power;
|
||||
int numlength = 10 - exp.length();
|
||||
x = x * Math.pow(10,power);
|
||||
s = String.valueOf(x);
|
||||
s = round(s,numlength);
|
||||
s = trimZeros(s);
|
||||
s += exp;
|
||||
}
|
||||
if (neg)
|
||||
return "-" + s;
|
||||
else
|
||||
return s;
|
||||
}
|
||||
|
||||
private static String trimZeros(String num) { // used by realToString
|
||||
if (num.indexOf('.') >= 0 && num.charAt(num.length() - 1) == '0') {
|
||||
int i = num.length() - 1;
|
||||
while (num.charAt(i) == '0')
|
||||
i--;
|
||||
if (num.charAt(i) == '.')
|
||||
num = num.substring(0,i);
|
||||
else
|
||||
num = num.substring(0,i+1);
|
||||
}
|
||||
return num;
|
||||
}
|
||||
|
||||
private static String round(String num, int length) { // used by realToString
|
||||
if (num.indexOf('.') < 0)
|
||||
return num;
|
||||
if (num.length() <= length)
|
||||
return num;
|
||||
if (num.charAt(length) >= '5' && num.charAt(length) != '.') {
|
||||
char[] temp = new char[length+1];
|
||||
int ct = length;
|
||||
boolean rounding = true;
|
||||
for (int i = length-1; i >= 0; i--) {
|
||||
temp[ct] = num.charAt(i);
|
||||
if (rounding && temp[ct] != '.') {
|
||||
if (temp[ct] < '9') {
|
||||
temp[ct]++;
|
||||
rounding = false;
|
||||
}
|
||||
else
|
||||
temp[ct] = '0';
|
||||
}
|
||||
ct--;
|
||||
}
|
||||
if (rounding) {
|
||||
temp[ct] = '1';
|
||||
ct--;
|
||||
}
|
||||
// ct is -1 or 0
|
||||
return new String(temp,ct+1,length-ct);
|
||||
}
|
||||
else
|
||||
return num.substring(0,length);
|
||||
|
||||
}
|
||||
private static void dumpString(String str, int w) { // output string to console
|
||||
for (int i=str.length(); i<w; i++)
|
||||
out.print(' ');
|
||||
for (int i=0; i<str.length(); i++)
|
||||
if ((int)str.charAt(i) >= 0x20 && (int)str.charAt(i) != 0x7F) // no control chars or delete
|
||||
out.print(str.charAt(i));
|
||||
else if (str.charAt(i) == '\n' || str.charAt(i) == '\r')
|
||||
newLine();
|
||||
}
|
||||
|
||||
private static void errorMessage(String message, String expecting) {
|
||||
// inform user of error and force user to re-enter.
|
||||
newLine();
|
||||
dumpString(" *** Error in input: " + message + "\n", 0);
|
||||
dumpString(" *** Expecting: " + expecting + "\n", 0);
|
||||
dumpString(" *** Discarding Input: ", 0);
|
||||
if (lookChar() == '\n')
|
||||
dumpString("(end-of-line)\n\n",0);
|
||||
else {
|
||||
while (lookChar() != '\n')
|
||||
out.print(readChar());
|
||||
dumpString("\n\n",0);
|
||||
}
|
||||
dumpString("Please re-enter: ", 0);
|
||||
readChar(); // discard the end-of-line character
|
||||
}
|
||||
|
||||
private static char lookChar() { // return next character from input
|
||||
if (buffer == null || pos > buffer.length())
|
||||
fillBuffer();
|
||||
if (pos == buffer.length())
|
||||
return '\n';
|
||||
return buffer.charAt(pos);
|
||||
}
|
||||
|
||||
private static char readChar() { // return and discard next character from input
|
||||
char ch = lookChar();
|
||||
pos++;
|
||||
return ch;
|
||||
}
|
||||
|
||||
private static void newLine() { // output a CR to console
|
||||
out.println();
|
||||
out.flush();
|
||||
}
|
||||
|
||||
private static boolean possibleLinefeedPending = false;
|
||||
|
||||
private static void fillBuffer() { // Wait for user to type a line and press return,
|
||||
// and put the typed line into the buffer.
|
||||
StringBuffer b = new StringBuffer();
|
||||
out.flush();
|
||||
try {
|
||||
int ch = in.read();
|
||||
if (ch == '\n' && possibleLinefeedPending)
|
||||
ch = in.read();
|
||||
possibleLinefeedPending = false;
|
||||
while (ch != -1 && ch != '\n' && ch != '\r') {
|
||||
b.append((char)ch);
|
||||
ch = in.read();
|
||||
}
|
||||
possibleLinefeedPending = (ch == '\r');
|
||||
if (ch == -1) {
|
||||
System.out.println("\n*** Found an end-of-file while trying to read from standard input!");
|
||||
System.out.println("*** Maybe your Java system doesn't implement standard input?");
|
||||
System.out.println("*** Program will be terminated.\n");
|
||||
throw new RuntimeException("End-of-file on standard input.");
|
||||
}
|
||||
}
|
||||
catch (IOException e) {
|
||||
System.out.println("Unexpected system error on input.");
|
||||
System.out.println("Terminating program.");
|
||||
System.exit(1);
|
||||
}
|
||||
buffer = b.toString();
|
||||
pos = 0;
|
||||
}
|
||||
|
||||
private static void emptyBuffer() { // discard the rest of the current line of input
|
||||
buffer = null;
|
||||
}
|
||||
|
||||
|
||||
} // end of class TextIO
|
261
test/Aout.java
Normal file
261
test/Aout.java
Normal file
@ -0,0 +1,261 @@
|
||||
|
||||
/** Helper methods.
|
||||
* Arrays converted to array expressions (toString(...))
|
||||
* and prettyprinting (toPrettyString(...)).
|
||||
* @author Jaanus
|
||||
*/
|
||||
public class Aout {
|
||||
|
||||
/** Just testing. */
|
||||
public static void main (String[] args) {
|
||||
System.out.println (toString (new String[]
|
||||
{null, "", "0", "a\nb", " ", " ", "\t", "möäüÕga", "\"", "\\", "\'"}));
|
||||
} // main
|
||||
|
||||
/** Conversion for int[][] . */
|
||||
public static String toString (int[][] m) {
|
||||
if (m == null) return "(int[][])null";
|
||||
StringBuffer sb = new StringBuffer();
|
||||
sb.append ("new int[][]{");
|
||||
for (int i=0; i < m.length; i++) {
|
||||
if (i > 0) sb.append (", ");
|
||||
if (m[i] == null)
|
||||
sb.append ("null");
|
||||
else {
|
||||
sb.append ("{");
|
||||
for (int j=0; j < m[i].length; j++) {
|
||||
if (j > 0) sb.append (", ");
|
||||
sb.append (String.valueOf (m[i][j]));
|
||||
} // for j
|
||||
sb.append ("}");
|
||||
}
|
||||
} // for i
|
||||
sb.append ("}");
|
||||
return sb.toString();
|
||||
} // toString int[][]
|
||||
|
||||
/** Conversion for double[][] . */
|
||||
public static String toString (double[][] m) {
|
||||
if (m == null) return "(double[][])null";
|
||||
StringBuffer sb = new StringBuffer();
|
||||
sb.append ("new double[][]{");
|
||||
for (int i=0; i < m.length; i++) {
|
||||
if (i > 0) sb.append (", ");
|
||||
if (m[i] == null)
|
||||
sb.append ("null");
|
||||
else {
|
||||
sb.append ("{");
|
||||
for (int j=0; j < m[i].length; j++) {
|
||||
if (j > 0) sb.append (", ");
|
||||
sb.append (String.valueOf (m[i][j]));
|
||||
} // for j
|
||||
sb.append ("}");
|
||||
}
|
||||
} // for i
|
||||
sb.append ("}");
|
||||
return sb.toString();
|
||||
} // toString double[][]
|
||||
|
||||
/** Conversion for int[] . */
|
||||
public static String toString (int[] m) {
|
||||
if (m == null) return "(int[])null";
|
||||
StringBuffer sb = new StringBuffer();
|
||||
sb.append ("new int[]{");
|
||||
for (int i=0; i < m.length; i++) {
|
||||
if (i > 0) sb.append (", ");
|
||||
sb.append (String.valueOf (m[i]));
|
||||
} // for i
|
||||
sb.append ("}");
|
||||
return sb.toString();
|
||||
} // toString int[]
|
||||
|
||||
/** Conversion for double[] . */
|
||||
public static String toString (double[] m) {
|
||||
if (m == null) return "(double[])null";
|
||||
StringBuffer sb = new StringBuffer();
|
||||
sb.append ("new double[]{");
|
||||
for (int i=0; i < m.length; i++) {
|
||||
if (i > 0) sb.append (", ");
|
||||
sb.append (String.valueOf (m[i]));
|
||||
} // for i
|
||||
sb.append ("}");
|
||||
return sb.toString();
|
||||
} // toString double[]
|
||||
|
||||
/** Conversion for int . */
|
||||
public static String toString (int n) {
|
||||
return String.valueOf (n);
|
||||
} // toString int
|
||||
|
||||
/** Conversion for double . */
|
||||
public static String toString (double d) {
|
||||
return String.valueOf (d);
|
||||
} // toString double
|
||||
|
||||
/** Conversion for String . */
|
||||
public static String toString (String s) {
|
||||
if (s == null)
|
||||
return "null";
|
||||
StringBuffer tmp = new StringBuffer();
|
||||
for (int k=0; k < s.length(); k++) {
|
||||
char c = s.charAt (k);
|
||||
switch (c) {
|
||||
case '\n': { tmp.append ("\\n"); break; }
|
||||
case '\t': { tmp.append ("\\t"); break; }
|
||||
case '\b': { tmp.append ("\\b"); break; }
|
||||
case '\f': { tmp.append ("\\f"); break; }
|
||||
case '\r': { tmp.append ("\\r"); break; }
|
||||
case '\\': { tmp.append ("\\\\"); break; }
|
||||
case '\'': { tmp.append ("\\\'"); break; }
|
||||
case '\"': { tmp.append ("\\\""); break; }
|
||||
// TODO!!! add more escapes if needed
|
||||
default: tmp.append (c);
|
||||
} // switch
|
||||
} // for k
|
||||
return "\"" + tmp.toString() + "\"";
|
||||
} // toString String
|
||||
|
||||
/** Conversion for String[] . */
|
||||
public static String toString (String[] m) {
|
||||
if (m == null)
|
||||
return "(String[])null";
|
||||
StringBuffer sb = new StringBuffer();
|
||||
sb.append ("new String[]{");
|
||||
for (int i=0; i < m.length; i++) {
|
||||
if (i > 0)
|
||||
sb.append (", ");
|
||||
sb.append (toString (m[i]));
|
||||
} // for i
|
||||
sb.append ("}");
|
||||
return sb.toString();
|
||||
} // toString String[]
|
||||
|
||||
/** Double number as string with the given length.
|
||||
* @param d argument
|
||||
* @param len length
|
||||
* @return d as string
|
||||
*/
|
||||
public static String fString (double d, int len) {
|
||||
if (len<1)
|
||||
return "";
|
||||
// pad on ruum punkti ja v6imaliku miinusm2rgi jaoks
|
||||
int pad = 1 + ((d<0)?1:0);
|
||||
// loga on t2isosa numbrikohtade arv
|
||||
int loga = (int)Math.max (0., Math.log10 (Math.abs (d))) + 1;
|
||||
// kk on punkti j2rel olevate kohtade arv
|
||||
int kk = (int)Math.max (len-pad-loga, 0);
|
||||
String fs = "%" + String.valueOf (len) + "." +
|
||||
String.valueOf (kk) + "f";
|
||||
String res = "";
|
||||
try {
|
||||
res = String.format ((java.util.Locale)null, fs, d);
|
||||
} catch (IllegalArgumentException e) {
|
||||
res = String.valueOf (d);
|
||||
} // try
|
||||
return res;
|
||||
} // fString
|
||||
|
||||
/** Prettyprint for double[][] .
|
||||
* @param m array to print
|
||||
* @param fs format string for element
|
||||
* @return m array as multiline string
|
||||
*/
|
||||
public static String toPrettyString (double[][] m, String fs) {
|
||||
String nl = System.getProperty ("line.separator");
|
||||
if (m == null)
|
||||
return "nullpointer instead of this matrix" + nl;
|
||||
// throw new NullPointerException ("(double[][])null"); // alternative
|
||||
if (m.length == 0)
|
||||
return "this matrix is empty" + nl;
|
||||
StringBuffer sb = new StringBuffer(nl);
|
||||
for (int i=0; i < m.length; i++) {
|
||||
if (m[i] == null)
|
||||
sb.append ("nullpointer instead of this row" + nl);
|
||||
else {
|
||||
if (m[i].length == 0)
|
||||
sb.append ("this row is empty");
|
||||
else {
|
||||
for (int j=0; j < m[i].length; j++) {
|
||||
String elem = "";
|
||||
if (fs == null || fs.length() < 1) {
|
||||
// TODO!!! keera siit, kui tahad pilti muuta
|
||||
elem = fString (m[i][j], 6) + "\t";
|
||||
} else {
|
||||
try {
|
||||
elem = String.format ((java.util.Locale)null,
|
||||
fs, m[i][j]) + " "; // remove space if needed
|
||||
} catch (IllegalArgumentException e) {
|
||||
elem = fString (m[i][j], 6) + "\t";
|
||||
} // try
|
||||
}
|
||||
sb.append (elem);
|
||||
} // for j
|
||||
} // nonempty row
|
||||
sb.append (nl);
|
||||
} // non-null row
|
||||
} // for i
|
||||
return sb.toString();
|
||||
} // toPrettyString double[][]
|
||||
|
||||
/** Version of double[][] prettyprint without format string. */
|
||||
public static String toPrettyString (double[][] m) {
|
||||
return toPrettyString (m, null);
|
||||
} // toPrettyString double[][]
|
||||
|
||||
/** Prettyprint for int[][] .
|
||||
* @param m array to print
|
||||
* @param fs format string for element
|
||||
* @return m array as a multiline string
|
||||
*/
|
||||
public static String toPrettyString (int[][] m, String fs) {
|
||||
String nl = System.getProperty ("line.separator");
|
||||
if (m == null)
|
||||
return "nullpointer instead of this matrix" + nl;
|
||||
// throw new NullPointerException ("(double[][])null"); // alternative
|
||||
if (m.length == 0)
|
||||
return "this matrix is empty" + nl;
|
||||
StringBuffer sb = new StringBuffer(nl);
|
||||
for (int i=0; i < m.length; i++) {
|
||||
if (m[i] == null)
|
||||
sb.append ("nullpointer instead of this row" + nl);
|
||||
else {
|
||||
if (m[i].length == 0)
|
||||
sb.append ("this row is empty");
|
||||
else {
|
||||
for (int j=0; j < m[i].length; j++) {
|
||||
String elem = "";
|
||||
if (fs == null || fs.length() < 1)
|
||||
fs = "%5d"; // TODO!!! keera siit, kui vaja
|
||||
try {
|
||||
elem = String.format ((java.util.Locale)null,
|
||||
fs, m[i][j]) + " "; // remove space if needed
|
||||
} catch (IllegalArgumentException e) {
|
||||
elem = String.valueOf (m[i][j]) + "\t";
|
||||
} // try
|
||||
sb.append (elem);
|
||||
} // for j
|
||||
} // nonempty row
|
||||
sb.append (nl);
|
||||
} // non-null row
|
||||
} // for i
|
||||
return sb.toString();
|
||||
} // toPrettyString int[][]
|
||||
|
||||
/** Version of int[][] prettyprint without format string. */
|
||||
public static String toPrettyString (int[][] m) {
|
||||
return toPrettyString (m, null);
|
||||
} // toPrettyString int[][]
|
||||
|
||||
/** Prettyprint for String[] . */
|
||||
public static String toPrettyString (String[] m) {
|
||||
String nl = System.getProperty ("line.separator");
|
||||
if (m == null) return "(String[])null";
|
||||
StringBuffer sb = new StringBuffer();
|
||||
for (int i=0; i < m.length; i++) {
|
||||
sb.append (toString (m[i]) + nl);
|
||||
} // for i
|
||||
return sb.toString();
|
||||
} // toPrettyString String[]
|
||||
|
||||
} // Aout
|
||||
|
148
test/BallsTest.java
Normal file
148
test/BallsTest.java
Normal file
@ -0,0 +1,148 @@
|
||||
import static org.junit.Assert.*;
|
||||
import org.junit.Test;
|
||||
|
||||
public class BallsTest {
|
||||
|
||||
/** Number of milliseconds allowed to spend for sorting 1 million elements */
|
||||
public static int threshold = 25;
|
||||
|
||||
/** Test data */
|
||||
static Balls.Color[] balls = null;
|
||||
|
||||
/** Number of red balls */
|
||||
static int rCount = 0;
|
||||
|
||||
/** Correctness check for the result */
|
||||
static boolean check (Balls.Color[] balls, int r) {
|
||||
int len = balls.length;
|
||||
if (len == 0)
|
||||
return true;
|
||||
for (int i=0; i < r; i++)
|
||||
if (balls[i] != Balls.Color.red)
|
||||
return false;
|
||||
for (int i=r; i < len; i++)
|
||||
if (balls[i] != Balls.Color.green)
|
||||
return false;
|
||||
return true;
|
||||
} // check
|
||||
|
||||
@Test (timeout=1000)
|
||||
public void testFunctionality() {
|
||||
balls = new Balls.Color [100000];
|
||||
rCount = 0;
|
||||
for (int i=0; i < balls.length; i++) {
|
||||
if (Math.random() < 0.5) {
|
||||
balls[i] = Balls.Color.red;
|
||||
rCount++;
|
||||
} else {
|
||||
balls[i] = Balls.Color.green;
|
||||
}
|
||||
}
|
||||
Balls.reorder (balls);
|
||||
assertTrue ("Result incorrect", check (balls, rCount));
|
||||
}
|
||||
|
||||
@Test (timeout=1000)
|
||||
public void testShort() {
|
||||
balls = new Balls.Color [1];
|
||||
if (Math.random() < 0.5) {
|
||||
balls[0] = Balls.Color.red;
|
||||
rCount = 1;
|
||||
} else {
|
||||
balls[0] = Balls.Color.green;
|
||||
rCount = 0;
|
||||
}
|
||||
Balls.reorder (balls);
|
||||
assertTrue ("One element array not working", check (balls, rCount));
|
||||
balls = new Balls.Color [0];
|
||||
rCount = 0;
|
||||
Balls.reorder (balls);
|
||||
assertTrue ("Zero element array not working", check (balls, rCount));
|
||||
balls = new Balls.Color [100000];
|
||||
rCount = 0;
|
||||
for (int i=0; i < balls.length; i++) {
|
||||
if (Math.random() < 0.5) {
|
||||
balls[i] = Balls.Color.red;
|
||||
rCount++;
|
||||
} else {
|
||||
balls[i] = Balls.Color.green;
|
||||
}
|
||||
}
|
||||
Balls.reorder (balls);
|
||||
assertTrue ("Result incorrect", check (balls, rCount));
|
||||
}
|
||||
|
||||
@Test (timeout=1000)
|
||||
public void testAllGreen() {
|
||||
balls = new Balls.Color [100000];
|
||||
rCount = 0;
|
||||
for (int i=0; i < balls.length; i++) {
|
||||
balls[i] = Balls.Color.green;
|
||||
}
|
||||
Balls.reorder (balls);
|
||||
assertTrue ("Result incorrect for all green", check (balls, rCount));
|
||||
balls = new Balls.Color [100000];
|
||||
rCount = 0;
|
||||
for (int i=0; i < balls.length; i++) {
|
||||
if (Math.random() < 0.5) {
|
||||
balls[i] = Balls.Color.red;
|
||||
rCount++;
|
||||
} else {
|
||||
balls[i] = Balls.Color.green;
|
||||
}
|
||||
}
|
||||
Balls.reorder (balls);
|
||||
assertTrue ("Result incorrect", check (balls, rCount));
|
||||
}
|
||||
|
||||
@Test (timeout=1000)
|
||||
public void testAllRed() {
|
||||
balls = new Balls.Color [100000];
|
||||
rCount = 0;
|
||||
for (int i=0; i < balls.length; i++) {
|
||||
balls[i] = Balls.Color.red;
|
||||
rCount++;
|
||||
}
|
||||
Balls.reorder (balls);
|
||||
assertTrue ("Result incorrect for all red", check (balls, rCount));
|
||||
balls = new Balls.Color [100000];
|
||||
rCount = 0;
|
||||
for (int i=0; i < balls.length; i++) {
|
||||
if (Math.random() < 0.5) {
|
||||
balls[i] = Balls.Color.red;
|
||||
rCount++;
|
||||
} else {
|
||||
balls[i] = Balls.Color.green;
|
||||
}
|
||||
}
|
||||
Balls.reorder (balls);
|
||||
assertTrue ("Result incorrect", check (balls, rCount));
|
||||
}
|
||||
|
||||
@Test (timeout=1000)
|
||||
public void testSpeed() {
|
||||
balls = new Balls.Color [1000000];
|
||||
rCount = 0;
|
||||
for (int i=0; i < balls.length; i++) {
|
||||
if (Math.random() < 0.5) {
|
||||
balls[i] = Balls.Color.red;
|
||||
rCount++;
|
||||
} else {
|
||||
balls[i] = Balls.Color.green;
|
||||
}
|
||||
}
|
||||
long t0 = System.currentTimeMillis();
|
||||
Balls.reorder (balls);
|
||||
long t1 = System.currentTimeMillis();
|
||||
int delta = (int)(t1-t0);
|
||||
assertTrue ("Result incorrect", check (balls, rCount));
|
||||
assertTrue ("Too slow: "+ delta, delta < threshold);
|
||||
System.out.println ("Time spent: " + delta + " ms");
|
||||
}
|
||||
|
||||
@Test (expected=RuntimeException.class)
|
||||
public void testNullArray() {
|
||||
Balls.reorder (null);
|
||||
}
|
||||
}
|
||||
|
BIN
test/hamcrest-core-1.3.jar
Normal file
BIN
test/hamcrest-core-1.3.jar
Normal file
Binary file not shown.
BIN
test/junit-4.12.jar
Normal file
BIN
test/junit-4.12.jar
Normal file
Binary file not shown.
Loading…
x
Reference in New Issue
Block a user