华为od机试题3 真题

2023-11-19

以下题目附带Java解法,是我个人写的,不一定是标准答案,没有真正的测试数据,只能说是我自己认为通过率100%,也不一定是最优解。如果有错误或是有更好的解法,请评论告诉我!!!

67.最小字符串

  题目描述:
  给定一个字符串s,最多只能进行一次变换,返回变换后能得到的最小字符串(按照字典序进行比较)。
  变换规则:交换字符串中任意两个不同位置的字符。
  输入描述:
  一串小写字母组成的字符串s。
  输出描述:
  按照要求进行变换得到的最小字符串。
  备注:
  s是都是小写字符组成
  1<=s.length<=1000
  示例
  输入:abcdef
  输出:abcdef
  说明:abcdef已经是最小字符串,不需要交换
 
  输入:bcdefa
  输出:acdefb
  说明:a和b进行位置交换,可以得到最小字符串
    // 最小字符串
    // 解题思路:遍历每一个元素,找到最小的,与第一个元素交换,如果第一个元素是最小的,则找第二个元素与第二小的元素交换,以此类推
    public static void test067() {
        Scanner sc = new Scanner(System.in);
        String line = sc.nextLine();
        char[] chars = line.toCharArray();
        // 遍历每一个元素
        for (int j = 0; j < chars.length; j++) {
            // 存放最小的元素
            char minValue = chars[j];
            // 存放最小元素的索引
            int minIndex = j;
            // 遍历往后的所有元素
            for (int i = j + 1; i < chars.length; i++) {
                // 使用<=是因为要拿到排在最后的最小元素
                if (chars[i] <= minValue) {
                    minValue = chars[i];
                    minIndex = i;
                }
            }
            // 当最小元素不是第一个时,则交换第一个元素与最小元素的位置,输出后结束
            if (minIndex != j && chars[j] != chars[minIndex]) {
                chars[minIndex] = chars[j];
                chars[j] = minValue;
                System.out.println(new String(chars));
                return;
            }
        }
        // 当元素是按顺序排的,则直接输出
        System.out.println(line);
    }

66.最长元音字符串

  定义当一个字符串只有元音字母(a,e,i,o,u,A,E,I,O,U)组成,
  称为元音字符串,现给定一个字符串,请找出其中最长的元音字符串,
  并返回其长度,如果找不到请返回0,
  字符串中任意一个连续字符组成的子序列称为该字符串的子串
  <p>
  输入描述:
  一个字符串其长度 0<length ,字符串仅由字符a-z或A-Z组成
  输出描述:
  一个整数,表示最长的元音字符子串的长度
  <p>
  示例1:
  输入
  asdbuiodevauufgh
  输出
  3
  说明:
  最长的元音字符子串为uio和auu长度都为3,因此输出3
    // 最长元音字符串
    // 解题思路:定义一个元音字符数组,判断字符是否在数组中,且是连续的,定义一个临时长度来记录连续且元音字符长度,保留最长的
    public static void test066() {
        Scanner sc = new Scanner(System.in);
        char[] chars = sc.nextLine().toCharArray();
        List<Character> list = new ArrayList<>();
        list.add('a');
        list.add('e');
        list.add('i');
        list.add('o');
        list.add('u');
        list.add('A');
        list.add('E');
        list.add('I');
        list.add('O');
        list.add('U');
        // 最大长度
        int maxLen = 0;
        // 临时长度
        int tempLen = 0;
        for (int i = 0; i < chars.length; i++) {
            // 元音且连续
            while (i < chars.length && list.contains(chars[i])) {
                i++;
                tempLen++;
            }
            // 保留最长串
            maxLen = Math.max(maxLen, tempLen);
            // 初始化
            tempLen = 0;
        }
        System.out.println(maxLen);
    }

