笔试算法题

1.题目描述:假设有这样一个算法题,该计算器只有两个按钮,按下第一个按钮能是数值减1,按下第二个按钮能使数值的值乘以2,当前显示数值为N,那么按多少次按钮使得显示数值变成M?

输入:两个整数N和M,1<=N,M<=10^9
输出:使得显示数N变为M的次数

样例输入:4 5
样例输出:3

import java.util.Scanner;
public class Demo4 {
    public static void main(String[] args) {
        int len=0;
        Scanner sc=new Scanner(System.in);
        int N=sc.nextInt();
        int M=sc.nextInt();
        for (int i = 0; i < 1000; i++) {
            if(N>=M) {
                len+=N-M;
                System.out.println(len);
                break;
            }else {
                if (M%2!=0) len++;
                M=(int) Math.ceil(M/2.0);
                len++;
            }
        }
    }
}
2.输入一个字符串,要求逆序输出,时间复杂度为O(n)
import java.util.Scanner;

public class Demo {
    public static void main(String args[]){
        Scanner input=new Scanner(System.in);
        String str=input.next();
        char[] strm=str.toCharArray();
        for(int i=0;i<str.length();i++){
            System.out.print(strm[str.length()-1-i]+"");
        }
    }
}
java笔试算法 目录 :envelope: 说明 项目介绍 该文档主要是笔主在学习 Java 的过程中的一些学习笔记,但是为了能够涉及到大部分后端学习所需的技术知识点我也会偶尔引用一些别人的优秀文章的链接。文档大部分内容都是笔者参考书籍以及自己的原创。少部分面试回答参考了其他人已有答案,上面都已注明。 该文档涉及的主要内容包括: Java、 数据结构与算法、计算机网络与数据通信、 操作系统、主流框架、数据存储、架构、面试必备知识点等等。相信不论你是前端还是后端都能在这份文档中收获到东西。 关于转载 如果需要引用到本仓库的一些东西,必须注明转载地址!!!毕竟大多都是手敲的,或者引用的是我的原创文章,希望大家尊重一下作者的劳动:grinning_face_with_big_eyes::grinning_face_with_big_eyes::grinning_face_with_big_eyes:! 如何对该开源文档进行贡献 笔记内容大多是手敲,所以难免会有笔误,你可以帮我找错别字。 很多知识点我可能没有涉及到,所以你可以对其他知识点进行补充。 现有的知识点难免存在不完善或者错误,所以你可以对已有知识点的修改/补充。 为什么要做这个开源文档? 在我们学习Java的时候,很多人会面临我不知道继续学什么或者面试会问什么的尴尬情况(我本人之前就很迷茫:grinning_face_with_smiling_eyes:)。所以,我决定通
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值