刷题笔记之十 (小易的升级之路+找出字符串中第一个只出现一次的字符+洗牌+MP3光标位置)

news2025/7/3 17:42:11

目录

1.存取任意指定序号的元素和在最后进行插入和删除运算,利用顺序表存储最节省时间

2. 数据结构中具有记忆功能的是栈

3. 递归程序的优化一般为 尾递归优化

4.二叉树遍历,前中后序遍历用到的是栈,而层序遍历用到的队列

5. 将两个各有n个元素的有序表归并成一个有序表,最少的比较次数是n

6. 每经过一次元素的交换会产生新的逆序的是快速排序

7. 小易的升级之路

8. 找出字符串中第一个只出现一次的字符

9. 设一个有序的单链表中有n个结点,现要求插入一个新结点后使得单链表仍然保持有序,则该操作的时间复杂度(D)

10. 给定下列程序,那么执行printf("%d\n", foo(20, 13));的输出结果是(D)

11. 循环链表不是循环队列的存储结构,数组才是

12. 堆(大根堆/小根堆)是从任意结点出发到根路径上所经过的结点序列按其关键字有序

13. 堆排序是一个非常稳定的O(nlogn)

14. 将整数数组(7-6-3-5-4-1-2)按照堆排序的方式原地进行升序排列,请问在第一轮排序结束之后,数组的顺序是(C)

15. 洗牌

16. MP3光标位置


1.存取任意指定序号的元素和在最后进行插入和删除运算,利用顺序表存储最节省时间

若某线性表最常用的操作是存取任意指定序号的元素和在最后进行插入和删除运算,则利用(A)存储方式最节省时间

A. 顺序表         B. 双链表             C. 带头结点的双循环链表             D. 单循环链表

存取任意指定序号,如果是数组取元素的话是O(1)

如果是在数组末尾的插入和删除那也是O(1),所以最好是数组,也就是顺序表存储最节省时间选A


2. 数据结构中具有记忆功能的是栈

下列数据结构具有记忆功能的是?   C

A. 队列        B. 循环队列        C. 栈        D. 顺序表

记忆功能比如, 浏览器的回退功能,文本编辑器的撤销功能,都属于记忆功能

而栈的LIFO特性,A函数调用B函数,B函数调用C函数,然后最后一层一层返回,这也具有记忆功能


3. 递归程序的优化一般为 尾递归优化

对递归程序的优化的一般的手段为(A)

A. 尾递归优化       B. 循环优化        C. 堆栈优化            D. 停止值优化

比如快速排序和归并排序,在递归的终止条件是 l 是区间最左侧,r 是区间最右侧

//终止条件

(l >= r){return ;}

//在递归终止条件处进行优化

//当区间个数较小时,采用插入排序来优化

(r - l <= 15)  --->  采用插入排序

所以这种对递归的优化一般都是 尾递归优化


4.二叉树遍历,前中后序遍历用到的是栈,而层序遍历用到的队列

将一颗二叉树的根结点放入队列,然后递归的执行如下操作,将出队结点所有子结点加入队.以上操作可以实现哪种遍历?     D

A. 前序遍历      B. 中序遍历      C. 后序遍历       D. 层序遍历

题中是将二叉树的根结点放入队列中,在这几种遍历中,只有层序遍历会用到队列,

而前中后序遍历用到的是栈 ,所以选D


5. 将两个各有n个元素的有序表归并成一个有序表,最少的比较次数是n

将两个各有n个元素的有序表归并成一个有序表,最少的比较次数是(D)

A. 2n         B. 2n-1          C. n-1       D. n

两个有序的子区间个数都为n,最好的情况为第二个区间都要比第一个子区间要大

这样只需要比较n次即可(归并排序)


6. 每经过一次元素的交换会产生新的逆序的是快速排序

下列排序法中,每经过一次元素的交换会产生新的逆序的是(A)

A. 快速排序        B. 冒泡排序        C. 简单插入排序          D. 简单选择排序    

数组的逆序:每当一次元素交换后,当前元素之后还有比当前元素还小的元素,就构成了一次逆序

而快排就是扫描到一个arr[i] < key,就把arr[i]交换到 < key 的区间中

每当交换一次,相对于元素key来将,就产生了一组新的逆序对 

而冒泡,简单插入,简单选择排序都是交换相邻元素,不一定会产生逆序对(减少逆序对)


7. 小易的升级之路

题目链接:小易的升级之路_牛客题霸_牛客网 (nowcoder.com)

