千锋教育-做有情怀、有良心、有品质的职业教育机构

领取全套视频

关注千锋学习站小程序
随时随地免费学习课程

当前位置:首页  >  技术要点  >  正文
分享到:

大厂面试 TypeScript 套题,看看你能做出几个

时间:2023-03-21 11:33     来源: 作者:gxy

  某大厂给前端面试者出了一套 TypeScript 笔试题,要求面试者在线实时答题。这种面试题考察的是应聘者的 TS 硬实力,先把题目和要求给出来,你试试能做出来几个。

 TypeScript 笔试题

  一、答题要求

  1、环境搭建

  所有题目均为 NodeJS 环境下,TypeScript 编程题。 NodeJS 版本建议 v14 及以上。代码题以本地可以运行通过为准,Node 版本不够则无法运行高版本语法。 请提前配置好开发环境。

  npm i ts-node -g

  复制代码

  2、依赖

  NodeJS 环境运行 TS 文件推荐使用 ts-node,建议提前安装。

  运行 ts-node 运行第一题命令如下:

  ts-node src/1.reverseWord.ts

  复制代码

  3、tsconfig.json

  {

  "compilerOptions": {

  "target": "es2016",

  "module": "commonjs",

  "esModuleInterop": true,

  "forceConsistentCasingInFileNames": true,

  "strict": true,

  "skipLibCheck": true

  }

  }

  复制代码

  二、笔试题目

  1、objToArray.ts

  /**

  * @file objToArray

  *

  * 将对象按照要求转为数组

  * 注意console示例运行结果

  */

  type Obj = Record;

  interface FormatItem {

  key: string;

  op: string;

  value: string;

  }

  function objToArray(obj: Record): FormatItem[] {

  // 补全此处代码

  throw new Error("功能待实现");

  }

  console.log(

  objToArray({

  key1: {

  op1: "value1",

  },

  key2: {

  op2: "value2",

  },

  })

  );

  // result示例

  // [

  // {key: 'key1', op: 'op1', value: 'value1'},

  // {key: 'key2', op: 'op2', value: 'value2'}

  // ]

  export default {};

  复制代码

  2、reverseWord.ts

  /**

  * @file 反转句子

  *

  * 同时满足以下条件:1、去除首尾空格,2、单词间隔中多个空格变成一个;

  * 注意console示例运行结果

  */

  function reverseWord(str: string) {

  // 补全此处代码

  throw new Error('功能待实现');

  }

  console.log(reverseWord('the sky is blue')); // blue is sky the

  // 去除首尾空格

  console.log(reverseWord(" hello world ")); // world hello

  // 单词间隔中多个空格变成一个

  console.log(reverseWord("a good example")); // example good a

  export default {}

  复制代码

  3、firstSingleChar.ts

  /**

  * @file 找出字符串中第一个只出现一次的字符

  */

  function firstSingleChar(str: string) {

  // 补全此处代码

  throw new Error('功能待实现');

  }

  // a 和 b 都出现了两次,只有 c 出现了一次,返回 c

  console.log(firstSingleChar('abcba')) // c

  // b c d 都出现了一次,返回第一个

  console.log(firstSingleChar('aabcdee')) // b

  // a 和 b 都出现了多次,没有只出现一次的元素,返回 undefined

  console.log(firstSingleChar('aaaabbbb')) // undefined

  export default {}

  复制代码

  4、mergeArray.ts

  /**

  * @file 合并两个有序数组

  */

  function merge(arr: number[], arr2: number[]): number[] {

  // 补全此处代码

  throw new Error('功能待实现');

  }

  // 参数数组从小到大排列

  console.log(merge([1, 2, 3], [2, 5, 6])) // [ 1, 2, 2, 3, 5, 6 ]

  export default {}

  复制代码

  5、map.ts

  /**

  * @file 实现数组 map 方法

  */

  function myMap(arr: T[], callbackFn: (v: T) => R): R[] {

  // 补全此处代码,可以使用除数组 map 以外的其他任何函数

  throw new Error('功能待实现');

  }

  // 测试

  console.log(myMap([1, 2, 3], v => v * 2)) // [2, 4, 6]

  export default {};

  复制代码

  6、bTreePath.ts

  /**

  * @file 二叉树所有路径

  */

  type Tree = {

  value: number;

  left?: Tree;

  right?: Tree;

  }

  const tree: Tree = {

  value: 1,

  left: {

  value: 2,

  right: { value: 5 }

  },

  right: { value: 3 }

  };

  function treePath(root: Tree): string[] {

  // 补全此处代码

  throw new Error('功能待实现');

  }

  console.log(treePath(tree)) // [ '1->2->5', '1->3' ]

  export default {}

  复制代码

  7、mapTree.ts

  /**

  * @file 树结构映射

  * 数组 map 保持数组长度相同,将对应位置元素进行映射。

  * 与之类似,在二叉树 Tree 上的映射我们称为 mapTree,该函数返回一个结构相同的新树,对应位置 value 字段经过 fn 映射。

  */

  type Tree = {

  value: number;

  left?: Tree;

  right?: Tree;

  }

  function mapTree(tree: Tree, fn: (v: number) => number): Tree {

  // 补全此处代码

  throw new Error('功能待实现');

  }

  // 测试

  const tree: Tree = {

  value: 1,

  left: { value: 2 },

  right: { value: 3 }

  };

  console.log(mapTree(tree, v => v * 2)) // { value: 2, left: { value: 4 }, right: { value: 6 } }

  export default {};

  复制代码

  8、product.ts

  /**

  * @file 计算数组笛卡尔积

  */

  // 示例

  product([1, 2], [3, 4]) // [[1, 3], [1, 4], [2, 3], [2, 4]]

  function product(xList: number[], yList: number[]): [number, number][] {

  // 补全内部实现

  throw new Error('功能待实现');

  }

  export default {}

  复制代码

  9、sleep.ts

  /**

  * @file 返回一个 Promise,并在 ms 毫秒后 Promise 变为完成状态

  */

  export function sleep(ms: number): Promise {

  // 补全此处代码

  throw new Error('功能待实现');

  }

  async function main(){

  console.log('a')

  await sleep(1000);

  console.log('b');

  await sleep(1000);

  console.log('c');

  }

  main()

  export default {}

  复制代码

  10、promiseAll.ts

  /**

  * @file 实现 PromiseAll 方法

  */

  import { sleep } from "./8.sleep";

  async function myAll(values: T): Promise<{ [P in keyof T]: Awaited }> {

  // 补全此处代码,使用 Promise.all 以外的语法完成

  throw new Error('功能待实现');

  }

  // 一秒钟后返回结果 value

  async function request(value: string) {

  await sleep(1000);

  return value;

  }

  async function main() {

  console.log('start');

  const res = await myAll([

  request('a'),

  request('b'),

  request('c'),

  ])

  console.log(res); // 预期输出 start 一秒后输出 ['a', 'b', 'c']

  }

  main()

  export default {}

  复制代码

  11、asyncAdd.ts

  /**

  * @file 假设加法是一个异步过程,如何计算多个数组之和?

  */

  function sleep(ms: number) {

  return new Promise(r => {

  setTimeout(() => {

  r(undefined)

  }, ms);

  })

  }

  async function asyncAdd(a: number, b: number) {

  await sleep(1000);

  return a + b;

  }

  function sum(arr: number[]): Promise {

  // 补全这里代码,涉及 arr 中两数求和只能使用 asyncAdd,禁止使用加号

  throw new Error('功能待实现');

  }

  console.time('a')

  sum([1, 2, 3, 4, 5, 6, 7, 8])

  .then(v => {

  console.log(v) // 36

  console.timeEnd('a') // a: <耗时>

  })

  export default {}

  复制代码

  三、参考答案

  1、objToArray.ts

  /**

  * @file objToArray

  *

  * 将对象按照要求转为数组

  * 注意console示例运行结果

  */

  type Obj = Record;

  interface FormatItem {

  key: string;

  op: string;

  value: string;

  }

  function objToArray(obj: Record): FormatItem[] {

  // 参考答案

  return Object.keys(obj).reduce((value: Array, key: string) => {

  var op: string = Object.keys(obj[key])[0];

  value.push({ key: key, op: op, value: obj[key][op] });

  return value;

  }, []);

  }

  console.log(

  objToArray({

  key1: {

  op1: "value1",

  },

  key2: {

  op2: "value2",

  },

  })

  );

  // result示例

  // [

  // {key: 'key1', op: 'op1', value: 'value1'},

  // {key: 'key2', op: 'op2', value: 'value2'}

  // ]

  export default {};

  复制代码

  2、reverseWord.ts

  /**

  * @file 反转句子

  *

  * 同时满足以下条件:1、去除首尾空格,2、单词间隔中多个空格变成一个;

  * 注意console示例运行结果

  */

  function reverseWord(str: string):string {

  // 参考答案

  return (str.match(/\S+/g)).reverse().join(" ");

  }

  console.log(reverseWord('the sky is blue')); // blue is sky the

  // 去除首尾空格

  console.log(reverseWord(" hello world ")); // world hello

  // 单词间隔中多个空格变成一个

  console.log(reverseWord("a good example")); // example good a

  export default {}

  复制代码

  3、firstSingleChar.ts

  /**

  * @file 找出字符串中第一个只出现一次的字符

  */

  function firstSingleChar(str: string) {

  // 参考答案

  return str.split("").filter((item: string, index: number, arr: string[]) => {

  arr.splice(index, 1);

  return !arr.includes(item);

  })[0];

  }

  // a 和 b 都出现了两次,只有 c 出现了一次,返回 c

  console.log(firstSingleChar("abcba")); // c

  // b c d 都出现了一次,返回第一个

  console.log(firstSingleChar("aabcdee")); // b

  // a 和 b 都出现了多次,没有只出现一次的元素,返回 undefined

  console.log(firstSingleChar("aaaabbbb")); // undefined

  console.log(firstSingleChar("dabvb"));

  export default {};

  复制代码

  4、mergeArray.ts

  /**

  * @file 合并两个有序数组

  */

  function merge(arr: number[], arr2: number[]): number[] {

  // 参考答案

  return arr.concat(arr2).sort((a: number, b: number) => a - b);

  }

  // 参数数组从小到大排列

  console.log(merge([1, 2, 3], [2, 5, 6])); // [ 1, 2, 2, 3, 5, 6 ]

  export default {};

  复制代码

  5、map.ts

  /**

  * @file 实现数组 map 方法

  */

  function myMap(arr: T[], callbackFn: (v: T) => R): R[] {

  // 参考答案

  var arr1: R[] = [];

  for (var i = 0; i < arr.length; i++) {

  if (i in arr) arr1[i] = callbackFn(arr[i]);

  }

  return arr1;

  }

  // 测试

  console.log(myMap([1, 2, 3], (v) => v * 2)); // [2, 4, 6]

  export default {};

  复制代码

  6、bTreePath.ts

  /**

  * @file 二叉树所有路径

  */

  type Tree = {

  value: number;

  left?: Tree;

  right?: Tree;

  };

  const tree: Tree = {

  value: 1,

  left: {

  value: 2,

  right: { value: 5 },

  },

  right: { value: 3 },

  };

  function treePath(root: Tree): string[] {

  // 补全此处代码

  // throw new Error('功能待实现');

  const answer: [] = [];

  let tmp: [][] = [];

  const travel = (r: Tree) => {

  if (r == null) {

  return;

  }

  //@ts-ignore

  tmp.push(r.value);

  if (r.left == null && r.right == null) {

  //@ts-ignore

  answer.push(tmp);

  tmp = [tmp[0]];

  return;

  }

  if (r.left) travel(r.left);

  if (r.right) travel(r.right);

  };

  travel(root);

  //@ts-ignore

  return answer.map((t) => t.join("->"));

  }

  console.log(treePath(tree)); // [ '1->2->5', '1->3' ]

  export default {};

  复制代码

  7、mapTree.ts

  /**

  * @file 树结构映射

  * 数组 map 保持数组长度相同,将对应位置元素进行映射。

  * 与之类似,在二叉树 Tree 上的映射我们称为 mapTree,该函数返回一个结构相同的新树,对应位置 value 字段经过 fn 映射。

  */

  type Tree = {

  value: number;

  left?: Tree;

  right?: Tree;

  };

  function mapTree(tree: Tree, fn: (v: number) => number): Tree {

  // 参考答案

  if (tree == null) {

  return tree;

  }

  tree.value = fn(tree.value);

  if (tree.left) mapTree(tree.left, fn);

  if (tree.right) mapTree(tree.right, fn);

  return tree;

  }

  // 测试

  const tree: Tree = {

  value: 1,

  left: { value: 2 },

  right: { value: 3 },

  };

  console.log(mapTree(tree, (v) => v * 2)); // { value: 2, left: { value: 4 }, right: { value: 6 } }

  export default {};

  复制代码

  8、product.ts

  /**

  * @file 计算数组笛卡尔积

  */

  // 示例

  console.log(product([1, 2], [3, 4])); // [[1, 3], [1, 4], [2, 3], [2, 4]]

  function product(xList: number[], yList: number[]): [number, number][] {

  // 参考答案

  return xList.reduce((v, t) => {

  return v.concat(yList.map((item) => [t, item]));

  }, [] as [number, number][]);

  }

  export default {};

  复制代码

  9、sleep.ts

  /**

  * @file 返回一个 Promise,并在 ms 毫秒后 Promise 变为完成状态

  */

  export function sleep(ms: number): Promise {

  // 参考答案

  return new Promise(

  (

  resolve: (value: undefined) => void,

  reject: (value: undefined) => void

  ) => {

  setTimeout(() => {

  resolve(undefined);

  }, ms);

  }

  );

  }

  async function main() {

  console.log("a");

  await sleep(1000);

  console.log("b");

  await sleep(1000);

  console.log("c");

  }

  main();

  export default {};

  复制代码

  10、promiseAll.ts

  /**

  * @file 实现 PromiseAll 方法

  */

  import { sleep } from "./8.sleep";

  async function myAll(

  values: T

  ): Promise<{ [P in keyof T]: Awaited }> {

  // 补全此处代码,使用 Promise.all 以外的语法完成

  // throw new Error('功能待实现');

  var arr = [];

  for (var i = 0; i < values.length; i++) {

  arr.push(await values[i]);

  }

  return arr as { [P in keyof T]: Awaited };

  }

  // 一秒钟后返回结果 value

  async function request(value: string) {

  await sleep(1000);

  return value;

  }

  async function main() {

  console.log("start");

  const res = await myAll([request("a"), request("b"), request("c")]);

  console.log(res); // 预期输出 start 一秒后输出 ['a', 'b', 'c']

  }

  main();

  export default {};

  复制代码

  11、asyncAdd.ts

  /**

  * @file 假设加法是一个异步过程,如何计算多个数组之和?

  */

  function sleep(ms: number) {

  return new Promise((r) => {

  setTimeout(() => {

  r(undefined);

  }, ms);

  });

  }

  async function asyncAdd(a: number, b: number) {

  await sleep(1000);

  return a + b;

  }

  async function sum(arr: number[]): Promise {

  // 参考答案

  var s: number = arr[0];

  for (var i = 1; i < arr.length; i++) {

  s = await asyncAdd(s, arr[i]);

  }

  return s;

  }

  console.time("a");

  sum([1, 2, 3, 4, 5, 6, 7, 8]).then((v) => {

  console.log(v); // 36

  console.timeEnd("a"); // a: <耗时>

  });

  export default {};