65.字母所在字符串中的位置索引

  输入一个由N个大小写字母组成的字符串
  按照ASCII码值从小到大进行排序
  查找字符串中第K个最小ASCII码值的字母(k>=1)
  输出该字母所在字符串中的位置索引(字符串的第一个位置索引为0)
  k如果大于字符串长度则输出最大ASCII码值的字母所在字符串的位置索引
  如果有重复字母则输出字母的最小位置索引

  输入描述
  第一行输入一个由大小写字母组成的字符串
  第二行输入k k必须大于0 k可以大于输入字符串的长度

  输出描述
  输出字符串中第k个最小ASCII码值的字母所在字符串的位置索引
  k如果大于字符串长度则输出最大ASCII码值的字母所在字符串的位置索引
  如果第k个最小ASCII码值的字母存在重复  则输出该字母的最小位置索引

  示例一
  输入
  AbCdeFG
  3
  输出
  5
  说明
  根据ASCII码值排序,第三个ASCII码值的字母为F
  F在字符串中位置索引为5(0为字符串的第一个字母位置索引)
 
  示例二
  输入
  fAdDAkBbBq
  4
  输出
  6
  说明
  根据ASCII码值排序前4个字母为AABB由于B重复则只取B的第一个最小位置索引6
  而不是第二个B的位置索引8
    // 字母所在字符串中的位置索引
    // 解题思路:将字符串转为集合,对集合进行排序,找到指定位置的值,在字符串中找该字符所在位置索引
    public static void test065() {
        Scanner sc = new Scanner(System.in);
        String line = sc.nextLine();
        char[] chars = line.toCharArray();
        int index = sc.nextInt();
        int length = chars.length;
        List<Character> list = new ArrayList<>();
        for (int i = 0; i < length; i++) {
            list.add(chars[i]);
        }
        // 对集合进行排序
        Collections.sort(list);
        // 大于字符长度
        if (index > length) {
            // 输出排序后最后一个字符所在字符串的索引位置
            System.out.println(line.indexOf(list.get(length - 1)));
        } else {
            // 输出指定位置字符所在字符串的索引位置
            System.out.println(line.indexOf(list.get(index - 1)));
        }
    }

64.计算图形面积

  绘图机器的绘图笔初始位置在原点(0,0)
  机器启动后按照以下规则来进行绘制直线
  1. 尝试沿着横线坐标正向绘制直线
  直到给定的终点E
  2. 期间可以通过指令在纵坐标轴方向进行偏移
  offsetY为正数表示正向偏移,为负数表示负向偏移
 
  给定的横坐标终点值E 以及若干条绘制指令
  请计算绘制的直线和横坐标轴以及x=E的直线组成的图形面积
  输入描述:
  首行为两个整数N 和 E
  表示有N条指令,机器运行的横坐标终点值E
  接下来N行 每行两个整数表示一条绘制指令x offsetY
  用例保证横坐标x以递增排序的方式出现
  且不会出现相同横坐标x
  取值范围:
  0<N<=10000
  0<=x<=E<=20000
  -10000<=offsetY<=10000
 
  输出描述:
  一个整数表示计算得到的面积 用例保证结果范围在0到4294967295之内
  示例1:
  输入:
  4 10
  1 1
  2 1
  3 1
  4 -2
  输出:
  12
 
  示例2:
  输入:
  2 4
  0 1
  2 -2
  输出:
  4

在这里插入图片描述

    // 这个通过率好像只有95%,没有具体的测试数据,我也不知道哪里有问题
    // 计算图形面积
    // 解题思路:每个点的面积等于下一个点x值 - 当前点x值 乘以 当前点y的累计值。最后一个点则是:终点x值 - 当前点x值 乘以 当前点y的累计值
    public static void test064() {
        Scanner sc = new Scanner(System.in);
        String line1 = sc.nextLine();
        String[] split1 = line1.split(" ");
        int num = Integer.parseInt(split1[0]);
        int end = Integer.parseInt(split1[1]);
        // 存放x坐标的值
        List<Integer> listX = new ArrayList<>();
        // 存放y坐标的值
        List<Integer> listY = new ArrayList<>();
        for (int i = 0; i < num; i++) {
            String line = sc.nextLine();
            String[] split = line.split(" ");
            listX.add(Integer.parseInt(split[0]));
            listY.add(Integer.parseInt(split[1]));
        }
        // y的累计值
        int sumY = 0;
        // 总面积
        int sumArea = 0;
        for (int i = 0; i < num; i++) {
            // 最后一个点
            if (i == num - 1) {
                // y的累计值
                sumY += listY.get(i);
                // 终点x值 - 当前点x值 乘以 当前点y的累计值
                sumArea += (end - listX.get(i)) * Math.abs(sumY);
            } else {
                // y的累计值
                sumY += listY.get(i);
                // 下一个点x值 - 当前点x值 乘以 当前点y的累计值
                sumArea += (listX.get(i + 1) - listX.get(i)) * Math.abs(sumY);
            }
        }
        System.out.println(sumArea);
    }

