(有假币,因子个数)笔试强训

  • 博主简介:想进大厂的打工人
  • 博主主页:@xyk:
  • 所属专栏: JavaEE初阶

目录

文章目录

一、选择1

二、选择2

二、[编程题]有假币

 三、[编程题]因子个数


一、选择1

在使用锁保证线程安全时,可能会出现活跃度失败的情况,活跃度失败主要包括:

在使用锁保证现场安全时可能会出现 活跃度 失败的情况主要包括 饥饿、丢失信号、和活锁、死锁 等。【多线程除了死锁之外遇到最多的就是活跃度问题了】

饥饿 :指线程需要访问的资源 被永久拒绝 ,以至于不能再继续进行。解决饥饿问题需要平衡线程对资源的竞争,如线程的优先级、任务的权重、执行的周期等。

活锁 :指线程虽然没有被阻塞,但由于某种条件不满足,一直尝试重试却始终失败。解决活锁问题需要对 重试机制 引入一些随机性。例如如果检测到冲突,那么就暂停随机的一定时间进行重试,这会大大减少碰撞的可能性。

所以本题选D~~~

二、选择2

下列选项中,满足短任务优先且不会发生饥饿现象的调度算法是 

饥饿现象:是指系统不能保证某个进程的等待时间上界,从而使该进程长时间等待,当等待时间给进程推进和响应带来明显影响时,称发生了进程饥饿。

D选项会产生饥饿现象

A、C选项,不满足短作业优先


选B选项,由于响应比=(作业执行时间十作业等待时间)/作业执行时间。

高响应比调度算法在等待时间相同的情况下,作业执行时间越短响应比越高,满足短任务优先。随着等待时间增加,响应比也会变大,执行机会就增大,所以不会产生饥饿现象

高响应比优先算法的思想,它结合了短作业优先+先来先服务+不冷落长作业等特点

二、[编程题]有假币

链接:有假币__牛客网
来源:牛客网

居然有假币! 现在猪肉涨了,但是农民的工资却不见涨啊,没钱怎么买猪肉啊。nowcoder这就去买猪肉,结果找来的零钱中有假币!!!可惜nowcoder 一不小心把它混进了一堆真币里面去了。只知道假币的重量比真币的质量要轻,给你一个天平(天平两端能容纳无限个硬币),请用最快的时间把那个可恶的假币找出来。

先枚举一些例子,找出其中规律:

  • 对于 1个硬币,称量 0次
  • 对于 2个硬币,称量 1次
  • 对于 3个硬币,称量 1次

对于 4个硬币,称量 2次,先分成(2,2,0),第一次称量前两份(2,2),如果重量不一样,再次求出判断另外2个硬币需要称量的次数。

对于 5个硬币,称量 2次,先分成(2,2,1),第一次称量前两份(2,2),如果重量不一样,再次判断另外1个硬币需要称量的次数。


对于 6个硬币,称量 2次,先分成(2,2,2),第一次称量前两份(2,2),如果重量不一样,再次判断求出另外2个硬币需要称量的次数。

对于 7个硬币,称量 2次,先分成(3,3,1),第一次称量前两份(3,3),如果重量不一样,再次判断求出另外3个硬币需要称量的次数。

通过上面分析可以看出,对于要称量的硬币,每次称量前分成3份,要求前两份的个数不小于第三份。如果前两份重量是一样,那么假币在第三份中,这样就除去了2/3的硬币。
如果前两份重量不一样,那么假币在重量轻的一份中,这样也除去了2/3的硬币。

其中有一个规则,我们每次把n分成是3堆,

 如果n % 3 == 0,分成 n/3、 n/3、 n/3三堆, 剩下 n/3

 如果n % 3 == 1,分成 n/3、 n/3、1 + (n/3)三堆,最坏剩下 1 + (n/3)

 如果n % 3 == 2,分成 n/3、 1 + (n/3)、1 + (n/3)三堆,最坏剩下 1 + (n/3)

注意是要用 最快的时间 最多需要多少次 求出假币!!!要考虑最坏的情况!!!

import java.util.Scanner;

/**
 * @author xyk的电脑
 * @version 1.0
 * @description: TODO
 * @date 2023/4/21 16:30
 */
public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        while (scanner.hasNextInt()) {
            int n = scanner.nextInt();
            if (n == 0) {
                return;
            } else if (n == 1) {
                System.out.println(0);
            } else if (n == 2 || n == 3) {
                System.out.println(1);
            } else {
                int count = 1;
                while (n > 3) {
                    if (n % 3 == 0) {
                        n /= 3;
                    } else {
                        n = n / 3 + 1;
                    }
                    count++;
                }
                System.out.println(count);
            }

        }
    }

}

 三、[编程题]因子个数

链接:因子个数__牛客网
来源:牛客网
 

一个正整数可以分解成一个或多个数组的积。例如36=2*2*3*3,即包含2和3两个因子。NowCoder最近在研究因子个数的分布规律,现在给出一系列正整数,他希望你开发一个程序输出每个正整数的因子个数。

本题就根据判断素数来找灵感,能被2整除的,count++,然后循环 n /= 2,这样就可以将所有的2除尽,使原数没有2的质因子~~

import java.util.Scanner;
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        while (in.hasNextInt()) {
            int n = in.nextInt();
            int count = 0;
            for (int i = 2; i <= Math.sqrt(n); i++) {
                if (n % i == 0) {
                    while (n % i == 0) {
                        n /= i;
                    }
                    count++;
                }
            }
            if (n != 1) {
                count++;
            }
            System.out.println(count);
        }
    }
}

 

在C++中,我们可以编写一个简单的模拟天平算法来辨别假币。这个例子通常涉及到排序和二分查找,假设我们有一堆金币,每个金币有一个重量值,我们需要找出其中较轻的那个,因为假金币通常比真金币轻一些。这里是一个简化的示例: ```cpp #include <iostream> #include <vector> using namespace std; bool lighter(int weight[], int n) { // 使用快速选择算法找到最轻的一枚金币位置 return quickSelect(weight, 0, n - 1, n / 2); } int quickSelect(int arr[], int left, int right, int k) { if (left == right) { return arr[left]; } int pivotIndex = partition(arr, left, right); if (k == pivotIndex) { return arr[k]; } else if (k < pivotIndex) { return quickSelect(arr, left, pivotIndex - 1, k); } else { return quickSelect(arr, pivotIndex + 1, right, k); } } int partition(int arr[], int left, int right) { int pivot = arr[right]; int i = left - 1; for (int j = left; j <= right - 1; ++j) { if (arr[j] <= pivot) { ++i; swap(arr[i], arr[j]); } } swap(arr[i + 1], arr[right]); return i + 1; } int main() { vector<int> weights(5); // 假设有5个金币,用数字代替实际重量 // 初始化权重,假设其中有假金币 // ... 这里填入具体的重量值 int minWeight = lighter(weights.data(), weights.size()); cout << "The lightest coin has a weight of: " << minWeight << endl; // 检查这个重量是否正常,如果异常可能假币 if (/* 根据实际情况检查这个重量 */){ cout << "A fake coin is detected." << endl; } else { cout << "All coins are genuine." << endl; } return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值