最新那些年,我们一起做过的 Java 课后练习题(16 - 20)(1),Java春招实习面试经验汇总

总目录展示

该笔记共八个节点(由浅入深),分为三大模块。

高性能。 秒杀涉及大量的并发读和并发写,因此支持高并发访问这点非常关键。该笔记将从设计数据的动静分离方案、热点的发现与隔离、请求的削峰与分层过滤、服务端的极致优化这4个方面重点介绍。

一致性。 秒杀中商品减库存的实现方式同样关键。可想而知,有限数量的商品在同一时刻被很多倍的请求同时来减库存,减库存又分为“拍下减库存”“付款减库存”以及预扣等几种,在大并发更新的过程中都要保证数据的准确性,其难度可想而知。因此,将用一个节点来专门讲解如何设计秒杀减库存方案。

高可用。 虽然介绍了很多极致的优化思路,但现实中总难免出现一些我们考虑不到的情况,所以要保证系统的高可用和正确性,还要设计一个PlanB来兜底,以便在最坏情况发生时仍然能够从容应对。笔记的最后,将带你思考可以从哪些环节来设计兜底方案。


篇幅有限,无法一个模块一个模块详细的展示(这些要点都收集在了这份《高并发秒杀顶级教程》里),麻烦各位转发一下(可以帮助更多的人看到哟!)

由于内容太多,这里只截取部分的内容。

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

分别将 a、b、c 和 x、y、z 进行配对,然后除开不符合题意的组合,最后得出的结果就是比赛名单。主要还是利用 for 循环和 if 条件判断来实现!

实现

/**

  • Created with IntelliJ IDEA.

  • @author : cunyu

  • @version : 1.0

  • @email : 747731461@qq.com

  • @website : https://cunyu1943.github.io

  • @date : 2021/6/3 13:08

  • @project : Java 编程实例

  • @package : PACKAGE_NAME

  • @className : Example18

  • @description :

*/

public class Example18 {

static char[] teamA = {‘a’, ‘b’, ‘c’};

static char[] teamB = {‘x’, ‘y’, ‘z’};

public static void main(String[] args) {

int size = teamA.length;

System.out.println(“对战名单如下:”);

for (int i = 0; i < size; i++) {

for (int j = 0; j < size; j++) {

if (teamA[i] == ‘a’ && teamB[j] == ‘x’) {

continue;

} else if (teamA[i] == ‘a’ && teamB[j] == ‘y’) {

continue;

} else if ((teamA[i] == ‘c’ && teamB[j] == ‘x’) || (teamA[i] == ‘c’ && teamB[j] == ‘z’)) {

continue;

} else if (((teamA[i] == ‘b’ && teamB[j] == ‘z’) || (teamA[i] == ‘b’ && teamB[j] == ‘y’))) {

continue;

} else {

System.out.println(teamA[i] + " VS " + teamB[j]);

}

}

}

}

}

结果

实例 19


题目

实现打印输出一个菱形。








分析

将菱形分为上下部分,然后穿插打印空格和 * 即可。

实现

import java.util.Scanner;

/**

  • Created with IntelliJ IDEA.

  • @author : cunyu

  • @version : 1.0

  • @email : 747731461@qq.com

  • @website : https://cunyu1943.github.io

  • @date : 2021/6/3 13:30

  • @project : Java 编程实例

  • @package : PACKAGE_NAME

  • @className : Example19

  • @description :

*/

public class Example19 {

public static void main(String[] args) {

Scanner scanner = new Scanner(System.in);

System.out.println(“输入需要打印的行数”);

int row = scanner.nextInt();

if (row % 2 == 0) {

// 计算菱形大小,将其分为上下部分

row++;

}

for (int i = 0; i < row / 2 + 1; i++) {

for (int j = row / 2 + 1; j > i + 1; j–) {

// 输出左上角位置的空白

System.out.print(" ");

}

for (int j = 0; j < 2 * i + 1; j++) {

// 输出菱形上半部边缘

System.out.print(“*”);

}

System.out.println(); // 换行

}

for (int i = row / 2 + 1; i < row; i++) {

for (int j = 0; j < i - row / 2; j++) {

// 输出菱形左下角空白

System.out.print(" ");

}

for (int j = 0; j < 2 * row - 1 - 2 * i; j++) {

// 输出菱形下半部边缘

System.out.print(“*”);

}

// 换行

System.out.println();

}

}

}

结果

实例 20


题目

有一个分数序列:2/1、3/2、5/3、8/5、……,求出该数列的前 20 项之和。

分析

观察序列可知,从第二项开始,当前分数的分子就等于上一个分数的分子分母之和,分母就等于上一个分数的分子,根据此规律,对分数序列进行求和即可!

实现

/**

  • Created with IntelliJ IDEA.

  • @author : cunyu

  • @version : 1.0

  • @email : 747731461@qq.com

  • @website : https://cunyu1943.github.io

  • @date : 2021/6/3 13:30

  • @project : Java 编程实例

  • @package : PACKAGE_NAME

  • @className : Example20

  • @description :

*/

public class Example20 {

public static void main(String[] args) {

double sum = 0.0d;

// 分母

总结

面试前的“练手”还是很重要的,所以开始面试之前一定要准备好啊,不然也是耽搁面试官和自己的时间。

我自己是刷了不少面试题的,所以在面试过程中才能够做到心中有数,基本上会清楚面试过程中会问到哪些知识点,高频题又有哪些,所以刷题是面试前期准备过程中非常重要的一点。

面试题及解析总结

三年Java开发,刚从美团、京东、阿里面试归来,分享个人面经

大厂面试场景

三年Java开发,刚从美团、京东、阿里面试归来,分享个人面经

知识点总结

三年Java开发,刚从美团、京东、阿里面试归来,分享个人面经

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

面试题及解析总结

[外链图片转存中…(img-SnRU9SDo-1715683389092)]

大厂面试场景

[外链图片转存中…(img-ARw09Ebg-1715683389093)]

知识点总结

[外链图片转存中…(img-NKZmJXG8-1715683389093)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

  • 30
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值