63.剩余可用字符集

  给定两个字符集合
  一个是全量字符集
  一个是已占用字符集
  已占用字符集中的字符不能再使用
  要求输出剩余可用字符集
 
  输入描述
  1. 输入一个字符串 一定包含@
 
  @前为全量字符集 @后的为已占用字符集
  2. 已占用字符集中的字符
  一定是全量字符集中的字符
  字符集中的字符跟字符之间使用英文逗号隔开
  3. 每个字符都表示为字符+数字的形式
  用英文冒号分隔
  比如a:1标识一个a字符
  4. 字符只考虑英文字母,区分大小写
  数字只考虑正整型 不超过100
  5. 如果一个字符都没被占用 @标识仍存在
  例如 a:3,b:5,c:2@
  
  输出描述:
  输出可用字符集
  不同的输出字符集之间用回车换行
  注意 输出的字符顺序要跟输入的一致
  不能输出b:3,a:2,c:2
  如果某个字符已全部占用 则不需要再输出
  
  示例一:
  输入
  a:3,b:5,c:2@a:1,b:2
  输出
  a:2,b:3,c:2
  说明:
  全量字符集为三个a,5个b,2个c
  已占用字符集为1个a,2个b
  由于已占用字符不能再使用
  因此剩余可用字符为2个a,3个b,2个c
  因此输出a:2,b:3,c:2
    // 如果全量字符中有重复的,是相加还是取最后一个?? 我做的是相加,如果取最后一个则先remove,在put,就能保证插入顺序
    // 剩余可用字符集
    // 解题思路:使用按插入顺序排列的LinkedHashMap来存储全量字符集,在减掉已用字符集
    public static void test063() {
        Scanner sc = new Scanner(System.in);
        String line = sc.nextLine();
        String[] split = line.split("@");
        // 一个字符都没被占用
        if (line.charAt(line.length() - 1) == '@') {
            System.out.println(line.substring(0, line.length() - 1));
            return;
        }
        String[] allString = split[0].split(",");
        String[] userString = split[1].split(",");
        // LinkedHashMap 按插入顺序排列
        Map<String, Integer> map = new LinkedHashMap<>();
        // 遍历全量字符串,存进LinkedHashMap中
        for (int i = 0; i < allString.length; i++) {
            String[] strAndNum = allString[i].split(":");
            String str = strAndNum[0];
            int num = Integer.parseInt(strAndNum[1]);
            if (map.containsKey(str)) {
                map.put(str, map.get(str) + num);
            } else {
                map.put(str, num);
            }
        }
        // 遍历用过的字符串,在LinkedHashMap中减掉使用的次数
        for (int i = 0; i < userString.length; i++) {
            String[] strAndNum = userString[i].split(":");
            String str = strAndNum[0];
            int num = Integer.parseInt(strAndNum[1]);
            map.put(str, map.get(str) - num);
        }
        // 拼接输出的字符串
        StringBuilder sb = new StringBuilder();
        for (String s : map.keySet()) {
            // 只输出有剩余的字符串
            if (map.get(s) > 0) {
                sb.append(s + ":" + map.get(s) + ",");
            }
        }
        System.out.println(sb.substring(0, sb.length() - 1));
    }

62.字符串解压缩

 有一种简易压缩算法:针对全部为小写英文字母组成的字符串,
 将其中连续超过两个相同字母的部分压缩为连续个数加该字母
 其他部分保持原样不变.
 例如字符串aaabbccccd  经过压缩变成字符串 3abb4cd
 请您编写解压函数,根据输入的字符串,
 判断其是否为合法压缩过的字符串
 若输入合法则输出解压缩后的字符串
 否则输出字符串"!error"来报告错误

 输入描述
 输入一行,为一个ASCII字符串
 长度不超过100字符
 用例保证输出的字符串长度也不会超过100字符串

 输出描述
 若判断输入为合法的经过压缩后的字符串
 则输出压缩前的字符串
 若输入不合法 则输出字符串"!error"

 示例一:
 输入
 4dff
 输出
 ddddff
 说明
 4d扩展为4个d ,故解压后的字符串为ddddff

 示例二
 输入
 2dff
 输出
 !error
 说明
 2个d不需要压缩 故输入不合法

 示例三
 输入
 4d@A
 输出
 !error
 说明
 全部由小写英文字母做成的字符串,压缩后不会出现特殊字符@和大写字母A
 故输入不合法
    // 字符串解压缩
    // 解题思路:遍历每个字符,取出字符前的数字进行解压缩
    public static void test062(){
        Scanner sc = new Scanner(System.in);
        String line = sc.nextLine();
        // 替换掉合法字符
        String replaceAll = line.replaceAll("[1-9]|[a-z]", "");
        // 替换掉合法字符后,长度不为0,则不合法 || 最后一个字符是数字,不合法
        if (replaceAll.length() > 0 || Character.isDigit(line.charAt(line.length() - 1))) {
            System.out.println("!error");
            return;
        }
        // 存放结果
        String resLine = line;
        for (int i = 0; i < line.length(); i++) {
            char c = line.charAt(i);
            // 获取字符前的数字
            if (Character.isDigit(c)){
                int start = i;
                while (Character.isDigit(line.charAt(i+1))){
                    i++;
                }
                int num = Integer.parseInt(line.substring(start, i+1));
                // 2不需要压缩,不合法
                if (num <= 2) {
                    System.out.println("!error");
                    return;
                }
                // 解压缩
                resLine = resLine.replaceFirst(num+"", getString(num, line.charAt(i + 1)));
            }
        }
        System.out.println(resLine);
    }