题目要求:

 题目分析:       

这道题就是根据c和b的大小来分情况讨论

c = a;

c >= bi 时, 那 c += bi

c < bi 时, 那 c += gcd(c,bi)     输出最后的c就可以了

只要会写 gcd(c,bi)求最大公约数那就没啥问题

最大公约数用辗转相除法,记住这个公式,下次看着这个写就可以了

gcd(a,b) = gcd(b,a%b)    最后返回a就可以

有两种,递归和非递归的

上代码

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        while(scan.hasNext()) {
            int n = scan.nextInt();
            int a = scan.nextInt();
            int[] b = new int[n];
            for (int i = 0; i < n; i++) {
                b[i] = scan.nextInt();
            }

            int c = a;
            for (int i = 0; i < n; i++) {
                if(b[i] <= c ) {
                    c += b[i];
                }else {
                    c += gcd(b[i],c);
                }
            }
            System.out.println(c);
        }
    }

    private static int gcd1(int a, int b) {
        if(b == 0) {
            return a;
        }
        int r = a%b;
        return gbc(b,r);
    }
    private static int gcd(int a, int b) {
        int c;
        while((c = a % b) != 0) {
            a = b;
            b = c;
        }
        return b;
    }
}

8. 找出字符串中第一个只出现一次的字符

题目链接:找出字符串中第一个只出现一次的字符_牛客题霸_牛客网 (nowcoder.com)

题目要求:

 

题目分析:

可以利用哈希的思想来做这道题

字符ascii码表是0-127,这里可以定义一个数组大小为128的数组 arr

然后根据每个字符的ascii对应arr数组位置,然后存入1,遇到相同字符,就给对应字符下标存储的元素+1

arr['a']:1    arr['s'];1      arr['d'];1    arr['f'];1     arr['a'];2       arr['s'];2     arr['d'];2   arr['f'];2   arr['0'];1

上代码

import java.io.*;
import java.util.*;

public class Main {
    public static void findFirstChar(String str) {
        int[] count = new int[128];
        char[] arr = str.toCharArray();
        //遍历字符统计数组
        for(int i = 0; i < arr.length; i++) {
            count[arr[i]]++;
        } 
        //找到第一个只出现一次的字符
        boolean ret = false;
        for(int i = 0; i < arr.length; i++) {
            if(count[arr[i]] == 1) {
                System.out.println(arr[i]); 
                ret = true;
                break;
            }
        }
        if(!ret) {
            System.out.println(-1);
        }
    }

    public static void main(String[] args) throws Exception{
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        String str;
        while((str = br.readLine()) != null) {
            findFirstChar(str);
        }
    }
}

方法二 

有两个方法是根据字符串中的字符来返回对应下标的

indexof() 是从前往后找,根据字符返回其下标

lastIndexof() 是从后往前找,根据字符返回其下标

如何可以通过遍历字符串来,来根据这两个方法其返回的下标是否一样来判断字符串中只出现一次的字符.

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.*;

public class Main {
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        String str;
        while ((str = br.readLine()) != null) {
            findFirstChar(str);
        }
    }

    private static void findFirstChar(String a) {
        int ret = 0;
        for (int i = 0; i < a.length(); i++) {
            //从前往后找,从后往前找,只有遍历完字符下标是一样的
            if(a.indexOf(a.charAt(i)) == a.lastIndexOf(a.charAt(i))) {
                ret = 1;
                System.out.println(a.charAt(i));
                break;
            }
        }
        if(ret == 0) {
            System.out.println(-1);
        }
    }
}

9. 设一个有序的单链表中有n个结点,现要求插入一个新结点后使得单链表仍然保持有序,则该操作的时间复杂度(D)

 最坏情况 2-3-4-5-6 插入新结点1(尾插)

2-3-4-5-6-1,移动n次,所以最坏情况下O(n),选D


10. 给定下列程序,那么执行printf("%d\n", foo(20, 13));的输出结果是(D)

 


11. 循环链表不是循环队列的存储结构,数组才是

 循环链表不是循环队列的存储结构,数组才是


12. 堆(大根堆/小根堆)是从任意结点出发到根路径上所经过的结点序列按其关键字有序

 关键字有序是升序或者降序

哈夫曼树:是带权值的树(与元素大小顺序无关)

二叉排序树(BST)的特点是:

(1)若左子树不空,则左子树上所有结点的值均小于它的根结点的值;

(2)若右子树不空,则右子树上所有结点的值均大于它的根结点的值;

