科大讯飞实习java一面

科大讯飞一面7.2

介绍一个项目相关,问的是对一些中间件的使用,架构

八股:

线程池参数的使用,以及如何挑选对应的线程池

线程池的工作流程

linux的基本命令,查看端口,

在linux上如何用命令查看日志文件里面的“error”的个数,并且统计行数

linux里面的 | 的管道符

jwt的组成和用法

mysql的默认事务隔离级别,解决什么问题,不能解决什么问题

MVVC的机制

undo_log的两个作用

bin_log作用

连接池的问题,有什么连接池?

列举Http协议里面请求头常见的字段

docker的使用

nginx的应用场景

如何解决跨域问题

Redis的哨兵机制(流程没答好)

哨兵节点怎么感知其他节点的存在

客户端连接哨兵节点,他是怎么感知其他哨兵的存在

场景题:

程序里面连接不上数据库,连接数据库偶尔提示连接超时,怎么去排查(只答了并发过载,节点切换,日志频繁,没答上连接池)

自己如何搭建哨兵机制(写配置文件,启动)

当运行程序发生CPU飙升怎么排查问题(这里应该答jvm排查线程,不是系统排查)

其他问题:

有没有遇到过学习或者做项目的时候问题以及排解

为什么说你有一定的学习能力

有没有用过大模型

有没有参与过团队合作

如何协调学习和自习

学习会不会遇到其他人的干预

反问

评价

公司的主要业务流程

后续流程

实习周期

#科大讯飞求职进展汇总#
全部评论
有算法题么
点赞 回复 分享
发布于 2024-07-28 21:04 安徽
大佬太牛了,收藏了
点赞 回复 分享
发布于 2024-07-25 21:42 广东
啥学历?为啥我打招呼都不理我😵
点赞 回复 分享
发布于 2024-07-11 16:42 湖南

相关推荐

中途加入只写了1,3,第二题没看懂要干啥第一题:优先队列 + 贪心可以想到贪心,先把所有的数给拆出来,比如[11, 299],拆成[9,9,2,1,1],然后贪心,把大的数放在位数高的那个元素就行了,比如例子中可以变成[(1,2), (2,3)]表示第一个数有两位,第二个数有三位,然后放入优先队列,首先取出第二个元素,将第三位变成9,现在第二个元素只剩两位了,继续放入优先队列,按照该顺序写就OK。代码如下:#include <bits/stdc++.h>using namespace std;const int N = 2e5 + 10;int a[N] ,h[10];pair<int, int> b[N];int main() {int n;cin >> n;priority_queue<pair<int, int>> pq;for (int i = 0; i < n; i ++) {cin >> a[i];b[i].second = i;while (a[i]) {h[a[i] % 10] ++;a[i] /= 10;b[i].first ++;}pq.push(b[i]);}while(pq.size() > 0) {pair<int, int> t = pq.top();pq.pop();int num = 0;for (int i = 9; i >= 0; i --) {if (h[i] != 0) {h[i] --;num = i;break;}}a[t.second] = a[t.second] * 10 + num;t.first--;if (t.first !=0) {pq.push(t);}}long long res = 0;for (int i = 0; i < n; i ++) res += a[i];cout << res;}第三题:组合数首先要推公式,如果两个数a[i]和a[j]之间有n个0,设z = a[j] - a[i], 有多少种可能的序列,设为f(z, n),C是组合数。当n = 1 时,记为f(z, 1),很简单,该0可能是a[i] - a[j]之间的任何数,有z + 1 种可能,f(z, 1) = z + 1 = C(z+1, 1)。当n = 2 时,固定第一个0,如果第一个0为x,那么第二个0就和n = 1 时一样,此时枚举第一个0从[0-z],f(z, 2) = f(z,1) +f(z-1,1) + ...+f(1, 1) + f(0, 1) = 1 +... +z+1 = C(z+2, 2)。同理, n=3时,同理枚举第一个0。f(z, 3) = f(z, 2) +... f(0, 2) = C(z+2, 2) + C (z + 1, 2) + ... C(2, 2) = C(z+3, 3)可以看出来f(z, n) = C(z + n, n) = (z +n)!/(n! & z!);#include <bits/stdc++.h>using namespace std;#define int long longconst int p = 1e9 + 7;const int N = 6e5 + 10;int a[N];int mul[N], dmul[N];int qs(int a, int b) {int res = 1;while (b) {if (b&1) res = res * a % p;a = a * a % p;b >>= 1;}return res;}int C(int n, int m) {int cc = 1;for (int i = n - m + 1; i <= n; i ++) cc = cc * i %p;return cc * dmul[m] % p;}int lucas(int n, int m) {if (m == 0) return 0;int a = n % p, b = m % p;if (b > a) return 0;return C(a, b) * lucas(n/p, m /p) % p;}signed main() {int n; cin >> n;vector<int> v;int res = 1;mul[0] = dmul[0] = 1;for (int i = 1 ; i < N ; i ++) {mul[i] = mul[i - 1] * i % p;dmul[i] = qs(mul[i], p - 2);}for (int i = 1 ;i <= n; i ++) cin >> a[i];for (int i = 1 ; i < n; ) {if (a[i] == 0) {int j = i;while (a[j] == 0) j++;int d = a[j] - a[i - 1];int z = j - i;res = res * C(z + d, z) % p;i = j;} else i++;}cout << res << '\n';}
投递小红书等公司10个岗位
点赞 评论 收藏
分享
评论
15
73
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务