61. 相等的连续子串

  给你两个字符串t和p
  要求从t中找到一个和p相同的连续子串
  并输出该子串第一个字符的下标
  输入描述
  输入文件包括两行 分别表示字符串t和p
  保证t的长度不小于p
  且t的长度不超过1000000
  p的长度不超过10000
  输出描述
  如果能从t中找到一个和p相等的连续子串,
  则输出该子串第一个字符在t中的下标
  下标从左到右依次为1,2,3,...;
  如果不能则输出 "No"
  如果含有多个这样的子串
  则输出第一个字符下标最小的
 
  示例一:
  输入:
  AVERDXIVYERDIAN
  RDXI
  输出
  4
    // 相等的连续子串
    // 解题思路:双层循环,遍历每个字符,依次判断是否与子串相同,当相同长度与子串相等时,结束并输出;否则进入下一个字符进行判断
    public static void test061() {
        Scanner sc = new Scanner(System.in);
        String t = sc.nextLine();
        String p = sc.nextLine();
        for (int i = 0; i < t.length(); i++) {
            // 开始字符位置
            int start = i;
            // 与子串相同字符个数
            int j = 0;
            // 与子串进行比对
            while (start < t.length() && j < p.length() && t.charAt(start) == p.charAt(j)) {
                // 索引位置向前
                start++;
                // 个数加1
                j++;
            }
            // 当子串相同字符个数 == 子串长度,满足条件,输入并结束
            if (j == p.length()) {
                System.out.println(i + 1);
                return;
            }
        }
        System.out.println("No");
    }

59.员工出勤奖

  公司用一个字符串来标识员工的出勤信息
  absent:    缺勤
  late:      迟到
  leaveearly:早退
  present:   正常上班
 
  现需根据员工出勤信息,判断本次是否能获得出勤奖,
  能获得出勤奖的条件如下:
  1.缺勤不超过1次
  2.没有连续的迟到/早退
  3.任意连续7次考勤 缺勤/迟到/早退 不超过3次
 
  输入描述:
  用户的考勤数据字符串记录条数  >=1
  输入字符串长度 <10000 ;
  不存在非法输入
  如:
  2
  present
  present absent present present leaveearly present absent
 
  输出描述:
  根据考勤数据字符串
  如果能得到考勤奖输出true否则输出false
  对于输出示例的结果应为
  true false
 
  示例一:
  输入:
  2
  present
  present present
  输出:
  true true
 
  示例二
  输入:
  2
  present
  present absent present present leaveearly present absent
  输出:
  true false
    // 员工出勤奖
    // 解题思路:将输入的内容放在集合中,遍历集合,按条件依次判断
    public static void test059() {
        Scanner sc = new Scanner(System.in);
        int num = Integer.parseInt(sc.nextLine());
        List<String> list = new ArrayList<>();
        for (int i = 0; i < num; i++) {
            String line = sc.nextLine();
            list.add(line);
        }
        for (int i = 0; i < list.size(); i++) {
            String str = list.get(i);
            String[] split = str.split(" ");
            // 1.缺勤不超过1次
            int absentCount = 0;
            for (int j = 0; j < split.length; j++) {
                if ("absent".equals(split[j])) {
                    absentCount++;
                }
            }
            if (absentCount > 1) {
                System.out.print(false + " ");
                // 退出此次循环
                continue;
            }
            // 2.没有连续的迟到/早退
            if (str.contains("late leaveearly") || str.contains("leaveearly late") || str.contains("leaveearly leaveearly") || str.contains("late late")) {
                System.out.print(false + " ");
                // 退出此次循环
                continue;
            }
            // 3.任意连续7次考勤 缺勤/迟到/早退 不超过3次
            // 用于存放 缺勤/迟到/早退 最大次数
            int count = 0;
            // 用于存放 缺勤/迟到/早退 临时次数
            int noPresent = 0;
            if (split.length > 7) {
                for (int j = 0; j + 7 <= split.length; j++) {
                    for (int k = j; k < 7 + j; k++) {
                        if ("absent".equals(split[k]) || "late".equals(split[k]) || "leaveearly".equals(split[k])) {
                            noPresent++;
                        }
                    }
                    count = Math.max(count, noPresent);
                    noPresent = 0;
                }
            } else {
                for (int j = 0; j < split.length; j++) {
                    if ("absent".equals(split[j]) || "late".equals(split[j]) || "leaveearly".equals(split[j])) {
                        count++;
                    }
                }
            }
            if (count > 3) {
                System.out.print(false + " ");
                // 退出此次循环
                continue;
            }
            // 都符合,则输出true
            System.out.print(true + " ");
        }
    }