这个就是一个二叉排序树,可以看到从根节点走下去,不是有序的

AVL是平衡二叉查找树,它的特点是,树中任意结点的两个子树高度最大差为1,所以也叫高度平衡树

堆,如果是大根堆,那么堆中的所有结点都是,根节点大于左右孩子,同样小根堆是根节点小于左右孩子,所以堆是有序的选D


13. 堆排序是一个非常稳定的O(nlogn)

堆排序是一个非常稳定的O(nlogn)

快速排序,当出现大量重复元素或者数组几乎有序时,递归数退化为链表O(n^2)

冒泡排序O(n^2)

希尔排序本质上是插入排序的优化,而插入排序是O(n^2),优化为希尔排序后至少是比O(nlogn)


14. 将整数数组(7-6-3-5-4-1-2)按照堆排序的方式原地进行升序排列,请问在第一轮排序结束之后,数组的顺序是(C)


15. 洗牌

题目链接:洗牌_牛客题霸_牛客网 (nowcoder.com)

题目要求:

 题目分析:

上代码

import java.util.*;

public class Main {
    // 左: i -->  2*i;
    // 右: i+n --> 2*i + 1;
    private static void playCard(int[] cards, int n,int k ) {
        for(int i = 0; i < k; i++) {
            //一次洗牌的顺序
            int[] newCards = new int[cards.length];
            //遍历编号为0-n-1
            for(int j = 0; j < n; j++) {
                newCards[2*j] = cards[j];
                newCards[2*j+1] = cards[j+n];
            }
            cards = newCards;
        }
        //从上往下打印
        printCard(cards);
    }
    private static void printCard(int[] cards) {
        for(int i = 0; i < cards.length-1; i++) {
            System.out.print(cards[i] + " ");
        }
        System.out.println(cards[cards.length-1]);
    }
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        int group = scan.nextInt();
        for(int i = 0; i < group; i++) {
            //读入每组数据
            int n = scan.nextInt();
            int k = scan.nextInt();
            int[] arr = new int[2*n];
            for(int j = 0; j < 2*n; j++) {
                arr[j] = scan.nextInt();
            }
            //洗牌
            playCard(arr,n,k);
        }
    }
}


16. MP3光标位置

题目链接:MP3光标位置_牛客题霸_牛客网 (nowcoder.com)

题目要求:

 题目分析:

这道题需要多注意每个条件

可以使用 first来表示列表的起始位置,使用mouse来表示光标的位置

所以每个判断条件也就是来写 first mouse 和U/D 的值和关系

只有一个地方需要注意

当 n > 4 时                     

//屏幕显示的不是第一页时,光标在当前屏幕最后一首歌时,按Down键显示下一首歌,

正常根据这个是写这样的条件 first != 1 && mouse == first+3 && order[i] == 'D'

但是这里要注意,如果是最后一页的话,按D就会到第一首歌

所以应该是 first != n-3 && mouse == first+3 && order[i] == 'D'

上代码

import java.util.Scanner;
import java.io.*;

