# 蓝桥集训（附加面试题）第八天

55 篇文章 4 订阅

## 导读

📣小白练手专栏，适合刚入手的新人以及考python二级的同学欢迎订阅编程小白进阶

📣python有趣练手项目里面包括了像《机器人尬聊》《恶搞程序》这样的有趣文章，可以让你快乐学python练手项目专栏

📣另外想学JavaWeb进厂的同学可以看看这个专栏：传送们

📣这是个冲刺大厂面试专栏还有算法比赛练习我们一起加油 上岸之路

## Java蓝桥集训

import java.util.*;
public class Main {
public static int [] MonthDay = {0,31,28,31,30,31,30,31,31,30,31,30,31};
public static void main(String[] args) {
int date,year,month,day;
Scanner scanner = new Scanner(System.in);
date = scanner.nextInt();
year = date / 10000;
month = year % 10 * 10 + year / 10 % 10;
day = year / 1000 + year / 100 % 10 * 10;
//该年对应的回文
if(year * 10000 + month * 100 + day <= date)
++year;
//保证是当前日期之后
while(true) {
month = year % 10 * 10 + year / 10 % 10;
day = year / 1000 + year / 100 % 10 * 10;
if(legel(year,month,day)) {
System.out.println(year * 10000 + month * 100 + day);
break;
}
++year;
}
//找到第一个回文日期
while(true) {
month = year % 10 * 10 + year / 10 % 10;
day = year / 1000 + year / 100 % 10 * 10;
if(legel(year,month,day) && isab(year,month,day)) {
System.out.print(year * 10000 + month * 100 + day);
break;
}
++year;
}
//找到第一个ababbaba型的日期
}
public static boolean legel(int year,int month,int day) {
if((year % 400 == 0) || (year % 4 == 0 && year % 100 != 0))
MonthDay[2] = 29;
else
MonthDay[2] = 28;
//以上是处理闰年
if(month > 12 || month < 1)
return false;
//如果月份不满足那么就不是合法日期
if(day > 0 && day <= MonthDay[month])
return true;
else
return false;
//日份不满足
}
public static boolean isab(int year,int month,int day) {
if(year / 1000 == year % 100 / 10 && year % 100 / 10 == month % 10 && month % 10 == day % 10
&& year / 100 % 10 == year % 10 && year % 10 == month / 10 && month / 10 == day / 10 && day % 10 != day / 10)
return true;
else
return false;
}
}



输入格式


样例输入
ababc
Data

28
Data

a     1
ab    2
aba   2
abab  2
ababc 3
b    1
ba   2
bab  2
babc 3
a   1
ab  2
abc 3
b  1
bc 2
c 1


import java.util.Scanner;
public class dd {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
String str = input.nextLine();
int sum = 0;
int aa = 0;
int mm = 0;
for(int i = 0;i<str.length();i++){
String str1 = str.substring(i,str.length());
mm = kk(str1);
aa = gg(str1,mm);
sum = sum+aa;
}
System.out.println(sum);
}
public static int gg(String str,int mm){
if(str.length()>1){
String str1 = str.substring(0,str.length()-1);
mm=gg(str1,mm);
mm=mm+kk(str1);
}
return mm;
}

public static int kk(String s){
char[] aa = new char[26];
char q= 'a';
for(int i =0 ;i<aa.length;i++){
aa[i]=q;
q++;
}
char[] x = s.toCharArray();
int he=0;
for(int i =0 ;i<x.length;i++){
xx: for(int j =0 ;j<aa.length;j++){
if(x[i]==aa[j]){
aa[j]='0';
he++;
break xx;
}
}
}
return he;

}
}



## 面试题

讲下 Kafka、RabbitMQ、RocketMQ 之间的区别是什么？

RabbitMQ 的单机 QPS 在万级别，Kafka 的单机 QPS 能够达到百万级别。RocketMQ

Kafka 与 RabbitMQ 都具备多副本机制，数据可靠性较高。RocketMQ 支持异步实时刷盘，

Kafka 采用集群部署，分区与多副本的设计，使得单节点宕机对服务无影响，且支持消息容

Kafka 与 RabbitMQ 都是比较主流的两款消息中间件，具备消息传递的基本功能，但在一些

Kafka 的架构说一下？

 生产者（Producer）：消息和数据生产者。
 代理（Broker）：缓存代理，Kafka 的核心功能。
 消费者（Consumer）：消息和数据消费者。
Kafka 给 Producer 和 Consumer 提供注册的接口，数据从 Producer 发送到 Broker，
Broker 承担一个中间缓存和分发的作用，负责分发注册到系统中的 Consumer。



## 点击直接资料领取

• 1
点赞
• 3
收藏
觉得还不错? 一键收藏
• 打赏
• 1
评论
03-09 1677
03-12 619
03-06 706
04-03
03-25
03-17
06-03
05-27
05-21 1144

### “相关推荐”对你有帮助么？

• 非常没帮助
• 没帮助
• 一般
• 有帮助
• 非常有帮助

¥1 ¥2 ¥4 ¥6 ¥10 ¥20

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