更多华为od机试题请点这里<华为od机试题4 真题>,每篇8题,有更多的题也请告诉我啊

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

华为od机试题3 真题 的相关文章

  • Objective-C 相当于 Java 枚举或“静态最终”对象

    我试图找到一个与 Java 枚举类型或 public static final 对象等效的 Objective C 例如 public enum MyEnum private String str private int val FOO f
  • 如何打印JTable中选定的行

    我尝试使用主 JTable 的选定行和相同的头和单元格渲染来创建临时 JTable 但是当我尝试打印它时 我只得到一个带有线边框的空矩形 我在如何打印 JTable 的特定行 列 https stackoverflow com questi
  • Java 比 Xmx 参数消耗更多内存

    我有一个非常简单的 Web 服务器类 基于 Java SEHttpServer class 当我使用此命令启动编译的类来限制内存使用时 java Xmx5m Xss5m Xrs Xint Xbatch Test 现在如果我使用检查内存top
  • 如何将参数传递给Workmanager DoWork方法

    我想安排任务在 24 小时后从数据库中删除 public class WorkManager extends Worker public WorkManager NonNull Context context NonNull WorkerP
  • 图像在 3D 空间中绕 Y 轴旋转

    我有一个 BufferedImage 我想用 theta 角而不是仿射变换绕 Java 中的 Y 轴旋转图像 图片 旋转将如下图所示 矩形将是图像 我可以通过旋转图像的每个像素并绘制图像来做到这一点 因为我必须旋转很多图像 所以我认为这不是
  • bean 的 CDI @TransactionAttribute

    我正在尝试CDI在测试应用程序上 我有一个DAO它注入一个托管的容器JTA像这样的持久化上下文 public class TestDAO implements Serializable PersistenceContext private
  • Java:Swing:设置JButton的位置

    我想实现以下布局 OK
  • Jboss EAP 7 - 如何从部署中排除隐式模块(javax.jms)?

    我没想到我会来到这里 但经过大量 Google 和 StackOverflow 搜索后 我来到了这里 这就是我的确切问题 https www linkedin com pulse tale two jars marco antonio al
  • 如何在 Android 中签署 AAR Artifacts?

    我目前正在开发一个 AAR android 库 我想用我自己的密钥对已发布的工件进行签名 以便我可以确定我是否发布了具有相同名称和功能的假 aar 注意事项1 我希望能够以编程方式检查我的库的真实性 即使是一个伪造的库 只是伪造了我的 aa
  • 如何使用Gson将JSONArray转换为List?

    在我的 Android 项目中 我试图将收到的 JSONArray 转换为列表 在 的帮助下这个答案 https stackoverflow com questions 8371274 how to parse json array in
  • 如何防止我的 servlet 被其他网站调用

    好的 我有一个像这样的简单的 servlet public class SimpleServlet extends HttpServlet public void doPost HttpServletRequest req HttpServ
  • 相对重力

    我最近开始使用jMonkey引擎 这非常好 但我在尝试实现相对重力时陷入了困境 我想让行星彼此围绕轨道运行 不一定是完美的圆形轨道 取决于速度 所以每个对象都应该影响其他对象 我现在拥有的 关闭全球重力 bulletAppState get
  • 如何在不冒 StackOverflowError 风险的情况下使用 CompletableFuture?

    我想遍历异步函数的搜索空间 我将逻辑编码如下 Assuming that a function maps a range of inputs to the same output value minimizes the input valu
  • 是否有适用于 Java 的 CalDAV 客户端库? [关闭]

    很难说出这里问的是什么 这个问题是含糊的 模糊的 不完整的 过于宽泛的或修辞性的 无法以目前的形式得到合理的回答 如需帮助澄清此问题以便重新打开 访问帮助中心 help reopen questions 我想使用 CalDAV 协议与我的日
  • Java中如何将Object[]转换为String[]?

    我有一个关于 Java 的问题 我有一个Object Java默认的 不是用户定义的 我想将它转换为String 谁能帮我 谢谢 这是转换 for int i 0 i lt objectArr length i try strArr i o
  • 将序列化数据发送到 servlet 时出现 java.io.EOFException

    我正在尝试从 Java 本地应用程序上传一个包含文件到服务器的对象 我的计划是 在 tomcat 上运行的 servlet 将使用以下方法获取对象ObjectInputStream in the doGet方法 但我得到一个EOFExcep
  • Spring Boot 中的服务限流能力

    有什么办法可以实现Spring中其余服务的服务限制能力 特别是Spring boot 这里的期望是 我的服务暴露于外界 目前每秒 分钟的服务调用数量没有限制 我们希望通过设置限制来控制这一点 我有一个替代选项 通过跟踪并发哈希映射或任何缓存
  • java.lang.IllegalStateException:FragmentManager 已被销毁

    活动中onResume我称之为 volley request 的方法 它获取项目列表 然后将它们加载到此活动内的 ListFragment 中 当我第一次进入活动时 一切正常 但当我重新进入活动时 ListFragment 为空 并且控制台
  • 如何预先填充 JFileChooser 将“文件名”?

    我打算用数据库中的名称填充 JFileChooser 但使用标准 JFileChooser 对话框进行加载 删除 保存和另存为 我想给用户留下这样的印象 他们正在处理文件系统 而在后端使用数据库来保存更改 用户不应该能够浏览到不同的目录进行
  • 如何将元素添加到通用集合

    我想知道如何将专用对象添加到通用集合中 我正在使用以下代码 Collection