相关文章

上一篇:async 的原理
下一篇:

热门视频

开班信息

  • HTML5大前端班--------------------

    06.22抢座

  • UI设计培训班--------------------

    06.15抢座

  • JavaEE培训班--------------------

    06.15抢座

  • Python培训班--------------------

    06.08抢座

  • HTML5大前端班--------------------

    06.08抢座

  • 软件测试培训班--------------------

    06.29抢座

  • 北京总部地址:北京市海淀区宝盛北里西区28号中关村智诚科创大厦4层
    北京沙河校区:北京市昌平区沙阳路18号北京科技职业技术学院广场服务楼
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、云计算培训、全栈软件测试培训、大数据+人工智能培训、智能物联网+嵌入式培训、Unity游戏开发培训、Go语言开发培训、PHP全栈+服务器集群培训、网络安全培训、网络营销培训、好程序员
    认证课程:软考、、PMP认证、红帽RHCE认证
  • 深圳校区地址:深圳市宝安区宝安大道5010号西部硅谷B座C区1层108
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、云计算培训、全栈软件测试培训、大数据+人工智能培训、智能物联网+嵌入式培训、Unity游戏开发培训、Go语言开发培训、PHP全栈+服务器集群培训、网络安全培训、网络营销培训、好程序员
    认证课程:软考、、PMP认证、红帽RHCE认证
  • 上海校区地址:上海市宝山区同济支路199号智慧七立方3号楼2-4层
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、云计算培训、全栈软件测试培训、大数据+人工智能培训、智能物联网+嵌入式培训、Unity游戏开发培训、Go语言开发培训、PHP全栈+服务器集群培训、网络安全培训、网络营销培训、好程序员
    认证课程:软考、、PMP认证、红帽RHCE认证
  • 广州校区地址:广州市白云区永平街永泰学山塘学山文化创意谷A1栋六楼
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、云计算培训、全栈软件测试培训、大数据+人工智能培训、智能物联网+嵌入式培训、Unity游戏开发培训、Go语言开发培训、PHP全栈+服务器集群培训、网络安全培训、网络营销培训、好程序员
    认证课程:软考、、PMP认证、红帽RHCE认证
  • 郑州二七区校区地址:郑州市二七区航海中路60号海为科技园C区10层
    郑州高新区校区地址:郑州市高新区金梭路与银杏路交叉口教育科技产业园南门D座4层
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、云计算培训、全栈软件测试培训、大数据+人工智能培训、智能物联网+嵌入式培训、Unity游戏开发培训、Go语言开发培训、PHP全栈+服务器集群培训、网络安全培训、网络营销培训、好程序员
    认证课程:软考、、PMP认证、红帽RHCE认证
  • 大连校区地址:辽宁省大连市高新园区爱贤街10号大连设计城A座901
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、云计算培训、全栈软件测试培训、大数据+人工智能培训、智能物联网+嵌入式培训、Unity游戏开发培训、Go语言开发培训、PHP全栈+服务器集群培训、网络安全培训、网络营销培训、好程序员
    认证课程:软考、、PMP认证、红帽RHCE认证
  • 武汉金融港校区地址:武汉市东新区光谷大道77号金融港B18栋三、四层
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、云计算培训、全栈软件测试培训、大数据+人工智能培训、智能物联网+嵌入式培训、Unity游戏开发培训、Go语言开发培训、PHP全栈+服务器集群培训、网络安全培训、网络营销培训、好程序员
    认证课程:软考、、PMP认证、红帽RHCE认证
  • 成都校区地址:成都市高新区肖家河沿街138号肖家河大厦三楼
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、云计算培训、全栈软件测试培训、大数据+人工智能培训、智能物联网+嵌入式培训、Unity游戏开发培训、Go语言开发培训、PHP全栈+服务器集群培训、网络安全培训、网络营销培训、好程序员
    认证课程:软考、、PMP认证、红帽RHCE认证
  • 西安校区地址:西安市雁塔区高新六路52号立人科技C座西区4楼
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、云计算培训、全栈软件测试培训、大数据+人工智能培训、智能物联网+嵌入式培训、Unity游戏开发培训、Go语言开发培训、PHP全栈+服务器集群培训、网络安全培训、网络营销培训、好程序员
    认证课程:软考、、PMP认证、红帽RHCE认证
  • 杭州旺田校区:浙江省杭州市上城区九堡镇旺田书画城A座4层
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、云计算培训、全栈软件测试培训、大数据+人工智能培训、智能物联网+嵌入式培训、Unity游戏开发培训、Go语言开发培训、PHP全栈+服务器集群培训、网络安全培训、网络营销培训、好程序员
    认证课程:软考、、PMP认证、红帽RHCE认证
  • 青岛校区地址:青岛市市北区龙城路31号卓越世纪中心4号楼5层
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、云计算培训、全栈软件测试培训、大数据+人工智能培训、智能物联网+嵌入式培训、Unity游戏开发培训、Go语言开发培训、PHP全栈+服务器集群培训、网络安全培训、网络营销培训、好程序员
    认证课程:软考、、PMP认证、红帽RHCE认证
  • 重庆校区地址:重庆市九龙坡区科园一路3号渝高大厦9楼
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、云计算培训、全栈软件测试培训、大数据+人工智能培训、智能物联网+嵌入式培训、Unity游戏开发培训、Go语言开发培训、PHP全栈+服务器集群培训、网络安全培训、网络营销培训、好程序员
    认证课程:软考、、PMP认证、红帽RHCE认证
  • 长沙校区地址:湖南省长沙市岳麓区麓谷企业广场A2栋三单元306号
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、云计算培训、全栈软件测试培训、大数据+人工智能培训、智能物联网+嵌入式培训、Unity游戏开发培训、Go语言开发培训、PHP全栈+服务器集群培训、网络安全培训、网络营销培训、好程序员
    认证课程:软考、、PMP认证、红帽RHCE认证
  • 哈尔滨校区地址:哈尔滨市松北区世泽路689号 科技创新城4号楼405
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、云计算培训、全栈软件测试培训、大数据+人工智能培训、智能物联网+嵌入式培训、Unity游戏开发培训、Go语言开发培训、PHP全栈+服务器集群培训、网络安全培训、网络营销培训、好程序员
    认证课程:软考、、PMP认证、红帽RHCE认证
  • 南京校区地址:南京市建邺区应天大街780号弘辉产业园1栋2层
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、云计算培训、全栈软件测试培训、大数据+人工智能培训、智能物联网+嵌入式培训、Unity游戏开发培训、Go语言开发培训、PHP全栈+服务器集群培训、网络安全培训、网络营销培训、好程序员
    认证课程:软考、、PMP认证、红帽RHCE认证
  • 太原校区地址:太原市小店区长治路230号能源互联网大厦6层
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、云计算培训、全栈软件测试培训、大数据+人工智能培训、智能物联网+嵌入式培训、Unity游戏开发培训、Go语言开发培训、PHP全栈+服务器集群培训、网络安全培训、网络营销培训、好程序员
    认证课程:软考、、PMP认证、红帽RHCE认证
  • 沈阳校区地址:辽宁省沈阳市浑南区世纪路16号东大软件园B园B1座A201
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、云计算培训、全栈软件测试培训、大数据+人工智能培训、智能物联网+嵌入式培训、Unity游戏开发培训、Go语言开发培训、PHP全栈+服务器集群培训、网络安全培训、网络营销培训、好程序员
    认证课程:软考、、PMP认证、红帽RHCE认证
  • 合肥校区地址:合肥市包河区徽州大道396号东方广场B座12A
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、云计算培训、全栈软件测试培训、大数据+人工智能培训、智能物联网+嵌入式培训、Unity游戏开发培训、Go语言开发培训、PHP全栈+服务器集群培训、网络安全培训、网络营销培训、好程序员
    认证课程:软考、、PMP认证、红帽RHCE认证
  • 贵阳校区地址:贵阳市云岩区延安东路37号物资大厦老楼9楼
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python全栈+人工智能培训、全链路UI/UE设计培训、云计算培训、全栈软件测试培训、大数据+人工智能培训、智能物联网+嵌入式培训、Unity游戏开发培训、Go语言开发培训、PHP全栈+服务器集群培训、网络安全培训、网络营销培训、好程序员
    认证课程:软考、、PMP认证、红帽RHCE认证
  • 济南校区地址:济南市历下区历山路36号齐鲁师范学院利宝产业大厦3F
    咨询电话:400-811-9990
    面授课程:HTML5大前端培训、JavaEE+分布式开发培训、Python人工智能+数据分析培训、全链路UI/UE设计培训、云计算培训、全栈软件测试培训、大数据+人工智能培训、智能物联网+嵌入式培训、Unity游戏开发培训、网络安全培训、区块链培训、影视剪辑包装培训、游戏原画培训、全媒体运营培训
    认证课程:软考、、PMP认证、红帽RHCE认证
  • 千锋教育服务号

    了解千锋动态
    关注千锋教育服务号

  • 千锋教育移动站

    扫一扫快速进入
    千锋移动端页面

  • 千锋互联服务号

    扫码匿名提建议
    直达CEO信箱