第九周 算法Integer Break

Given a positive integer n, break it into the sum of at least two positive integers and maximize the product of those integers. Return the maximum product you can get.

For example, given n = 2, return 1 (2 = 1 + 1); given n = 10, return 36 (10 = 3 + 3 + 4).

Note: You may assume that n is not less than 2 and not larger than 58.

Credits:
Special thanks to @jianchao.li.fighter for adding this problem and creating all test cases.

Subscribe to see which companies asked this question.

把一个非负整数n分拆成至少两个整数之和,求分拆后各数乘积的最大值。
关键:这道题的难点其实在于拆出足够多的 3 就能使得乘积最大

class Solution {
public:
int integerBreak(int n)
{
    if(n == 2) return 1;
    if(n == 3) return 2;
    int ret = 1;
    while( n>4 )
    {
        ret *= 3;
        n -= 3;
    }
    return ret * n;
}
}
页面置换算法是操作系统中的重要概念之一,用于解决内存不足时如何将当前使用频率较低的页面从内存中置换出去,以便为其他进程或者应用程序腾出空间。下面是用 Java 代码实现 LRU 页面置换算法的示例: ``` import java.util.*; public class LRU { public static void main(String[] args) { Scanner sc = new Scanner(System.in); System.out.println("请输入内存块大小:"); int memSize = sc.nextInt(); // 内存块大小 int[] mem = new int[memSize]; // 内存块 int[] pages = new int[] {1, 2, 3, 4, 5, 6, 1, 2, 7, 8, 1, 3, 7, 9, 1}; // 页面访问序列 Map<Integer, Integer> map = new HashMap<>(); // 存储页面编号及其最近一次访问的时间 int time = 0; // 当前时间 for (int i = 0; i < pages.length; i++) { int page = pages[i]; time++; if (map.containsKey(page)) { // 页面已在内存中 map.put(page, time); // 更新最近一次访问时间 } else { // 页面未在内存中 int minTime = Integer.MAX_VALUE; // 记录最久未被访问的页面的最近访问时间 int minPage = -1; // 记录最久未被访问的页面 for (int j = 0; j < mem.length; j++) { if (mem[j] == 0) { // 内存块未被占用 mem[j] = page; map.put(page, time); break; } if (map.get(mem[j]) < minTime) { minTime = map.get(mem[j]); minPage = mem[j]; } } if (minPage != -1) { // 内存块已满,需置换页面 for (int j = 0; j < mem.length; j++) { if (mem[j] == minPage) { mem[j] = page; map.remove(minPage); map.put(page, time); break; } } } } System.out.print("第" + (i + 1) + "个页面访问后,内存中的页面为:"); for (int j = 0; j < mem.length; j++) { System.out.print(mem[j] + " "); } System.out.println(); } } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值