1----统计字符
链接:https://www.nowcoder.com/questionTerminal/e3f67da21c3f45bfb091cf0cabb9bb0f
来源:牛客网
给定一个英文字符串,请写一段代码找出这个字符串中首先出现三次的那个英文字符。
输入描述:
输入数据一个字符串,包括字母,数字等。
输出描述:
输出首先出现三次的那个英文字符
输入
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个字符)
输出描述:
对于每个测试示例,要求输出句子中单词反转后形成的句子
输入
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; 每个测试实例的输出占一行。
输入
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,空格分开)。
输出描述:
每组数据输出一个表示最大的整数。
输入
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();
}
}