2017真题1--

1----统计字符

链接:https://www.nowcoder.com/questionTerminal/e3f67da21c3f45bfb091cf0cabb9bb0f
来源:牛客网

给定一个英文字符串,请写一段代码找出这个字符串中首先出现三次的那个英文字符。

输入描述:
输入数据一个字符串,包括字母,数字等。


输出描述:
输出首先出现三次的那个英文字符
示例1

输入

Have you ever gone shopping and

输出

e
import java.util.*;
public class Main{
    public static void main(String[] args){
        Scanner sc = new Scanner(System.in);
        StringBuilder str = new StringBuilder();
        str.append(sc.nextLine());
        char[] c = str.toString().trim().toCharArray();
        int[] a = new int[127];
        for(char s : c){
            a[s]++;
            if((s >= 'a' && s <= 'z' || s >= 'A' && s <= 'Z') && a[s] == 3){
                System.out.print(s);
                break;
            }
        }
    }
}


方法二

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.HashMap;
import java.util.Map;
 
public class Main {
 
    //统计字符
    public static void main(String[] args) throws IOException {
         
        BufferedReader bf = new BufferedReader(new InputStreamReader(System.in));
        char[] c = bf.readLine().toCharArray();
        Map<Character,Integer> map = new HashMap<Character,Integer>();
        for(int i=0; i<c.length; i++){
            if(!(c[i]>='a'&&c[i]<='z') && !(c[i]>='A'&&c[i]<='z'))
                continue;
            if(!map.containsKey(c[i])){
                map.put(c[i], 1);
            }
            else{
                int val = map.get(c[i])+1;
                if(val == 3){
                    System.out.println(c[i]);
                    break;
                }
                map.put(c[i],val);
            }
        }
        bf.close();
    }
}

2--- 句子反转

链接:https://www.nowcoder.com/questionTerminal/0ae4a12ab0a048ee900d1536a6e98315
来源:牛客网

给定一个句子(只包含字母和空格), 将句子中的单词位置反转,单词用空格分割, 单词之间只有一个空格,前后没有空格。 比如: (1) “helloxiao mi”-> “mi xiao hello”

输入描述:
输入数据有多组,每组占一行,包含一个句子(句子长度小于1000个字符)


输出描述:
对于每个测试示例,要求输出句子中单词反转后形成的句子
示例1

输入

hello xiao mi

输出

mi xiao hello
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
 
public class Main {
 
    public static void main(String[] args) throws IOException {
        BufferedReader brs = new BufferedReader(new InputStreamReader(System.in));
        String inputString = brs.readLine();
        String[] numbers = inputString.split(" ");
        // 字符分割后,倒序输出即可
        for (int i = numbers.length - 1; i >= 0; i--) {
            if (i == 0) {
                System.out.print(numbers[i]);
            } else {
                System.out.print(numbers[i] + " ");
            }
        }
 
    }
}

3--- 水仙花数

链接:https://www.nowcoder.com/questionTerminal/dc943274e8254a9eb074298fb2084703
来源:牛客网

春天是鲜花的季节,水仙花就是其中最迷人的代表,数学上有个水仙花数,他是这样定义的:“水仙花数”是指一个三位数,它的各位数字的立方和等于其本身,比如:153=1^3+5^3+3^3。 现在要求输出所有在m和n范围内的水仙花数。

输入描述:
输入数据有多组,每组占一行,包括两个整数m和n(100 ≤ m ≤ n ≤ 999)。


输出描述:
对于每个测试实例,要求输出所有在给定范围内的水仙花数,就是说,输出的水仙花数必须大于等于m,并且小于等于n,如果有多个,则要求从小到大排列在一行内输出,之间用一个空格隔开;
如果给定的范围内不存在水仙花数,则输出no;
每个测试实例的输出占一行。
示例1

输入

100 120
300 380

输出

no
370 371

import java.util.*;
public class Main{
    public static void main(String[] args){
        Scanner cin=new Scanner(System.in);
        String[] data=new String[2];
        int[] array=new int[2];
        while(cin.hasNextLine()){
            int lo=cin.nextInt();
            int hi=cin.nextInt();
            boolean flag=false;//判断是否含有水仙花数
            String line="";//用来保存结果
            for(int i=lo;i<=hi;i++){
                int b=i/100;
                int s=(i%100)/10;
                int g=i-100*b-10*s;
                if(g*g*g+s*s*s+b*b*b==i){
                    line+=i+" ";
                    flag=true;
                }
            }
            if(!flag)System.out.println("no");
            else System.out.println(line.substring(0,line.length()-1));
             
        }
    }
}

4--- 数串

链接:https://www.nowcoder.com/questionTerminal/a6a656249f404eb498d16b2f8eaa2c60
来源:牛客网

设有n个正整数,将他们连接成一排,组成一个最大的多位整数。
如:n=3时,3个整数13,312,343,连成的最大整数为34331213。
如:n=4时,4个整数7,13,4,246连接成的最大整数为7424613。

输入描述:
有多组测试样例,每组测试样例包含两行,第一行为一个整数N(N<=100),第二行包含N个数(每个数不超过1000,空格分开)。


输出描述:
每组数据输出一个表示最大的整数。
示例1

输入

2
12 123
4
7 13 4 246

输出

12312
7424613
链接:https://www.nowcoder.com/questionTerminal/a6a656249f404eb498d16b2f8eaa2c60
来源:牛客网

import java.util.*;
 
public class Main{
    public static void main(String[] args){
        Scanner scan=new Scanner(System.in);
        while(scan.hasNext()){
            int num=scan.nextInt();
            String[] list=new String[num];
            StringBuffer sb=new StringBuffer();
            for(int i=0;i<num;i++){
                list[i]=String.valueOf(scan.nextInt());
            }
            Arrays.sort(list,new Comparator<String>(){
                public int compare(String a,String b){
                    String temp1=a+b;
                    String temp2=b+a;
                    return temp2.compareTo(temp1);
                }
            });
            for(int i=0;i<num;i++){
                sb.append(list[i]);
            }
            System.out.println(sb.toString());
        }
        scan.close();
    }
}






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值