随机推荐

  • 解决Java JPA Es索引时间戳字符串格式比较问题

    说明 在Java开发中常见使用 yyyy MM dd HH mm ss 来格式化时间戳 例如 ApiModelProperty 订单开始日期 JsonFormat pattern yyyy MM dd HH mm ss JSONField
  • 华为云云耀云服务器L实例评测|在云耀云服务器L实例上部署battle-city坦克大战小游戏

    华为云云耀云服务器L实例评测 在云耀云服务器L实例上部署battle city坦克大战小游戏 一 前言 1 1 云耀云服务器L实例简介 1 2 battle city坦克大战小游戏简介 二 本次实践介绍 2 1 本次实践简介 2 2 本次环
  • 数据结构与算法书籍推荐

    学习数据结构与算法 还是很有必要看几本相关的书籍 但根据不同基础的人 合适看的书也不一样 因此 针对不同层次 不同语言的人 推荐几本市面上口碑不错的书 1 入门级 针对刚入门的同学 建议不要急着去看那些经典书 像 算法导论 算法 这些比较经
  • Python入门--变量

    变量是指在程序运行期间可以改变其值的数据类型 在Python中 变量可以指定任何数据类型 如字符串 整数 浮点数等 要创建一个变量 我们必须先指定变量的名称 然后将其赋值 在Python中 变量名可以是任何有意义的名称 但通常使用小写字母和
  • 【Leetcode】151. 翻转字符串里的单词

    题目描述 给你一个字符串 s 逐个翻转字符串中的所有 单词 单词 是由非空格字符组成的字符串 s 中使用至少一个空格将字符串中的 单词 分隔开 请你返回一个翻转 s 中单词顺序并用单个空格相连的字符串 说明 输入字符串 s 可以在前面 后面
  • Android免打包多渠道统计如何实现,BAT面试文档

    我们程序员经常迷茫于有太多东西要学 有些找不到方向 不知所措 很多程序员都愿意说 我想变得更好 但是更好是什么却很模糊 同时我们又不知道该怎么样去做 我们的生命如此短暂 作为程序员的职业生涯可能会更短 所以我们更加需要充分利用工作 工作间隙
  • opencv resize()函数

    转自 https blog csdn net u012005313 article details 51943442 void resize InputArray src OutputArray dst Size dsize double
  • 在ping服务器时丢包该怎么办?

    一般跨境企业比如说跨境电商 游戏等等都会有海外各个节点服务器的需求 包括对海外服务器的需求 当使用服务器时 难免会出现一些问题 比如说丢包 那么 当服务器丢包的话 该如何处理呢 说到丢包 我们一般是在说PING服务器IP出现的数据包丢失的现
  • ASP.NET Core快速入门(第6章:ASP.NET Core MVC)--学习笔记

    课程链接 http video jessetalk cn course explore 良心课程 大家一起来学习哈 任务40 介绍 任务41 Individual authentication 模板 dotnet new mvc help
  • ChatGPT使用学习(三):ChatGPT桌面版使用

    文章目录 介绍 获取方式 界面展示 介绍 ChatGPT桌面版是指OpenAI推出的针对个人用户的ChatGPT应用程序 它是一个独立的桌面应用程序 可以在本地计算机上运行 而无需依赖互联网连接 这使得用户可以在没有网络连接的情况下使用Ch
  • 论文必备

    点击上方 小白学视觉 选择加 星标 或 置顶 重磅干货 第一时间送达 本文介绍了了12个将神经网络画地更好看的工具 1 draw convnet 一个用于画卷积神经网络的Python脚本 https github com gwding dr
  • 基于单片机的热敏电阻测温设计

    基于单片机的热敏电阻测温设计 1 基本功能 1 具有声光报警功能 2 使用液晶显示 3 温度上 下限报警值设定 温度上 下限报警 4 手动方式设定温度上下限 总体方案设计 温度控制系统主要由温度传感器 热敏电阻 A D转换器 单片机 STC
  • USB硬件设计注意事项

    USB物理层介绍及电路设计注意事项 博文原创 转载请注明出处 USB Universal Serial Bus USB 是英文Universal Serial Bus 通用串行总线的缩写 是一个外部总线标准 用于规范电脑与外部设备的连接和通
  • 【Hello mysql】 mysql的索引

    Mysql专栏 Mysql 本篇博客简介 介绍mysql的索引 mysql索引 索引 索引是什么 索引的分类 索引作用查看 磁盘 mysql的工作过程 认识磁盘 定位扇区 磁盘随机访问 Random Access 与连续访问 Sequent
  • PYTHON编程导论群问题汇总(四)

    Q6 函数局部变量赋值问题 P37 print语句后面的赋值语句使x成为函数g中的局部变量 执行print语句时还没有被赋值 报错的原因不是很理解 bigjing 在回答这个问题前 我们先理解一个规则 全局变量和局部变量同名的时候 局部变量
  • redux-saga原理浅析

    前言 笔者最近在做一些后台项目 使用的是Ant Design Pro 其使用了redux saga处理异步数据流 本文将对redux saga的原理做一个简单的解读 并将实现一个简易版的redux saga Generator函数的自动流程
  • filter() map(),some() every(),find(),findIndex(),reduce()区别和用法

    some every map filter find foreach 一 相同点 1 都是返回布尔值 some every map 2 遍历全部元素 every map 都是遍历完全部元素 3 遇到匹配结果即停止 find some 遇到匹
  • Mac安装SQLmap【亲测有用】

    sqlmap是由Python编写的渗透测试工具 主要用来检测sql注入漏洞 是一款功能强大的sql漏洞检测利用工具 Mac安装SQLmap有很多种方式 此篇文章使用brew install 简单直接 安装过brew的直接忽略前两步 在mac
  • 剑指offer——day1

    题目一 题目主要考察的是对栈和队列的理解和基本实现 typedef int STDataType define DEFSTACKSIZE 100 typedef struct Stack STDataType array int size
  • 华为od机试题3 真题

    华为od机试题 真题 67 最小字符串 66 最长元音字符串 65 字母所在字符串中的位置索引 64 计算图形面积 63 剩余可用字符集 62 字符串解压缩 61 相等的连续子串 59 员工出勤奖 以下题目附带Java解法 是我个人写的 不