题目描述
请设计一个资产管理系统,支持资产增加、借用、归还、统计的功能。每个资产编号都是全局唯一的
AssetsSystem() - 系统初始化
addAssets(int assetsId) - 线系统中增加一个编号为 assetsId 的资产,如果资产已经存在则直接返回0;否则增加成功并返回1.
borrowAssets(int employeeId, int assetsId) - 员工 employeeId 解用资产 assetsId:
如果资产不存在,则直接返回-1
如果资产被借用、且为归还,则直接返回0;
如果资产未被借用,则成功借用并返回1
returnAssets(int assetsId)-归还资产 assetsId
如果资产不存在,则直接返回-1
如果资产未被任何人借用,则直接返回0
否则成功归还,并返回1
statAssets(int topNum) - 统计当前系统内有借用、且未归还的借用人,并按如下规则返回 topNum 个借用人的 employeeId 和未归还资产的数量
优先按未归还的数量从大到小排序;若数量相同,再按借用人的 employeeId 从小到大排序
如果人数不足 topNum ,则按实际人数返回;如果实际人数为0,返回空数组[]
样例1
输入
new AssetsSystem();
addAssets(1812);
borrowAssets(99527, 1812);
addAssets(1812);
statAssets(2);
returnAssets(1812);
输出
null
1
1
0
[[99527,1]]
1
样例2
输入
AssetsSystem();
addAssets(6789);
borrowAssets(41336, 6789);
addAssets(1234);
addAssets(2345);
borrowAssets(99527, 1234);
borrowAssets(99527, 2345);
statAssets(2);
returnAssets(2345);
statAssets(2);
returnAssets(555);
输出
null
1
1
1
1
1
1
[[99527, 2], [41336, 1]]
1
[[41336, 1], [99527, 1]]
-1
Java代码实现
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class AssetsSystem {
private static List<Map<Integer, Integer>> assetsList = new ArrayList<>();
private static final List<Map<Integer, Integer>> employeeList = new ArrayList<>();
AssetsSystem() {
System.out.println("null");
}
static int addAssets(int assetsId) {
if (assetsList == null) {
assetsList = new ArrayList<>();
}
for (Map<Integer, Integer> map : assetsList) {