数组 栈 队列 链表
- 定义数组类实现动态定义长度,添加,插入,编辑,查询,搜索,排序
#!/usr/bin/python
# -*- coding: UTF-8 -*-
class ArrayClass:
'数组类' #类文档字符串
# 数组声明
def __init__(self,len=10):
self.len = len
self.size=0
self.arr = [0 for i in range(len)]
# 数组长度
def count(self):
return self.len
# 数组添加
def add(self,value):
self.arr[self.size] = value
self.size +=1
return self.arr
# 数组插入
def insert(self,index,value):
for i in reversed(range(self.len)):
if(i>=index and i!=(self.len-1) ):
self.arr[i+1] = self.arr[i]
self.arr[index] = value
self.size +=1
return self.arr
# 数组编辑
def set(self,index,value):
self.arr[index]=value;
return self.arr[index]
# 数组查询
def select(self,index=False):
if(index and index>=self.len):
return False
if(index):
return self.arr[index]
return self.arr
# 数组检索
def check(self,value):
index = ''
for i in range(self.len):
if(self.arr[i]==value):
index=index+str(i)+' '
if(index==''):
return False
return index
# 数组排序
def sort(self,way='asc'):
if way=='asc':
for i in range(0,self.len):
min = self.arr[i]
for j in range(i+1,self.len):
if(self.arr[j]<min):
min = self.arr[j];
self.arr[j] = self.arr[i]
self.arr[i] = min
else:
for i in range(0,self.len):
max = self.arr[i]
for j in range(i+1,self.len):
if(self.arr[j]>max):
max = self.arr[j];
self.arr[j] = self.arr[i]
self.arr[i] = max
return self.arr
-
给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。
不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成。
示例 1:
给定数组 nums = [1,1,2],
函数应该返回新的长度 2, 并且原数组 nums 的前两个元素被修改为 1, 2。
你不需要考虑数组中超出新长度后面的元素。
示例 2:给定 nums = [0,0,1,1,1,2,2,3,3,4],
函数应该返回新的长度 5, 并且原数组 nums 的前五个元素被修改为 0, 1, 2, 3, 4。
你不需要考虑数组中超出新长度后面的元素。
时间复杂度O(n)
class Solution {
/**
* @param Integer[] $nums
* @return Integer
*/
function removeDuplicates(&$nums) {
$n = count($nums);
$cur = 0;
for($i=1;$i<$n;$i++){
if($nums[$i]!=$nums[$cur]){
$nums[++$cur]=$nums[$i];
}
if($cur!=$i) unset($nums[$i]);
}
return $cur+1;
}
}
-
给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效。
有效字符串需满足:
左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
注意空字符串可被认为是有效字符串。示例 1:
输入: "()"
输出: true
示例 2:输入: "()[]{}"
输出: true
示例 3:输入: "(]"
输出: false
示例 4:输入: "([)]"
输出: false
示例 5:输入: "{[]}"
输出: true
解题思路,运用栈:
<?php
class Solution {
/**
* @param String $s
* @return Boolean
*/
function isValid($s) {
$ss=[];
$length = strlen($s);
for($i=0;$i<$length;$i++){
$t=substr($s,$i,1);
if($t=='('||$t=='['||$t=='{'){
array_push($ss,$t);
}else{
if(empty($ss)) return false;
$end = end($ss);
if( ($end=='(' && $t==')') || ($end=='[' && $t==']') || ($end=='{' && $t=='}') ){
array_pop($ss);
}else{
return false;
}
}
}
if($ss) return false;
return true;
}
}
-
给定两个没有重复元素的数组 nums1 和 nums2 ,其中nums1 是 nums2 的子集。找到 nums1 中每个元素在 nums2 中的下一个比其大的值。
nums1 中数字 x 的下一个更大元素是指 x 在 nums2 中对应位置的右边的第一个比 x 大的元素。如果不存在,对应位置输出-1。
示例 1:
输入: nums1 = [4,1,2], nums2 = [1,3,4,2].
输出: [-1,3,-1]
解释:
对于num1中的数字4,你无法在第二个数组中找到下一个更大的数字,因此输出 -1。
对于num1中的数字1,第二个数组中数字1右边的下一个较大数字是 3。
对于num1中的数字2,第二个数组中没有下一个更大的数字,因此输出 -1。
示例 2:输入: nums1 = [2,4], nums2 = [1,2,3,4].
输出: [3,-1]
解释:
对于num1中的数字2,第二个数组中的下一个较大数字是3。
对于num1中的数字4,第二个数组中没有下一个更大的数字,因此输出 -1。
<?php
class Solution {
/**
* @param Integer[] $nums1
* @param Integer[] $nums2
* @return Integer[]
*/
function nextGreaterElement($nums1, $nums2) {
$n = count($nums2);
$map = [];
for($i=0;$i<$n;$i++){
$k=$i;
$map[$nums2[$i]]=-1;
while(++$k<$n){
if($nums2[$k]>$nums2[$i]){
$map[$nums2[$i]]=$nums2[$k];
break;
}
}
}
$r=[];
for($i=0;$i<count($nums1);$i++){
$r[]=$map[$nums1[$i]];
}
//测试用例没通过,搞不懂
// while($num=array_pop($nums1)){
// $r[]=$map[$num];
// }
//array_shift($r);
return $r;
}
}
-
反转一个单链表。
示例:
输入: 1->2->3->4->5->NULL
输出: 5->4->3->2->1->NULL进阶:
你可以迭代或递归地反转链表。你能否用两种方法解决这道题
<?php
/**
* Definition for a singly-linked list.
* class ListNode {
* public $val = 0;
* public $next = null;
* function __construct($val) { $this->val = $val; }
* }
*/
class Solution {
/**
* @param ListNode $head
* @return ListNode
*/
function reverseList($head) {
while($head->val!==null){
$node = new ListNode($head->val);
$node->next = isset($nodetemp)?$nodetemp:null;
$nodetemp = $node;
$head = $head->next;
}
return $node;
}
}
-
删除链表中等于给定值 val 的所有节点。
示例:
输入: 1->2->6->3->4->5->6, val = 6
输出: 1->2->3->4->5
<?php
/**
* Definition for a singly-linked list.
* class ListNode {
* public $val = 0;
* public $next = null;
* function __construct($val) { $this->val = $val; }
* }
*/
class Solution {
/**
* @param ListNode $head
* @param Integer $val
* @return ListNode
*/
function removeElements($head, $val) {
$pre = new ListNode(0);
$pre->next = $head;
$cur = $pre;
while( $pre->next!= null){
if($val==$pre->next->val){
$pre->next= $pre->next!=null?$pre->next->next:null;
}
while($val==$pre->next->val){
$pre->next = $pre->next->next;
}
$pre = $pre->next;
}
return $cur->next;
}
}
-
给定一个排序链表,删除所有重复的元素,使得每个元素只出现一次。
示例 1:
输入: 1->1->2
输出: 1->2
示例 2:
输入: 1->1->2->3->3
输出: 1->2->3
解决:移动节点next指针,进行判断。复杂度O(n)
<?php
/**
* Definition for a singly-linked list.
* class ListNode {
* public $val = 0;
* public $next = null;
* function __construct($val) { $this->val = $val; }
* }
*/
class Solution {
/**
* @param ListNode $head
* @return ListNode
*/
function deleteDuplicates($head) {
$pre = $head;
while( $pre->next!==null ){
if($pre->val==$pre->next->val){
$pre->next=$pre->next?$pre->next->next:null;
}else{
$pre=$pre->next;
}
}
return $head;
}
}