Java寒假作业——编程题

二、编程题(ACM模式)5-6题

5 (2022小红书)一个序列的生成方式如下:序列生成需要一个基础序列A,这个序列由n个不大于100的数字组成,同时给定镜像复制次数m。然后对于A进行m次镜像复制,例如序列A={1,2,3},则一次镜像复制后得到的序列是{1,2,3,3,2,1},两次镜像复制得到的序列是B={1,2,3,3,2,1,1,2,3,3,2,1}。现在给出你生成一个序列所需要的参数,请你计算该序列的第k位是多少。

输入描述

3 2 9

1 2 3

输入第一行包含三个整数n,m,k,含义如题所示

输入第二行包含n个正整数,每个正整数都不大于100,表示基础序列A,数字间由空格隔开

输出描述

3

输出仅包含一个正整数,即序列第k位的数字

package 分治回溯算法;

import java.util.ArrayList;
import java.util.Scanner;

public class Exercise05 {
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        System.out.println("输入第一行,包含三个整数:n(数字个数),m(镜像复制次数),k(该序列的第k位):");
        int n = input.nextInt();
        int m = input.nextInt();
        int k = input.nextInt();
        System.out.println("输入第二行,包含n个正整数,每个正整数都不大于100,表示基础序列A,数字间由空格隔开:");
        ArrayList<Integer> list = new ArrayList<>();
        for (int i = 0; i < n; i++) {
            list.add(input.nextInt());
        }
        list = newList(list, m);
        System.out.println("该序列的第k位是:" + list.get(k));
    }

    private static ArrayList<Integer> newList(ArrayList<Integer> list, int m) {
        if (m == 0) {//不用进行复制了,返回即可
            return list;
        }
        for (int i = list.size() - 1; i >= 0; i--) {
            list.add(list.get(i));//将列表的数字 倒着依次输入到 列表的后面
        }
        return newList(list, m- 1 );
    }
}

6 (2022华为)士兵在迷宫中执行任务,迷宫中危机重重,他需要在最短的时间内到达指定的位置。你可以告诉士兵他最少需要多长时间吗?输入一个n*m的迷宫中,迷宫中0为路,1为墙,2为起点,3为终点,4为陷阱,6为炸弹。士兵只能向上下左右四个方向移动,如果路径上为墙,不能移动。已知每走一步需要花费1个单位的时间,走到陷阱上需要花费3个单位的时间,走到炸弹上将会激活炸弹将炸弹上下左右的墙炸为路。

注意点:

(1)炸弹只能炸聚地,不会炸掉陷阱

(2)炸弹、陷阱只能发挥一次作用

(3)迷宫为最大为25*25

(4)用例保证士兵一定有方法能到达终点

输入描述

4 4

1 1 1 1

1 6 2 1

1 1 0 1

1 3 1 1

第一行输入n和m

第二行输入n*m的矩阵

输出描述

3

最少需要的单位时间

解释:士兵在位置2,向左移动到炸弹上,会将炸弹周围的墙炸掉,向下走两步 即可到达终点

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
用来完成大作业的。文档内容: 1 Java技术体系 1.1 Java语言 1.2 Java平台 1.3 Java应用领域 2 Java语言的技术特点 2.1 1 2.2 2 2.3 3 3 Java语言与C++的异同分析总结。 4 选用C和java语言时编程算法程序有什么不同,有什么优势和劣势。 5 自己编程学习的级别和状态。以及自己以后的编程学习的计划和想法。 6 下面3道题目中选一道,给出算法分析和程序。 1)“黄金分割数”在我们的生活中很常见,但是在不同的应用领域,要求的精度也不一样。 例如:三位小数是0.618 现在我们需要你能求出保留100位小数的黄金分割数,采用的算法为“分层计算法”: 黄金数= 1 --------------- 1+ 1 ------------- 1+ 1 ----------- 1+ 1 --------- ..... 注意,计算出的结果,如果第100位为0也需要保留。 2)已知一个数列: 5,2,4,3,7,6 那么,在这个数列中存在这样一些“连续数”,例如:5,2,4,3这个子数列排序后是连续的。同样2,4,3也是连续的,为了方便表示 我们使用下标来标识,这样,这个数列中存在以下“连续数”: [1,1] [1,4] [1,6] [2,2] [2,4] [3,3] [3,4] [4,4] [5,5] [5,6] [6,6] 这样,他就存在11个“连续数”。现在需要你在用户找出一个数组中所有的“连续数”。 要求: 1、用户输入一个整数N,表示下面数组的个数 2、用户每输入一行作为一个数组 如: 用户输入: 1 5,2,4,3,7,6 程序输出: 11 3)有一种数我们称之为幸运数,它的特点是这样的,首先,由自然数按顺序排列: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 … 这样,1比较特殊, 1为第一个幸运数,那么,我们移除掉序号能被2整除的数(注意:是序号,而不是数本身,每次移除后都重新排序)就剩下: 1 3 5 7 9 11 13 15 17 19… 3为第二个幸运数,那么我们需要去掉序号能被3(下一次是除4,然后是5,每次加1)整除的数,5 11 17...剩下: 1 3 7 9 13 15 19… 那么7为第三个幸运数,后面的幸运数,依此类推,移除之后剩下的数字都是幸运数。 现在我们需要你求出给定的m和n之间的幸运数的个数: 例如:给定1 20,那么个数为:5(5个幸运数分别是1,3,7,13,19) 现在要求用户输入两个数m和n(m<n<=1000*1000),输出幸运数的个数。 例如: 用户输入: 1 20 程序输出: 5 格式:小四,1.5倍行距

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值