- 剑指offer-顺序打印矩阵
yyming
题目:输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下4X4矩阵:12345678910111213141516则依次打印出数字1,2,3,4,8,12,16,15,14,13,9,5,6,7,11,10.解题思路:定义矩阵最大最小值,然后从第一行第一个到第一行最后一个访问,从右列第二个到最后一个访问,依次类推;假设每次访问周期为一个圈,内部为剩下没有访问的矩阵;可
- 剑指offer 48- 礼物的最大价值
顾子豪
在一个m×n的棋盘的每一格都放有一个礼物,每个礼物都有一定的价值(价值大于0)你可以从棋盘的左上角开始拿格子里的礼物,并每次向右或者向下移动一格直到到达棋盘的右下角。给定一个棋盘及其上面的礼物,请计算你最多能拿到多少价值的礼物?注意:m,n>0样例:输入:[[2,3,1],[1,7,1],[4,6,1]]输出:19解释:沿着路径2→3→7→6→1可以得到拿到最大价值礼物。分析:(1)状态表示:dp
- 求1+2+3+...+n
Waitt_
剑指OFFERC++
剑指OFFER题6------按牛客网通过率排序时间:2018.10.16.2036作者:Waitt题目求1+2+3+…+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)。时间限制:1秒空间限制:32768K热度指数:128539解答1+2+3+…+n的公式结果为:(n2+n)/2;由于题目要求不可使用一些语句,则考虑利用mat
- 力扣基础速攻题单(排位刷分适用)
0
leetcode算法职场和发展
Leetcode速攻题单一部分:1.算法入门100讲系列,C语言入门系列算法零基础100讲1.2的幂2.3的幂3.4的幂4.斐波那契数5.第N个泰波那契数6.剑指offer.求1+2+…+n7.单调数列8.最富有客户的资产总量9.二进制矩阵中的特殊位置10.翻转图像11.旋转图像12.转置矩阵13.将一维数组转变为二维数组14.判断矩阵经轮转后是否一致15.二维网络迁移16.杨辉三角17.杨辉三角
- 【C++】二维数组传参方式
虚拟笔记使
C++c++开发语言
最近刚开始刷剑指offer,刚做到第三题的时候,发现C++二维数组的传参方式和C语言略有些不同,所以在这篇博客中,会列出C/C++常见的二维数组传参方式。(本方式和代码都是基于vs环境所编写)一.C语言二维数组传参方式C语言二维数组传参一般有三个方式。1.指针形式接收#includevoidPrint1(int*parr,introws,intcols)//指针,行数,列数{for(inti=0;
- 剑指Offer - 5 - 用两个栈实现队列
vouv
题目描述用两个栈实现队列思路用一个栈来保存数据,其中栈底是队尾,栈顶是队头push时,需要先把数据栈中数据都弹出然后推入数据,再把弹出的数据推回pop则直接弹出栈顶即可CodePython#-*-coding:utf-8-*-items=[]tmp=[]classSolution:defpush(self,node):whilelen(items)!=0:tmp.append(items.pop(
- Leetcode 剑指 Offer II 064. 实现一个魔法字典
随便发挥
Leetcodeleetcodelinux算法
题目难度:中等原题链接今天继续更新Leetcode的剑指Offer(专项突击版)系列,大家在公众号算法精选里回复剑指offer2就能看到该系列当前连载的所有文章了,记得关注哦~题目描述设计一个使用单词列表进行初始化的数据结构,单词列表中的单词互不相同。如果给出一个单词,请判定能否只将这个单词中一个字母换成另一个字母,使得所形成的新单词存在于已构建的神奇字典中。实现MagicDictionary类:
- 剑指 Offer II 092. 翻转字符 / 剑指 Offer II 093. 最长斐波那契数列
彼淇梁
力扣刷题记录动态规划算法leetcodejava刷题记录
剑指OfferII092.翻转字符【中等题】思路:【动态规划】二阶dp数组dp[i][0]表示将第i位翻转为0后,数组保持递增的最小翻转次数dp[i][1]表示将第i位翻转为1后,数组保持递增的最小翻转次数初始状态:dp[0][0]=s.charAt(0)=='0'?0:1dp[0][1]=s.charAt(0)=='1'?0:1转移方程:dp[i][0]=dp[i-1][0]+s.charAt(
- LeetCode 剑指 Offer II 093. 最长斐波那契数列
大涛小先生
LeetCode解题报告leetcode算法动态规划
LeetCode剑指OfferII093.最长斐波那契数列文章目录LeetCode剑指OfferII093.最长斐波那契数列题目描述一、解题关键词二、解题报告1.思路分析2.时间复杂度3.代码示例2.知识点总结相同题目题目描述如果序列X_1,X_2,…,X_n满足下列条件,就说它是斐波那契式的:n>=3对于所有i+2<=n,都有X_i+X_{i+1}=X_{i+2}给定一个严格递增的正整数数组形成
- JavaScript——leetcode剑指offer 53 - I. 在排序数组中查找数字 I
周三有雨
算法leetcodejavascript排序算法
JavaScript——leetcode剑指offer53-I.在排序数组中查找数字I题目描述统计一个数字在排序数组中出现的次数。示例1:输入:nums=[5,7,7,8,8,10],target=8输出:2示例2:输入:nums=[5,7,7,8,8,10],target=6输出:0代码片/***@param{number[]}nums*@param{number}target*@return{
- 《剑指offer第二版》面试题49:丑数(Ugly Number)(java)
castlet
题目描述题目描述:我们把只包含2,3,5的数称为丑数(uglynumber),求从小到大的顺序的第1500个丑数。例如6,8是丑数,但14不是,因为它包含因子7。习惯上我们把1称为第一个丑数。解题思路根据丑数的定义,丑数应该是丑数乘以2、3或者5的结果。可以创建一个数组A,数组里的数字是排好序的丑数。假设数组里最大的丑数是M,则接下的一个丑数则是之前的某个丑数乘以2、3或者5的结果。记录三个下标,
- 剑指offer 二进制中1的个数 python
霍尔元件
先上代码classSolution2:defNumberOf1(self,n):n=n&0xffffffffifn<0elsen#把负数转换成一个正数这个正数的二进制表示和附属的补码是一样的cnt=0whilen:#只要n不为0就必然存在1在某些位置上n=n&(n-1)#消灭掉n中最靠右的一个1cnt+=1returncnt这里面让人疑惑的就是python的补码实际上python应该是没有补码的怎
- 「剑指 Offer 32-III. 从上到下打印二叉树III」
快乐二狗呀
算法
「剑指Offer32-III.从上到下打印二叉树III」题目描述(level中等)请实现一个函数按照之字形顺序打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右到左的顺序打印,第三行再按照从左到右的顺序打印,其他行以此类推。示例例如:给定二叉树:[3,9,20,null,null,15,7],3/\920/\157返回其层次遍历结果:[[3],[20,9],[15,7]]思路分析对返回结果
- 《剑指offer》78--把二叉树打印成多行[C++][Java]
贫道绝缘子
剑指offer算法散列表leetcode
把二叉树打印成多行_牛客题霸_牛客网【牛客题霸】收集各企业高频校招笔面试题目,配有官方题解,在线进行百度阿里腾讯网易等互联网名企笔试面试模拟考试练习,和牛人一起讨论经典试题,全面提升你的技术能力https://www.nowcoder.com/practice/445c44d982d04483b04a54f298796288?tpId=13&tags=&title=&difficulty=0&ju
- 剑指offer 替换空格 C语言
我是故意的216
c语言前端开发语言
描述请实现一个函数,将一个字符串s中的每个空格替换成“%20”。例如,当字符串为WeAreHappy.则经过替换之后的字符串为We%20Are%20Happy。数据范围:0≤���(�)≤10000≤len(s)≤1000。保证字符串中的字符为大写英文字母、小写英文字母和空格中的一种。示例1输入:"WeAreHappy"复制返回值:"We%20Are%20Happy"复制示例2输入:""复制返回值
- 剑指offer面试题29. 顺时针打印矩阵(边界问题)
程旭员
剑指offer顺时针打印矩阵边界问题剑指offerPython
题目描述输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字。思路详见链接代码classSolution:defspiralOrder(self,matrix:[[int]])->[int]:ifnotmatrix:return[]l,r,t,b,res=0,len(matrix[0])-1,0,len(matrix)-1,[]whileTrue:foriinrange(l,r+1):re
- 剑指Offer面试题20顺时针打印矩阵,面试题21包含min函数的栈
login_sonata
《剑指Offer》Java版《剑指Offer》Java版剑指OfferJava面试题栈数组
面试题20:顺时针打印矩阵思路:一圈一圈打印,再具体到四个边分别打印。本题的Java实现:publicclassPrintMatrixInCircle{publicvoidPrintMatrixClockwisely(int[][]a){if(a==null)return;introws=a.length;intcolumns=a[0].length;intstart=0;//起始位置坐标都是(0
- [M二叉树] lc105. 从前序与中序遍历序列构造二叉树(递归建树+迭代建树+经典问题)
Ypuyu
LeetCode算法
文章目录1.题目来源2.题目解析1.题目来源链接:105.从前序与中序遍历序列构造二叉树力扣题解:官方题解:从前序与中序遍历序列构造二叉树之前的博文:剑指offer的博文,有图例,代码也十分清楚![剑指-Offer]7.重建二叉树(二叉树、递归建树)2.题目解析参考原有博文即可:剑指offer的博文,有图例,代码也十分清楚![剑指-Offer]7.重建二叉树(二叉树、递归建树)十分经典的问题哈,这
- 《剑指Offer》Java实现
探索者丶
androidjava开发语言后端
1)找出数组中重复的数字2)不修改数组找出重复的数字3)二维数组中的查找4)替换空格5)从尾到头打印链表6)重建二叉树7)二叉树的下一个结点8)用两个栈实现队列9)斐波那契数列及青蛙跳台阶问题10)旋转数组的最小数字11)矩阵中的路径12)机器人的运动范围13)剪绳子14)二进制中1的个数15)数值的整数次方16)打印1到最大的n位数17)在O(1)时间删除链表结点18)删除链表中重复的结点19)
- 剑指 Offer 53 - I. 在排序数组中查找数字 I
来到了没有知识的荒原
剑指Offer53-I.在排序数组中查找数字IclassSolution{public:stringreverseLeftWords(strings,intn){returns.substr(n)+s.substr(0,n);}};
- 2021-09-01
幸福大黑鸭
IT1.LeetCode力扣:从上到下打印二叉树II2021-09-01(剑指Offer32-II.从上到下打印二叉树II)2.《剑指offer》:p174~p176英语1.墨墨背单词:复习50个单词
- 《剑指Offer》笔记&题解&思路&技巧&优化 Java版本——新版leetcode_Part_2
_Matthew
Leetcode笔记javaleetcode
《剑指Offer》笔记&题解&思路&技巧&优化_Part_2相知相识广度优先搜索BFS深度优先搜索DFS开始刷题1.LCR129.字母迷宫——矩阵中的路径2.LCR130.衣橱整理——机器人的运动范围3.LCR131.砍竹子I——剪绳子I4.LCR132.砍竹子II——剪绳子II5.LCR133.位1的个数——二进制中1的个数6.LCR134.Pow(x,n)——数值的整数次方7.LCR135.报
- 数据结构---链表篇
Winfred_Bo
python
数据结构-----链表篇链表的考察主要包括(反转链表、删除节点、链表相交、环形链表和链表设计)1.反转链表剑指Offer06.从尾到头打印链表234.回文链表剑指Offer24.反转链表2.删除链表节点剑指Offer18.删除链表的节点剑指Offer22.链表中倒数第k个节点19.删除链表的倒数第N个结点(中等)3.链表相交剑指Offer25.合并两个排序的链表23.合并K个升序链表(困难)2.两
- 剑指 Offer 题解44. 数字序列中某一位的数字
拾光1024
leetcode算法动态规划
剑指Offer44.数字序列中某一位的数字classSolution{publicintfindNthDigit(intn){//1位数有10个//2位数有90个//3位数有900个intdigit=1;//数字位数(例如三位数digit=3)longstart=1;//digit位数的第一个数字longcount=9;//所有digit位数所占的位数while(n>count){//找到是几位数
- 2022-01-03
幸福大黑鸭
IT工业界1.力扣:对称的二叉树2022-01-03(剑指Offer28.对称的二叉树)英语1.墨墨背单词:复习50个单词
- 《剑指offer第二版》面试题38_1:字符串的组合(java)
castlet
题目描述输入一个字符串,打印出该字符串的所有组合,例如输入字符串abc,则所有的排列为:a、b、c、ab、ac、bc、abc。解题思路:如果输入n个字符,则能构成长度为1,2,...n的组合。求n个字符中长度为m的组合的时候,可以把n个字符分为两个部分,第一部分:第一个字符,第二部分:n-1个其他的所有字符。可以选取第一个字符,再在第二部分的字符里选取m-1个字符,也可以不选取第一个字符,在第二部
- java数据结构与算法刷题-----LeetCode151. 反转字符串中的单词
殷丿grd_志鹏
算法java算法leetcode
java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完):https://blog.csdn.net/grd_java/article/details/123063846解题思路这道题,可以理解为,将字符串颠倒,但是每个单词原来的顺序是什么还是什么,不能改变单词的组合顺序,比如apple,able这个例子,字符串颠倒后为ab
- java数据结构与算法刷题-----LeetCode541. 反转字符串 II
殷丿grd_志鹏
算法javaleetcode算法
java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完):https://blog.csdn.net/grd_java/article/details/123063846解题思路使用双指针,left指针指向每次反转的左边界,right指针指向右边界left每次移动2k的单位然后定位right右边界,如果left后面元素个数不
- 剑指Offer----面试题27:二叉搜索树与双向链表
烽火前秦路
剑指OfferC++剑指offer面试题二叉树链表
题目:输入一颗二叉搜索树,将该二叉搜索树转换成一个排序的双向链表。要求不能创建任何新的结点,只能调整树中结点指针的指向。如下图中的二叉搜索树,则输出转换之后的排序双向链表。分析:中序遍历算法的特点是按照从小到大的顺序遍历二叉树的每一个结点。当遍历到根节点的时候,可以把树分为三部分:值为10的结点,根节点值为6的左子树,根节点值为14的右子树。根据排序链表的定义,将根节点与左子树最大的一个结点连接起
- 剑指Offer----面试题39(1):二叉树的深度
烽火前秦路
剑指OfferC++剑指Offer二叉树树的深度
题目:输入一颗二叉树的根结点,求该树的深度。从根结点到叶节点依次经过的结点(含根、叶节点)形成树的一条路径,最长路径的长度为树的深度。分析如果一颗树只有一个根结点,那么该树的深度为1。如果该树只有左子树没有右子树,那么该树的深度应该是左子树的深度加1;同理,如果该树只有右子树而没有左子树,那么该树的深度应该是右子树的深度加1。如果该树既有左子树又有右子树,那么该树的深度应该是左子树和右子树深度的最
- java杨辉三角
3213213333332132
java基础
package com.algorithm;
/**
* @Description 杨辉三角
* @author FuJianyong
* 2015-1-22上午10:10:59
*/
public class YangHui {
public static void main(String[] args) {
//初始化二维数组长度
int[][] y
- 《大话重构》之大布局的辛酸历史
白糖_
重构
《大话重构》中提到“大布局你伤不起”,如果企图重构一个陈旧的大型系统是有非常大的风险,重构不是想象中那么简单。我目前所在公司正好对产品做了一次“大布局重构”,下面我就分享这个“大布局”项目经验给大家。
背景
公司专注于企业级管理产品软件,企业有大中小之分,在2000年初公司用JSP/Servlet开发了一套针对中
- 电驴链接在线视频播放源码
dubinwei
源码电驴播放器视频ed2k
本项目是个搜索电驴(ed2k)链接的应用,借助于磁力视频播放器(官网:
http://loveandroid.duapp.com/ 开放平台),可以实现在线播放视频,也可以用迅雷或者其他下载工具下载。
项目源码:
http://git.oschina.net/svo/Emule,动态更新。也可从附件中下载。
项目源码依赖于两个库项目,库项目一链接:
http://git.oschina.
- Javascript中函数的toString()方法
周凡杨
JavaScriptjstoStringfunctionobject
简述
The toString() method returns a string representing the source code of the function.
简译之,Javascript的toString()方法返回一个代表函数源代码的字符串。
句法
function.
- struts处理自定义异常
g21121
struts
很多时候我们会用到自定义异常来表示特定的错误情况,自定义异常比较简单,只要分清是运行时异常还是非运行时异常即可,运行时异常不需要捕获,继承自RuntimeException,是由容器自己抛出,例如空指针异常。
非运行时异常继承自Exception,在抛出后需要捕获,例如文件未找到异常。
此处我们用的是非运行时异常,首先定义一个异常LoginException:
/**
* 类描述:登录相
- Linux中find常见用法示例
510888780
linux
Linux中find常见用法示例
·find path -option [ -print ] [ -exec -ok command ] {} \;
find命令的参数;
- SpringMVC的各种参数绑定方式
Harry642
springMVC绑定表单
1. 基本数据类型(以int为例,其他类似):
Controller代码:
@RequestMapping("saysth.do")
public void test(int count) {
}
表单代码:
<form action="saysth.do" method="post&q
- Java 获取Oracle ROWID
aijuans
javaoracle
A ROWID is an identification tag unique for each row of an Oracle Database table. The ROWID can be thought of as a virtual column, containing the ID for each row.
The oracle.sql.ROWID class i
- java获取方法的参数名
antlove
javajdkparametermethodreflect
reflect.ClassInformationUtil.java
package reflect;
import javassist.ClassPool;
import javassist.CtClass;
import javassist.CtMethod;
import javassist.Modifier;
import javassist.bytecode.CodeAtt
- JAVA正则表达式匹配 查找 替换 提取操作
百合不是茶
java正则表达式替换提取查找
正则表达式的查找;主要是用到String类中的split();
String str;
str.split();方法中传入按照什么规则截取,返回一个String数组
常见的截取规则:
str.split("\\.")按照.来截取
str.
- Java中equals()与hashCode()方法详解
bijian1013
javasetequals()hashCode()
一.equals()方法详解
equals()方法在object类中定义如下:
public boolean equals(Object obj) {
return (this == obj);
}
很明显是对两个对象的地址值进行的比较(即比较引用是否相同)。但是我们知道,String 、Math、I
- 精通Oracle10编程SQL(4)使用SQL语句
bijian1013
oracle数据库plsql
--工资级别表
create table SALGRADE
(
GRADE NUMBER(10),
LOSAL NUMBER(10,2),
HISAL NUMBER(10,2)
)
insert into SALGRADE values(1,0,100);
insert into SALGRADE values(2,100,200);
inser
- 【Nginx二】Nginx作为静态文件HTTP服务器
bit1129
HTTP服务器
Nginx作为静态文件HTTP服务器
在本地系统中创建/data/www目录,存放html文件(包括index.html)
创建/data/images目录,存放imags图片
在主配置文件中添加http指令
http {
server {
listen 80;
server_name
- kafka获得最新partition offset
blackproof
kafkapartitionoffset最新
kafka获得partition下标,需要用到kafka的simpleconsumer
import java.util.ArrayList;
import java.util.Collections;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.
- centos 7安装docker两种方式
ronin47
第一种是采用yum 方式
yum install -y docker
 
- java-60-在O(1)时间删除链表结点
bylijinnan
java
public class DeleteNode_O1_Time {
/**
* Q 60 在O(1)时间删除链表结点
* 给定链表的头指针和一个结点指针(!!),在O(1)时间删除该结点
*
* Assume the list is:
* head->...->nodeToDelete->mNode->nNode->..
- nginx利用proxy_cache来缓存文件
cfyme
cache
user zhangy users;
worker_processes 10;
error_log /var/vlogs/nginx_error.log crit;
pid /var/vlogs/nginx.pid;
#Specifies the value for ma
- [JWFD开源工作流]JWFD嵌入式语法分析器负号的使用问题
comsci
嵌入式
假如我们需要用JWFD的语法分析模块定义一个带负号的方程式,直接在方程式之前添加负号是不正确的,而必须这样做:
string str01 = "a=3.14;b=2.71;c=0;c-((a*a)+(b*b))"
定义一个0整数c,然后用这个整数c去
- 如何集成支付宝官方文档
dai_lm
android
官方文档下载地址
https://b.alipay.com/order/productDetail.htm?productId=2012120700377310&tabId=4#ps-tabinfo-hash
集成的必要条件
1. 需要有自己的Server接收支付宝的消息
2. 需要先制作app,然后提交支付宝审核,通过后才能集成
调试的时候估计会真的扣款,请注意
- 应该在什么时候使用Hadoop
datamachine
hadoop
原帖地址:http://blog.chinaunix.net/uid-301743-id-3925358.html
存档,某些观点与我不谋而合,过度技术化不可取,且hadoop并非万能。
--------------------------------------------万能的分割线--------------------------------
有人问我,“你在大数据和Hado
- 在GridView中对于有外键的字段使用关联模型进行搜索和排序
dcj3sjt126com
yii
在GridView中使用关联模型进行搜索和排序
首先我们有两个模型它们直接有关联:
class Author extends CActiveRecord {
...
}
class Post extends CActiveRecord {
...
function relations() {
return array(
'
- 使用NSString 的格式化大全
dcj3sjt126com
Objective-C
格式定义The format specifiers supported by the NSString formatting methods and CFString formatting functions follow the IEEE printf specification; the specifiers are summarized in Table 1. Note that you c
- 使用activeX插件对象object滚动有重影
蕃薯耀
activeX插件滚动有重影
使用activeX插件对象object滚动有重影 <object style="width:0;" id="abc" classid="CLSID:D3E3970F-2927-9680-BBB4-5D0889909DF6" codebase="activex/OAX339.CAB#
- SpringMVC4零配置
hanqunfeng
springmvc4
基于Servlet3.0规范和SpringMVC4注解式配置方式,实现零xml配置,弄了个小demo,供交流讨论。
项目说明如下:
1.db.sql是项目中用到的表,数据库使用的是oracle11g
2.该项目使用mvn进行管理,私服为自搭建nexus,项目只用到一个第三方 jar,就是oracle的驱动;
3.默认项目为零配置启动,如果需要更改启动方式,请
- 《开源框架那点事儿16》:缓存相关代码的演变
j2eetop
开源框架
问题引入
上次我参与某个大型项目的优化工作,由于系统要求有比较高的TPS,因此就免不了要使用缓冲。
该项目中用的缓冲比较多,有MemCache,有Redis,有的还需要提供二级缓冲,也就是说应用服务器这层也可以设置一些缓冲。
当然去看相关实现代代码的时候,大致是下面的样子。
[java]
view plain
copy
print
?
public vo
- AngularJS浅析
kvhur
JavaScript
概念
AngularJS is a structural framework for dynamic web apps.
了解更多详情请见原文链接:http://www.gbtags.com/gb/share/5726.htm
Directive
扩展html,给html添加声明语句,以便实现自己的需求。对于页面中html元素以ng为前缀的属性名称,ng是angular的命名空间
- 架构师之jdk的bug排查(一)---------------split的点号陷阱
nannan408
split
1.前言.
jdk1.6的lang包的split方法是有bug的,它不能有效识别A.b.c这种类型,导致截取长度始终是0.而对于其他字符,则无此问题.不知道官方有没有修复这个bug.
2.代码
String[] paths = "object.object2.prop11".split("'");
System.ou
- 如何对10亿数据量级的mongoDB作高效的全表扫描
quentinXXZ
mongodb
本文链接:
http://quentinXXZ.iteye.com/blog/2149440
一、正常情况下,不应该有这种需求
首先,大家应该有个概念,标题中的这个问题,在大多情况下是一个伪命题,不应该被提出来。要知道,对于一般较大数据量的数据库,全表查询,这种操作一般情况下是不应该出现的,在做正常查询的时候,如果是范围查询,你至少应该要加上limit。
说一下,
- C语言算法之水仙花数
qiufeihu
c算法
/**
* 水仙花数
*/
#include <stdio.h>
#define N 10
int main()
{
int x,y,z;
for(x=1;x<=N;x++)
for(y=0;y<=N;y++)
for(z=0;z<=N;z++)
if(x*100+y*10+z == x*x*x
- JSP指令
wyzuomumu
jsp
jsp指令的一般语法格式: <%@ 指令名 属性 =”值 ” %>
常用的三种指令: page,include,taglib
page指令语法形式: <%@ page 属性 1=”值 1” 属性 2=”值 2”%>
include指令语法形式: <%@include file=”relative url”%> (jsp可以通过 include