Массив имеет элементы (1,2,2,1,1). Я должен найти, что количество отдельных элементов в вспомогательном массиве должно быть равно числу отдельных элементов в данном массиве. I число различных элементов элементов в массиве (1 и 2).Обход большого массива
Все возможные подмассивы: [1,2], [1,3], [1,4], [1,5], [2,4], [2,5], [3,4] , [3,5]
Distinct означает, что нет отдельных элементов it 2 {1,2,2} имеет 2 отдельных элемента. В этом вопросе 1,4 не означает, что мы включаем 1-й элемент и 4-й элемент, это означает, что наш вспомогательный массив начинается с 1 и заканчивается на 4 , таким образом, вспомогательный массив равен [1,2,2,1], который имеет 2 отдельных элемента и он удовлетворяет, поскольку весь массив имеет 2 разных элемента.
Проблема в том, что я получил тестовый пример размер массива из 2 lacs, и я должен получить выход за 1 секунду, и каждый раз, когда я получаю превышение лимита времени.
После просмотра ответа я должен использовать буферный считыватель (вместо сканера {из-за проблемы с производительностью}) и hashmap.
Во-первых, я использовал сканер и буферный считыватель, и оба дали выход в течение 2 минут 17 секунд (для входа 2 лака). Итак, зачем нужно использовать буферизатор (с помощью сканера уменьшена длина кода).
Во-вторых, я проверил и код на сайте, и оба кода дали результат в течение 1 секунды, тогда как на моей локальной машине это заняло 2 мин. 17 сек. я не понимал, почему так много разницы.
В-третьих, в чем смысл этого кода: final int mod = (int) 1e9 + 7; (хотя я видел много раз при использовании большого количества)
В-четвертых, что используется нижеприведенным кодом, используемым с буферизованным считывателем.
Я новичок в Java, так пожалуйста дайте простой ответ и извините за длинный пост
class InputReader
{
private InputStream stream;
private byte[] buf = new byte[1024];
private int curChar;
private int numChars;
private SpaceCharFilter filter;
public InputReader(InputStream stream)
{
this.stream = stream;
}
public int read()
{
if (numChars == -1)
throw new InputMismatchException();
if (curChar >= numChars)
{
curChar = 0;
try
{
numChars = stream.read(buf);
} catch (IOException e)
{
throw new InputMismatchException();
}
if (numChars <= 0)
return -1;
}
return buf[curChar++];
}
public int readInt()
{
int c = read();
while (isSpaceChar(c))
c = read();
int sgn = 1;
if (c == '-')
{
sgn = -1;
c = read();
}
int res = 0;
do
{
if (c < '0' || c > '9')
throw new InputMismatchException();
res *= 10;
res += c - '0';
c = read();
} while (!isSpaceChar(c));
return res * sgn;
}
public String readString()
{
int c = read();
while (isSpaceChar(c))
c = read();
StringBuilder res = new StringBuilder();
do
{
res.appendCodePoint(c);
c = read();
} while (!isSpaceChar(c));
return res.toString();
}
public double readDouble() {
int c = read();
while (isSpaceChar(c))
c = read();
int sgn = 1;
if (c == '-') {
sgn = -1;
c = read();
}
double res = 0;
while (!isSpaceChar(c) && c != '.') {
if (c == 'e' || c == 'E')
return res * Math.pow(10, readInt());
if (c < '0' || c > '9')
throw new InputMismatchException();
res *= 10;
res += c - '0';
c = read();
}
if (c == '.') {
c = read();
double m = 1;
while (!isSpaceChar(c)) {
if (c == 'e' || c == 'E')
return res * Math.pow(10, readInt());
if (c < '0' || c > '9')
throw new InputMismatchException();
m /= 10;
res += (c - '0') * m;
c = read();
}
}
return res * sgn;
}
public long readLong() {
int c = read();
while (isSpaceChar(c))
c = read();
int sgn = 1;
if (c == '-') {
sgn = -1;
c = read();
}
long res = 0;
do {
if (c < '0' || c > '9')
throw new InputMismatchException();
res *= 10;
res += c - '0';
c = read();
} while (!isSpaceChar(c));
return res * sgn;
}
public boolean isSpaceChar(int c)
{
if (filter != null)
return filter.isSpaceChar(c);
return c == ' ' || c == '\n' || c == '\r' || c == '\t' || c == -1;
}
public String next()
{
return readString();
}
public interface SpaceCharFilter
{
public boolean isSpaceChar(int ch);
}
}
class OutputWriter
{
private PrintWriter writer;
public OutputWriter(OutputStream outputStream)
{
writer = new PrintWriter(new BufferedWriter(new OutputStreamWriter(outputStream)));
}
public OutputWriter(Writer writer)
{
this.writer = new PrintWriter(writer);
}
public void print(Object... objects)
{
for (int i = 0; i < objects.length; i++)
{
if (i != 0)
writer.print(' ');
writer.print(objects[i]);
}
}
public void printLine(Object... objects)
{
print(objects);
writer.println();
}
public void close()
{
writer.close();
}
public void flush()
{
writer.flush();
}
}
Я вижу путь к много кода для такой сравнительно небольшой задачи. – SomeJavaGuy
Использование сканера удалит весь этот код, хотя я не понял, как использовать код, а также это мой третий раз, видя этот код, поэтому я должен опубликовать этот код, и всякий раз, когда я вижу этот код, он используется для обработки большого количества. – Fawkes