刷题之另类加法与走方格的方案数

这篇具有很好参考价值的文章主要介绍了刷题之另类加法与走方格的方案数。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

一、编程题

1.另类加法

 2.走方格的方案数

二、选择题


 文章来源地址https://www.toymoban.com/news/detail-441134.html

一、编程题

1.另类加法

链接:另类加法_牛客题霸_牛客网 (nowcoder.com)

描述

给定两个int AB。编写一个函数返回A+B的值,但不得使用+或其他算数运算符。

测试样例:

1,2

返回:3

🔎做题思路:位运算符

1.二进制位相异或的结果,是两个数对应相加的结果,不考虑进位

刷题之另类加法与走方格的方案数

 2.二进制与后左移一位的结果,是两个数相加进位后的结果(只考虑进位)

刷题之另类加法与走方格的方案数

结论:

刷题之另类加法与走方格的方案数

import java.util.*;

public class UnusualAdd {
    public int addAB(int A, int B) {
        if (B == 0) {
            return A;
        }
        int sum = 0;
        int carray = 0;
        while (B != 0) {
            sum = A ^ B;
            carray = (A & B) << 1;
            A = sum;
            B = carray;
        }
        return A;
    }
}

 2.走方格的方案数

链接:走方格的方案数_牛客题霸_牛客网 (nowcoder.com)

描述

请计算n*m的棋盘格子(n为横向的格子数,m为竖向的格子数)从棋盘左上角出发沿着边缘线从左上角走到右下角,总共有多少种走法,要求不能走回头路,即:只能往右和往下走,不能往左和往上走。

注:沿棋盘格之间的边缘线行走

数据范围:1≤n,m≤8 

输入描述:

输入两个正整数n和m,用空格隔开。(1≤n,m≤8)

输出描述:

输出一行结果

示例1

输入:

2 2

输出:

6

 🔎做题思路:

第一种情况:

刷题之另类加法与走方格的方案数

 第二种情况:

刷题之另类加法与走方格的方案数

import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        while (scanner.hasNext()) {
            int n = scanner.nextInt();
            int m = scanner.nextInt();
            System.out.println(med(n, m));
        }
    }
    public static int med(int n, int m) {
        //m == 1 或者 n == 1;
        if ((n == 1 && m >= 1) || (m == 1 && n >= 1)) {
            return m + n;
        }
        //n > 1, m > 1
        return med(n - 1, m) + med(n, m - 1);
    }
}

二、选择题

1.JAVA语言的下面几种数组复制方法中,哪个效率最高?

A.for循环逐一复制

B.System.arraycopy

C.Arrays.copyOf

D.使用clone方法

刷题之另类加法与走方格的方案数

2.对文件名为Test.java的java代码描述正确的是()

class Person {
	String name = "No name";
	public Person(String nm) {
		name = nm;
	}
}
class Employee extends Person {
	String empID = "0000";
	public Employee(String id) {
		empID = id;
	}
}
public class Test {
	public static void main(String args[]) {
		Employee e = new Employee("123");
		System.out.println(e.empID);
	}
}

A.输出:0000

B.输出:123

C.编译报错

D.输出:No name

 刷题之另类加法与走方格的方案数

3.在jdk1.5之后,下列 java 程序输出结果为______。

int i=0;
Integer j = new Integer(0);
System.out.println(i==j);
System.out.println(j.equals(i));

A.true,false

B.true,true

C.false,true

D.false,false

E.对于不同的环境结果不同

F.程序无法执行

 

 

 

到了这里,关于刷题之另类加法与走方格的方案数的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【算法刷题之链表篇(1)】

    给定一个已排序的链表的头 head , 删除原始链表中所有重复数字的节点,只留下不同的数字 。返回 已排序的链表 。 1.我们从指针 prev 指向链表的哑节点,随后开始对链表进行遍历。 2.如果当前 cur与 cur.next对应的元素相同,那么我们就需要将 cur 以及所有后面拥有相同元素值

    2024年02月12日
    浏览(24)
  • 【算法刷题之链表篇(2)】

    给你一个链表数组,每个链表都已经按升序排列。 请你将所有链表合并到一个升序链表中,返回合并后的链表。 思路 : 首先写出合并两个链表的代码 : 1.定义两个指针分别位于两个链表的头处,再定义一个哨兵位用于接受元素; 2.两个链表头处的指针开始遍历,并且相互

    2024年02月11日
    浏览(25)
  • leetcode刷题之回文链表

    目录 做题思路 代码实现 1.找到链表的中间节点 2.反转中间节点之后的链表 3.判断倒置的后半部分的链表是否等于前半部分的链表 整体代码展示 总结: 这里是题目链接。234. 回文链表 - 力扣(Leetcode)  这道题目的意思是:判断该链表中后半部分倒置是否跟前半部分相同,如

    2023年04月10日
    浏览(67)
  • 【算法刷题之数组篇(2)】

    (1)题目描述 给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O(log n) 的算法。 (2)方法及思路(二分查找) 考虑这个插入的位置 pos,它成立的条件为: num

    2024年02月10日
    浏览(29)
  • Leetcode刷题之环形链表

    莫等闲,白了少年头,空悲切。                                            --岳飞 目录 1.环形链表 2.环形链表Ⅱ 给你一个链表的头节点 head ,判断链表中是否有环。 如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中

    2023年04月19日
    浏览(31)
  • 【算法刷题之哈希表(2)】

    (1)题目描述 给你四个整数数组 nums1、nums2、nums3 和 nums4 ,数组长度都是 n ,请你计算有多少个元组 (i, j, k, l) 能满足: 0 = i, j, k, l n nums1[i] + nums2[j] + nums3[k] + nums4[l] == 0 (2)思路与方法 对于这道题可能首先想到的就是对于四个数组进行循环遍历,但是这种方法的时间复杂

    2024年02月11日
    浏览(32)
  • 【算法刷题之数组篇(1)】

    (1)题目描述 给你一个正整数 n ,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix 。 (2)方法与思路(模拟) 1.首先明白螺旋矩阵的拐点是在哪里,并且在旋转一周后边界值会有哪些变化。 2.先定义四个变量,分别来表示这个正方形

    2024年02月11日
    浏览(25)
  • 刷题之Leetcode209题(超级详细)

    力扣题目链接(opens new window) https://leetcode.cn/problems/minimum-size-subarray-sum/ 给定一个含有 n 个正整数的数组和一个正整数 s ,找出该数组中满足其和 ≥ s 的长度最小的 连续 子数组,并返回其长度。如果不存在符合条件的子数组,返回 0。 示例: 输入:s = 7, nums = [2,3,1,2,4,3] 输

    2024年04月11日
    浏览(29)
  • 【算法刷题之字符串篇】

    编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。 不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。 1.将 left 指向字符数组首元素,right 指向字符数组尾元素。 2.当 left right: 交换 s

    2024年02月10日
    浏览(31)
  • leetcode刷题之背包问题(01背包)

    01 背包 概念:有n件物品和一个最多能背重量为w 的背包。第i件物品的重量是 w e i g h t [ i ] weight[i] w e i g h t [ i ] ,得到的价值是 v a l u e [ i ] value[i] v a l u e [ i ] 。每件物品只能用一次,求解将哪些物品装入背包里物品价值总和最大。 方法1:暴力回溯法 方法2:动态规划 三个

    2024年02月02日
    浏览(23)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包