public class Main {
    private static void mouseMove(String numStr, String orderStr) {
        //歌曲数量
        int n = Integer.parseInt(numStr);
        //指令数组: ud
        char[] order = orderStr.toCharArray();
        //当前鼠标所在的位置
        int mouse = 1;
        //显示列表所在的起始位置
        int first = 1;

        //指令处理
        // n <= 4
        if(n <= 4) {
            for(int i = 0; i < order.length; i++) {
                if(mouse == 1 && order[i] == 'U') {
                    mouse = n;
                }else if(mouse == n && order[i] == 'D') {
                    mouse = 1;
                }else if(order[i] == 'U') {
                    mouse--;
                }else if(order[i] == 'D') {
                    mouse++;
                }
            }
            //输出
            //打印当前显示列表
            for(int i = 1; i < n; i++) {
                System.out.print(i + " ");
            }
            System.out.println(n);
            //打印当前歌曲
            System.out.println(mouse);
        } else {
            // n>4
            for (int i = 0; i < order.length; i++) {
                if(first == 1 && mouse == 1 && order[i] == 'U') {
                    first = n-3;
                    mouse = n;
                }else if (first == n-3 && mouse == n && order[i] == 'D') {
                    first = 1;
                    mouse = 1;
                }else if (first != 1 && mouse == first && order[i] == 'U') {
                    first--;
                    mouse--;
                    //屏幕显示的不是第一页时,光标在当前屏幕最后一首歌时,按Down键显示下一首歌,这里要注意,如果是最后一页的话,按D就会到第一首歌
                }else if (first != n-3 && mouse == first+3 && order[i] == 'D') {
                    first++;
                    mouse++;
                    //其他情况只移动光标
                }else if (order[i] == 'U') {
                    mouse--;
                }else if (order[i] == 'D') {
                    mouse++;
                }
            }
            //输出
            //打印当前显示列表
            for(int i = first; i < first+3; i++) {
                System.out.print(i + " ");
            }
            System.out.println(first+3);
            //打印当前歌曲
            System.out.println(mouse);
        }
    }
    public static void main(String[] args) throws Exception{
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        String numStr;
        while((numStr = br.readLine()) != null) {
            String orderStr = br.readLine();
            mouseMove(numStr,orderStr);
        }
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/5318.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Mybatis的增删改查操作

增删改查操作对于我们程序员来说是最基本也是最重要的操作.那么在Mybatis框架下如何对jdbc中的数据进行增删改查操作? 首先,在介绍之前,我们先来了解一下我们在进行增删改查操作过程中会遇到的各种属性和重要方法: 属性 1.namespace: 称为命名空间,用来将dao与Mapper进行绑…

[Python教程]三位数倒序

前言 最近博主也是没有什么时间来写文章&#xff0c;估计已经快两个月没写新文章了吧&#xff0c;这不&#xff0c;今天有空&#xff0c;所以想着写一篇文章。 今天的文章主要是面对Python刚刚入门的读者写的 涉及知识点 数据的基本运算字符串与数字的拼接输入与打印 相信…

Python正则表达式(持续更新,各种字符串筛选,总有一款适合您当前的功能)

前言 整个文章都是以精华部分为主&#xff0c;主要分文2个部分&#xff1a; 1、python的【re】正则表达式使用方法。 2、【re】正则表达式以及对应的demo。 第一部分让你知道【re】的几个函数的区别&#xff0c;更好的匹配项目中的需求。 第二部分让你快速的匹配具体需要的正则…

学习笔记-java代码审计-表达式注入

java代码审计-表达式注入 0x01漏洞挖掘 spel spel表达式有三种用法&#xff1a; 注解 value("#{表达式}") public String arg; 这种一般是写死在代码中的&#xff0c;不是关注的重点。 xml <bean id"Bean1" class"com.test.xxx"><prop…

Jquery

目录 一、基本介绍 二、下载地址 三、基本使用 四、jQuery对象和dom对象 五、jQuery选择器 六、jQuery的DOM操作 七、总结 相关文章 JSP的使用JSP的使用 JSON&AjaxJSON&Ajax一、基本介绍jQuery 是一个快速的&#xff0c;简洁的 javaScript 库&#xff0c;使用户能更方便…

DINO学习笔记

DINO学习笔记 DINO: DETR with Improved DeNoising Anchor Boxes for End-to-End Object Detection Abstract 我们提出了DINO(DETR with Improved deNoising anchOr boxes)&#xff0c;一种先进的端到端对象检测器。DINO采用对比的去噪训练方法、混合查询选择方法进行锚点初…

【蓝桥杯专项】动态规划_背包问题合集(Java)

✨哈喽&#xff0c;进来的小伙伴们&#xff0c;你们好耶&#xff01;✨ &#x1f6f0;️&#x1f6f0;️系列专栏:【蓝桥杯专项】 ✈️✈️本篇内容:动态规划_背包问题合集&#xff01; &#x1f680;&#x1f680;码云仓库gitee&#xff1a;Java数据结构代码存放! ⛵⛵作者简介…

【C++笔试强训】第二十二天

&#x1f387;C笔试强训 博客主页&#xff1a;一起去看日落吗分享博主的C刷题日常&#xff0c;大家一起学习博主的能力有限&#xff0c;出现错误希望大家不吝赐教分享给大家一句我很喜欢的话&#xff1a;夜色难免微凉&#xff0c;前方必有曙光 &#x1f31e;。 &#x1f4a6;&a…

动态内存管理

目录 内存中的栈区和堆区 malloc free calloc realloc 内存中的栈区和堆区 我们知道php的底层是C (任何语言其实都可以分为大同小异的几块) 而C语言的内存模型分为5个区&#xff1a;栈区、堆区、静态区、常量区、代码区。每个区存储的内容如下&#xff1a; 1、栈区&…

网络:IP与MAC

如果我们要跟对方通信&#xff0c;我们需要知道对方的IP地址与MAC地址。 一、IP IP地址&#xff0c;32位&#xff0c;工作在网络层&#xff0c;属IP协议族。在互联网中逻辑的代表某一台设备&#xff0c;但是在不同的时间&#xff0c;与我合作的主机非常多。某一个设备使用完我…

2022/11/12 json格式转换对象 动态sql

PostMapping public Integer save(RequestBody User user){return userMapper.insert(user); }选择json格式。以为本人忘记选了415错误&#xff0c;media错误 mybatisx插件 sprinboot yml文件导入xml mybatis: mapper-locations: classpath:mapper/*.xml 一直报错 发现重复了…

【华为ICT大赛】华为云激活设备的方法以及数据上下行

先展示一下没有激活的时候在线调试的状态 然后下面我将激活他&#xff0c;让他变为下面这个样子 官方教程 这里我从0演示一个产品的创建到MQTT.fx连接到云平台并且接收数据。 进入华为云平台控制台 然后开始创建一个产品 创建完毕产品之后就可以开始创建服务了&#xff0c;一…

提高工作效率的 keychron 键盘,你还没有入手吗?

前言 大家好&#xff0c;今天给大家推荐一款我最近入手并且一直在使用的机械键盘 keychron K4 。我自己是一个键盘的重度使用者&#xff0c;由于工作的需求&#xff0c;对键盘有很大的依赖&#xff0c;而一款可以提高工作效率的键盘&#xff0c;往往可以让我们的工作事半功倍。…

文化馆建筑方案设计原理及方案

文化馆建筑的分类与作用 根据职能不同&#xff0c;文化馆建筑可分为文化馆、群众艺术馆和文化站等形式。 文化馆是国家设立的开展社会宣传教育、普及科学文化知识、组织辅导群众文化艺术(活动)的综合性文化事业机构和场所。 群众艺术馆是国家设立的组织指导群众文化艺术活动及…

Github工程中的Markdown语言应用

Github工程中的Markdown语言应用1. 介绍2. 工具2.1 下载链接2.2 编辑界面2.3 插件安装3. 基本操作3.1 标题编写3.2 正文编写3.3 代码块编写3.4 加粗倾斜3.5 有序列表3.6 无序列表3.7 行内代码编写4. 参考资料最早开源代码中&#xff0c;接触的最多的就是Readme文件&#xff0c;…

Altium格式PCB转换成Allegro操作指导

Altium格式PCB转换成Allegro操作指导 首先打开Altium Design的PCB文件,输出一个“PCB ASCII File(*.pcbdoc)”格式的文件。如下图 打开Allegro,选择was performance L模式,新建空白的brd。 导入Altium PCB 选择文件转换即可 转换成功 This section is describe what t…

Spring更简单的实现Bean对象的存取

目录 一、前言&#xff1a; 二、储存Bean对象 5大类注解 Bean方法注解 三、获取Bean对象 属性注入 优缺点 Setter注入 优缺点分析 构造方法注入 优缺点分析 经典面试题 &#xff1a;属性注入 &#xff0c;构造方法注入 和 Setter 注入 之间&#xff0c;有什么区别…

大数据Presto(四):Presto自定义函数和JDBC连接

文章目录 Presto自定义函数和JDBC连接 一、Presto 自定义函数 1、​​​​​​​UDF函数 2、​​​​​​​UDAF函数 二、Presto JDBC连接 Presto自定义函数和JDBC连接 ​​​​​​​一、Presto 自定义函数 我们可以登录Presto客户端&#xff0c;使用命令&#xff1a;s…

JavaScript 71 JavaScript JSON 71.5 JSON.parse()

JavaScript 文章目录JavaScript71 JavaScript JSON71.5 JSON.parse()71.5.1 实例 – 解析 JSON71.5.2 来自服务器的 JSON71.5.3 作为 JSON 的数组71.5.4 例外71.5.5 浏览器支持71 JavaScript JSON 71.5 JSON.parse() JSON 的常规用途是同 web 服务器进行数据传输。 在从 web…

Hive笔记-01 架构概述

文章目录1.概述2.Metadata/Metastore的作用3 Metastore三种配置方式3.1 Hive配置参数说明3.1.1 基本配置参数3.1.2 其他配置参数3.2 内嵌模式&#xff08;Embedded&#xff09; 3.2.1 hive-site.xml配置说明 3.2.2 hive-site.xml配置样例3.2.3 启动方式3.2.4 缺点3.3 本地模式&…