Back to questions
Senior
4
На вход подаются данные OperationId TransactionId ISIN RcvID SndId Quantity OperationId - int ид операции TransactionId - int ид транзакции ISIN - String ид инструмента RcvID - int ид клиента получателя, если -1, это вывод SndId - int ид клиента отправителя, если -1, это ввод Quantity - double количество инструмента OperDate - String дата в формате [phone] на вход подаются строки, например 1 1 RUB [phone] USD [phone] USD [phone] RUB [phone] нужно подсчитать количество каждого инструмента у каждого клиента на последнюю дату [phone] USD [phone] USD [phone] RUB 100
Companies where asked
атон
Answer from AI
sobes.tech AI
Для решения задачи подсчёта количества каждого инструмента у каждого клиента на последнюю дату нужно:
- Считать все операции, парсить поля, включая дату.
- Отфильтровать операции по максимальной дате (последней).
- Для каждой операции обновить баланс клиента:
- Если RcvID != -1, увеличить количество инструмента у клиента RcvID на Quantity.
- Если SndId != -1, уменьшить количество инструмента у клиента SndId на Quantity.
Пример кода на Java с использованием Map для хранения балансов:
import java.util.*;
import java.time.LocalDate;
import java.time.format.DateTimeFormatter;
class Operation {
int operationId;
int transactionId;
String isin;
int rcvId;
int sndId;
double quantity;
LocalDate operDate;
public static Operation parse(String line) {
String[] parts = line.split(" ");
Operation op = new Operation();
op.operationId = Integer.parseInt(parts[0]);
op.transactionId = Integer.parseInt(parts[1]);
op.isin = parts[2];
op.rcvId = Integer.parseInt(parts[3]);
op.sndId = Integer.parseInt(parts[4]);
op.quantity = Double.parseDouble(parts[5]);
op.operDate = LocalDate.parse(parts[6], DateTimeFormatter.ISO_DATE); // формат даты должен быть ISO
return op;
}
}
public class BalanceCalculator {
public static void main(String[] args) {
List<Operation> operations = new ArrayList<>();
// Здесь считываем входные данные и парсим в operations
// Находим максимальную дату
LocalDate maxDate = operations.stream()
.map(op -> op.operDate)
.max(LocalDate::compareTo)
.orElse(LocalDate.MIN);
// Фильтруем операции по максимальной дате
List<Operation> lastDateOps = new ArrayList<>();
for (Operation op : operations) {
if (op.operDate.equals(maxDate)) {
lastDateOps.add(op);
}
}
// Map<Клиент, Map<Инструмент, Количество>>
Map<Integer, Map<String, Double>> balances = new HashMap<>();
for (Operation op : lastDateOps) {
if (op.rcvId != -1) {
balances.computeIfAbsent(op.rcvId, k -> new HashMap<>())
.merge(op.isin, op.quantity, Double::sum);
}
if (op.sndId != -1) {
balances.computeIfAbsent(op.sndId, k -> new HashMap<>())
.merge(op.isin, -op.quantity, Double::sum);
}
}
// Вывод балансов
for (var clientEntry : balances.entrySet()) {
int clientId = clientEntry.getKey();
for (var isinEntry : clientEntry.getValue().entrySet()) {
System.out.printf("Client %d has %.2f of %s\n", clientId, isinEntry.getValue(), isinEntry.getKey());
}
}
}
}
Важно, чтобы дата была в формате, который можно распарсить (например, ISO 8601). Если формат другой, нужно подстроить парсер даты.
Таким образом, мы учитываем ввод (sndId = -1) и вывод (rcvId = -1) корректно, обновляя балансы клиентов на последнюю дату.