当前位置:首页 » 《随便一记》 » 正文

有假币与求正数数组的最小不可组成和

16 人参与  2023年05月06日 17:37  分类 : 《随便一记》  评论

点击全文阅读


一、编程题

1.有假币

链接:有假币__牛客网 (nowcoder.com)

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

输入描述:

1≤n≤2^30,输入0结束程序。

输出描述:

最多要称几次一定能把那个假币找出来

示例1

输入

3

12

0

输出

1

3

?做题思路:

5b320226b1a648b89b59b905ef0ebcd5.png

b57da7559f7c4d678ed96d86ab63d693.png

import java.util.Scanner;public class Main {    public static void main(String[] args) {        Scanner scanner = new Scanner(System.in);        while (scanner.hasNext()) {            int n = scanner.nextInt();            if (n == 0) {                break;            }            int count = 0;            while (n >= 2) {                //注意的是Math返回的是double,强制转化为int                n = (int) Math.ceil((double)n / 3);                count++;            }            System.out.println(count);        }    }}

2.正数数组的最小不可组成和

链接:求正数数组的最小不可组成和_百度笔试题_牛客网 (nowcoder.com)

给定一个全是正数的数组arr,定义一下arr的最小不可组成和的概念:

1️⃣arr的所有非空子集中,把每个子集内的所有元素加起来会出现很多的值,其中最小的记为min,最大的记为max;

2️⃣在区间[min,max]上,如果有一些正数不可以被arr某一个子集相加得到,那么这些正数中最小的那个,就是arr的最小不可组成和;

3️⃣在区间[min,max]上,如果所有的数都可以被arr的某一个子集相加得到,那么max+1是arr的最小不可组成和;

✨举例: arr = {3,2,5} arr的min为2,max为10,在区间[2,10]上,4是不能被任何一个子集相加得到的值中最小的,所以4是arr的最小不可组成和; arr = {3,2,4} arr的min为2,max为9,在区间[2,9]上,8是不能被任何一个子集相加得到的值中最小的,所以8是arr的最小不可组成和; arr = {3,1,2} arr的min为1,max为6,在区间[1,6]上,任何数都可以被某一个子集相加得到,所以7是arr的最小不可组成和; 请写函数返回arr的最小不可组成和。

?做题思路:

6148ca27269f4fef93df53898a4483ef.png

9b1b955945a04d74b52d4276637ec063.png

public class Solution {/** *正数数组中的最小不可组成和 *输入:正数数组arr *返回:正数数组中的最小不可组成和 */public int getFirstUnFormedNum(int[] arr) {        int min = Integer.MAX_VALUE;        int max = 0;        for (int i = 0; i < arr.length; i++) {            max += arr[i];            min = Math.min(min, arr[i]);        }        boolean result[] = new boolean[max + 1];        result[0] = true; // 为了使单个元素去求和时是真的 (i + 0 = i)        for (int i = 0; i < arr.length; i++) {            for (int j = max; j >= arr[i]; j--) {                result[j] = result[j - arr[i]] || result[j];            }        }        for (int i = min; i < result.length; i++) {            if (!result[i])                return i;        }        return max + 1;    }}

 

 


点击全文阅读


本文链接:http://m.zhangshiyu.com/post/61215.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • [糙汉嘴软心硬,娇妻日日晚起]小说精彩节选免费试读_「黎夏顾卫城」主线最终章倒计时
  • 我的亲妹妹我当做畜生,只有儿子来救我反转剧情试读片段_[***小宝李小翠]精彩章节免费试读
  • 往梦难复温,沈淮霆宋思予在线_往梦难复温,沈淮霆宋思予在线
  • 爱意清浅随风离(简凝夕陆靳燃),爱意清浅随风离
  • 「冲喜而已,侯爷别太爱」小说免费在线阅读_侯府侯爷乐瑶主线最终章倒计时
  • 好看的往梦难复温沈淮霆宋思予_往梦难复温沈淮霆宋思予
  • 天才京剧花旦被废嗓后成为芭蕾舞王+后续+结局(秦意宋笙)全书秦意宋笙结局_秦意宋笙+结局列表_笔趣阁(天才京剧花旦被废嗓后成为芭蕾舞王+后续+结局)
  • (番外)+(全书)往梦难复温(沈淮霆宋思予+番外+全书)_(往梦难复温+番外+全书)免费_笔趣阁(沈淮霆宋思予)
  • 江晚烟陆聿我终于失去了你结局+番外(江晚烟陆聿)列表_江晚烟陆聿我终于失去了你结局+番外(江晚烟陆聿)结局篇+番外在线
  • 池雾陆砚寒结局+番外(陆砚寒池雾)列表_池雾陆砚寒结局+番外(陆砚寒池雾)池雾陆砚寒结局+番外在线
  • 沈静怡傅励行+后续+结局(傅励行沈静怡)列表_沈静怡傅励行+后续+结局(傅励行沈静怡)沈静怡傅励行+后续+结局在线
  • 非典时,我被妻子的白月光误诊遗弃在病房节选角色羁绊特辑‌_田越苏雅白月光角色专属支线试读入口

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1