华为机试题_提取不重复的整数/明明的随机数/字符串分隔

01_提取不重复的整数

题目描述

输入一个int型整数,按照从右向左的阅读顺序,返回一个不含重复数字的新的整数。
输入描述:输入一个int型整数
输出描述:按照从右向左的阅读顺序,返回一个不含重复数字的新的整数
输入:9876673 输出:37689

解题思路

因为要得到逆序并且无重复的新整数,就相当于将字符串反转再去重。我们可以把输入当做字符串来处理,但是题目要求输入是int型的整数,因此我们首先将输入的整型数转换为字符串型,然后再用StringBuffer来接收这个字符串,因为StringBuffe类有reverse()这个字符串反转的函数,方便我们对字符串进行反转,然后将字符串中的字符挨个加入到Set中进行去重操作,加入一个输出一个。因为Set不接收重复元素,因此就完成了字符串的去重。

java代码实现:

import java.util.*;
public class 提取不重复的整数 {
    public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);
    Set set = new HashSet();
    StringBuffer sb = new StringBuffer(Integer.toString(sc.nextInt()));
    sb.reverse(); // 引入StringBuffer是为了方便反转输入的字符串
    for (int i = 0; i < sb.length(); i++) {
        if (set.add(sb.substring(i, i + 1))) { // set不允许重复添加相同的元素
        System.out.print(sb.substring(i, i + 1));
        }
    }
    }
}

02_明明的随机数

题目描述

明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性,他先用计算机生成了N个1到1000之间的随机整数(N≤1000),对于其中重复的数字,只保留一个,把其余相同的数去掉,不同的数对应着不同的学生的学号。然后再把这些数从小到大排序,按照排好的顺序去找同学做调查。请你协助明明完成“去重”与“排序”的工作(同一个测试用例里可能会有多组数据,希望大家能正确处理)。

注:测试用例保证输入参数的正确性,答题者无需验证。测试用例不止一组。
输入描述:
输入多行,先输入随机整数的个数,再输入相应个数的整数
输出描述:
返回多行,处理后的结果
示例1
输入
11
10
20
40
32
67
40
20
89
300
400
15
输出
10
15
20
32
40
67
89
300
400

解题思路

题目要求很简单,1.去重;2.排序。先用HashSet进行去重,在进行排序即可。顺序不可颠倒,因为Set的存储顺序和取出顺序不一致,如果先进行排序,取出时顺序会再次打乱。

java代码实现:

import java.util.*;

public class Main {

    public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);
        while(sc.hasNext()) {
    int n = sc.nextInt();
    HashSet<Integer> inputArray = new HashSet<>();
    for (int i = 0; i < n; i++) {
        inputArray.add(sc.nextInt());
    }
    Object[] outputArray = inputArray.toArray();
    Arrays.sort(outputArray);
    for (Object q : outputArray)
        System.out.println(q);
    }
}
}

03_字符串分隔

题目描述

•连续输入字符串,请按长度为8拆分每个字符串后输出到新的字符串数组;
•长度不是8整数倍的字符串请在后面补数字0,空字符串不处理。
输入描述:
连续输入字符串(输入2次,每个字符串长度小于100)
输出描述:
输出到长度为8的新字符串数组
示例1
输入
abc
123456789
输出
abc00000
12345678
90000000

解题思路

字符串长度可能为8的倍数,也可能不是。不管长度为多少,直接先补7个0再说。为啥补7个0,如果长度刚好为8*n,那,那么7个0到最后被过滤掉,不产生影响。如果不为8*n,那么剩下的字符个数最多为7,最少为1。为7时,用到一个0去补齐,剩余6个0到最后被过滤掉;为1时,补上7个0刚刚好。 如果长度超过 8 ,直接截取前8个字符并输出,然后让字符串等于原字符串第8位到最后一位。接着再判断长度是否大于等于8。这样,即使之前多加了0,多余的0也不可能超过8个。自然就将其过滤掉。
按照题目要求,每次输入两个字符串,因此我们每次接收两个字符串分开进行处理。也可以加while(sc.hasNeXt()) 多次输入进行判断。

java代码实现:

import java.util.Scanner;

public class Main {

    public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);
    String s1 = sc.nextLine();
    String s2 = sc.nextLine();
    s1 = s1 + "0000000";
    s2 = s2 + "0000000";
    //不管长度为多少,直接先补7个0再说
    while (s1.length() >= 8) {
        System.out.println(s1.substring(0, 8));
        s1 = s1.substring(8);
      //截取前8个字符
    }
    while (s2.length() >= 8) {
        System.out.println(s2.substring(0, 8));
        s2 = s2.substring(8);
    }
    }
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
昨天 20:55
阿里国际 Java工程师 2.7k*16.0
程序员猪皮:没有超过3k的,不太好选。春招再看看
点赞 评论 收藏
分享
11-07 13:31
怀化学院 Java
勇敢牛牛不怕难:又疯一个
点赞 评论 收藏
分享
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务