前言: \textcolor{Green}{前言:} 前言:
快秋招了,那么这个专栏就专门来记录一下,同时呢整理一下常见面试题
部分题目来自自己的面试题,部分题目来自网络整理
对比Java、Python、Golang三种语言
Java
Python
Golang
参考连接
https://blog.csdn.net/a772304419/article/details/129516817
http://www.guoxiaolong.cn/blog/?id=9855
说一下面向对象语言的特征,具体体现在哪些方面
面向对象的特征包括封装、继承、多态、抽象
多态的实现
方法的重载和重写都是实现多态的方式,区别在于前者实现的是编译时的多态性,而后者实现的是运行时的多态性。
方法的重载(overload)
重写(override)
老规矩,面试题结束。来道算法题解解馋 |
题目来源: \textcolor{blue}{题目来源: } 题目来源: 234. 回文链表
等级:简单 \textcolor{OrangeRed}{等级:简单} 等级:简单
题目描述
给你一个单链表的头节点 head
,请你判断该链表是否为回文链表。如果是,返回 true
;否则,返回 false
。
示例 1:
输入:head = [1,2,2,1]
输出:true
输入:head = [1,2]
输出:false
提示:
代码编写
方法1
/**
* Definition for singly-linked list.
* public class ListNode {
* int val;
* ListNode next;
* ListNode() {}
* ListNode(int val) { this.val = val; }
* ListNode(int val, ListNode next) { this.val = val; this.next = next; }
* }
*/
class Solution {
public boolean isPalindrome(ListNode head) {
List<Integer> res = new ArrayList<>();
ListNode current = head;
while (current != null) {
res.add(current.val);
current = current.next;
}
int front = 0;
int last = res.size() - 1;
while (front < last) {
if (!res.get(front).equals(res.get(last))) {
return false;
}
front++;
last--;
}
return true;
}
}
今天结束。之前学习的明白了吗? |
简历上写着Java、Python、Golang,请对比一下三种语言。
面向对象的特征
算法:回文链表
下一次讲讲 Vue 框架的原理是什么?