- Java排序算法之<归并排序>
目录1、归并算法1.1、介绍1.2、归并排序特点2、算法原理3、执行流程4、编码实现1、归并算法1.1、介绍算法是采用分治法(DivideandConquer)。1.2、归并排序特点1、时间复杂度归并排序算法每次将序列折半分组,共需要logn轮,因此归并排序算法的时间复杂度是O(nlogn)。2、空间复杂度归并排序算法排序过程中需要额外的一个序列去存储排序后的结果,所占空间是n,因此空间复杂度为O
- 蓝桥杯-卡java排序
黄油烤菠萝
蓝桥杯c++算法
问题描述本题是一道针对Java中Arrays.sort的题目,因此只有一个数据,该数据可以把int类型的数组在使用Arrays.sort后卡成O(n2)O(n2)。给定一个有nn个正整数的序列aa,你需要将其升序排序后输出。输入格式第一行输入一个正整数nn。(n=2×105)(n=2×105)第二行输入nn个正整数aiai。(1≤i≤n,1≤ai≤n)(1≤i≤n,1≤ai≤n)。输出格式输出nn
- java list排序 sort_Java排序方法sort的使用详解
编辑部的宋姑娘
javalist排序sort
对数组的排序://对数组排序publicvoidarraySort(){int[]arr={1,4,6,333,8,2};Arrays.sort(arr);//使用java.util.Arrays对象的sort方法for(inti=0;iSystem.out.println(arr[i]);}}对集合的排序://对list升序排序publicvoidlistSort1(){Listlist=new
- JAVA排序
荔枝吃吃
java排序算法算法
1.冒泡排序/***使用冒泡排序算法对整数数组进行排序*冒泡排序是一种简单的排序算法,它重复地遍历要排序的数列,*一次比较两个元素,如果它们的顺序错误就把它们交换过来*遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成*这个算法的名字由来是因为越小(或越大)的元素会经过交换慢慢“浮”到数列的顶端**@paramarr待排序的整数数组*/publicstaticvoidbubb
- Java排序算法-桶排序
彬彬小码农
数据结构和算法java排序算法算法
原理:分别从个、十、百...开始排序,第一次比较个位上的大小,第二次比较十位,以此类推。其中比较的最大位数,即为数组中元素的最大位数(且不能为比较负数,如果比较负数需要在比较之前变成绝对值,在加负号)步骤:1.先创建二维数组存放10个桶2.在创建一维数组存放每个桶存放元素的数量3.遍历每个桶顺序取出元素publicint[]bucketSort(int[]arr){//计算出最大的位数intmax
- 全面掌握 Java 排序算法:从原理到代码实现
中國移动丶移不动
排序算法java算法
全面掌握Java排序算法:从原理到代码实现一、基本概念排序算法用于将一组数据按指定顺序排列(通常是升序或降序)。在评估排序算法时,通常需要考虑以下几个方面:1.1什么是排序算法排序算法是一种对数据集合按照某种特定顺序进行重新排列的过程,主要应用在数据处理、查找优化等场景。1.2排序算法的评估标准时间复杂度:算法处理n个元素时所需的时间,例如O(n2)O(n^2)O(n2)表示随着输入量增长,处理时
- java sort 面试题目
youyouxiong
排序算法算法
Java排序是面试中经常出现的主题,因为它不仅涉及Java集合框架中的排序方法,还涉及到基本的排序算法和性能优化。以下是一些关于Java排序的面试题目:解释Java中的Collections.sort()方法是如何工作的?Collections.sort()方法用于对List进行排序。它使用了TimSort算法,这是一种基于合并排序和插入排序的混合体,旨在提供最佳的性能。Java中的Arrays.
- java排序算法研究-复制代码即可运行
ssttIsme
一、排序算法分类使用内存的为内排序,内外存结合使用的为外排序内排序:所有排序操作都在内存中完成;外排序:由于数据太大,因此把数据放在磁盘中,而排序通过磁盘和内存的数据传输才能进行;二、稳定性稳定:如果a原本在b前面,而a=b,排序之后a仍然在b的前面;不稳定:如果a原本在b的前面,而a=b,排序之后a可能会出现在b的后面;时间复杂度:一个算法执行所耗费的时间。空间复杂度:运行完一个程序所需内存的大
- 用java做排序
无羡爱诗诗
java排序算法大全:一个牛人的博客地址:https://www.cnblogs.com/morethink/p/8419151.html
- Java算法排序之冒泡/插入/选择/快速、二分查找 - 附动图
布衣不才Jerry
1.Java排序:冒泡排序-最简单(1)比较前后相邻的二个数据,如果前面数据大于后面的数据,就将这二个数据交换。(2)这样对数组的第0个数据到N-1个数据进行一次遍历后,最大的一个数据就“沉”到数组第N-1个位置。(3)N=N-1,如果N不为0就重复前面二步,否则排序完成。Java冒泡排序【逻辑】外层0~array[j+1]){//相邻元素,升序//if(array[j]0;j--){//temp
- 《玩儿转算法面试》学习笔记
Coder_Cui
数据结构与常用算法总结数据结构算法1024程序员节
1.算法面试到底是什么鬼重在思路:注意:Java排序底层算法就是三路快排2.面试中的复杂度分析2.1时间复杂度一个操作如果和样本的数据量没有关系,每次都是在固定时间内完成操作,那么这个操作叫做常数操作,例如:+、-、*、\、位运算等。时间复杂度可以看作是一个在算法流程中用来衡量常数操作数量的指标,常用O来表示,读作BigO。具体来说,先要对一个算法流程非常熟悉,然后去写出这个算法流程中发生了多少次
- Java排序算法题-00
柠檬树LeTr
调整数组顺序使奇数位于偶数前面输入一个长度为n整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前面部分,所有的偶数位于数组的后面部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。冒泡直接插入、冒泡、基数、归并,这四个排序是稳定的双指针第一次遍历,查询有几个基数第二次遍历,第一个指针先动到目标位置,第二个指针在头上。根据要求放置。https://github.com/Cy
- Java排序算法-持续更新中
只年
java
一、比较排序1.1交换排序数组两元素交换位置publicclassArrayUtil{/***交换数组中的两个元素*@paramarray数组*@paramele1Idx元素1的索引下标*@paramele2Idx元素1的索引下表*/publicstaticvoidswap(int[]array,intele1Idx,intele2Idx){inttmp=array[ele1Idx];array[
- Java 排序
0771609860ee
概述对Java对数组对象进行排序,Java对排序问题的处理。Java排序一般包括基础排序和LambdaComparator增强排序。为了凸显增强排序的优势。准备我们先定义一个简单的实体类:publicclassFlux{privateStringname;privateintage;publicFlux(finalStringname,finalintage){this.name=name;thi
- JAVA排序
默默编码的Fxdll
算法排序算法数据结构
一、排序1、冒泡排序冒泡排序的英文BubbleSort,是一种最基础的交换排序。之所以叫做冒泡排序,因为每一个元素都可以像小气泡一样,根据自身大小一点一点向数组的一侧移动。原理冒泡排序的原理:每一趟只能确定将一个数归位。即第一趟只能确定将末位上的数归位,第二趟只能将倒数第2位上的数归位,依次类推下去。如果有n个数进行排序,只需将n-1个数归位,也就是要进行n-1趟操作。而“每一趟”都需要从第一位开
- java排序之选择排序
阿__龙
javajava选择排序冒泡排序
选择排序改进了冒泡排序,所改进的是排序时交换的次数,并没有改进比较的次数。在大批量数据排序的时候,选择排序中对于交换数据的时间和比较的时间来说,很显然,数据交换和移动的时间更为重要(一般来说,Java中不是这种情况,Java中只是改变了引用的位置,而实际对象的位置并未发生改变)用选择排序对篮球队员进行排序:进行选择排序就是把所有的队员扫描一遍,找到其中最低的队员,让他与最左边的队员(0号位置)进行
- 8大Java排序方法(由简入繁),有代码详解和原理指导
Byyyi耀
java算法排序算法
1.插入排序升序:publicstaticvoidmain(String[]args){intj;int[]array={14,98,36,80,28,99,55,32};for(inti=1;i=0&&array[j]=0&&array[j]>temp1;j--){array[j+1]=array[j];}array[j+1]=temp1;}}原理:初始化:从数组的第二个元素开始迭代,因为单个元
- Java排序[理解]+冒泡+二分查找
yangm_1111
JAVAjava排序基础算法优化冒泡二分查找
/***冒泡*@authoryangm**///冒泡排序:classBubbleSort{publicstaticvoidsort(intarr[]){intlen=arr.length-1,count=0;for(inti=0;iarr[j+1]){//不能用j++,会改变J的值。inttemp=arr[j];arr[j]=arr[j+1];arr[j+1]=temp;}}}//endout-f
- Java排序算法(一)——归并排序
染的人
Java算法java数据结构
介绍归并排序(MergeSort)是建立在归并操作上的一种有效,稳定的排序算法,该算法是采用分治法(DivideandConquer)的一个非常典型的应用。将已有序的子序列合并,得到完全有序的序列;即先使每个子序列有序,再使子序列段间有序。若将两个有序表合并成一个有序表,称为二路归并。其排序的速度仅次于快速排序,时间复杂度O(nlogn)。Java代码实现/***归并排序*@authorrocky
- java排序算法
洋葱土豆和香菜
排序算法java算法
------冒泡算法publicclassBubbleSort{publicstaticvoidmain(String[]args){int[]arr={64,34,25,12,22,11,90};System.out.println("排序前的数组:"+Arrays.toString(arr));bubbleSort(arr);System.out.println("排序后的数组:"+Array
- 12.21_黑马数据结构与算法笔记Java
simplesin
数据结构与算法笔记java开发语言算法数据结构广度优先迭代加深
//最近在复习,,java的进度会比较慢一些目录219排序算法基数排序2220排序算法java排序221排序e01根据另一个数组次序排序222排序e02根据出现频率排序thinking:关于比较器223排序e03最大间距解法1(超出内存限制)224排序e03最大间距解法2225排序e03最大间距解法3226排序e03最大间距解法4227图基本概念228图表示方式229图java表示230图DFS2
- java排序算法之选择排序
小码农叔叔
javajava数据结构与算法java选择排序
选择排序是表面最稳定的排序算法之一,因为无论什么数据进去,其时间复杂度都是O(n*n),所以如果你的数据规模不大的话,可以考虑使用选择排序,因为它是基于内存排序的算法,速度很快,它的工作原理是:在未排序的序列中找到最小(最大)的元素,放在序列的起始位置,然后再从剩余序列中继续寻找最小最大元素,放到已排序的元素末尾,以此类推,直到所有的元素都排序完毕;原理很好理解,下面就来看具体的代码实现,//选择
- Java排序算法之希尔排序
小筱在线
java算法大全java排序算法算法
希尔排序(ShellSort)又称“缩小增量排序”,是直接插入排序算法的一种更高效的改进版本。它的基本思想是:首先将整个数组按照一定的间隔分成若干个子序列,然后对每个子序列分别进行插入排序,减小间隔,再进行排序,直至间隔减至1。该算法主要分为以下几个步骤:先确定一个增量(间隙)序列,通常以数组长度的一半作为初始增量,不断缩小增量的值,直到为1为止。以增量序列中的每个值作为间隔,将待排序元素分成若干
- Java排序算法之堆排序
小筱在线
java算法大全算法数据结构堆排序
图解堆排序是一种常见的排序算法,它借助了堆这种数据结构。堆是一种完全二叉树,它可以分为两种类型:最大堆和最小堆。在最大堆中,每个结点的值都大于等于它的子结点的值,而在最小堆中,每个结点的值都小于等于它的子结点的值。堆排序的基本思想是:先将待排序的序列构建成一个最大堆(或者最小堆),然后将堆顶元素(最大值或最小值)与序列的最后一个元素交换位置,然后再将剩余的元素重新构建成一个最大堆(或最小堆),继续
- Java排序算法之贪心算法
小筱在线
java算法大全排序算法算法贪心算法
贪心算法是一种优化问题的解决方法,它在每一步选择中都采取在当前状态下最好或最优(即最有利)的选择,从而希望导致结果是全局最优的。贪心算法常用于最优化问题,比如最小生成树、哈夫曼编码、最短路径等。贪心算法是一种简单而有效的算法,它不需要对问题的所有情况进行全局搜索,可以在较短时间内得到较优解。但是,由于贪心算法仅考虑局部最优解,可能导致无法得到全局最优解。因此,在使用贪心算法时需要对问题进行分析,判
- Java排序算法之归并排序
小筱在线
java算法大全算法排序算法归并排序
图解归并排序是一种效率比较高的分治排序算法,主要分为两个步骤,分别为“分”和“并”。分:将序列不断二分,直到每个子序列只有一个元素为止。并:将相邻两个子序列进行合并,合并时比较两个子序列的元素大小,按照从小到大的顺序放入新的序列中。是一种分治算法,在每轮排序中将待排序数组分成两部分,递归地将每个子数组排序,最后将两个排好序的子数组合并成一个有序数组。具体实现如下:将待排序数组分成两个子数组,每个子
- Java排序算法之基数排序
小筱在线
java算法大全排序算法java算法基数排序
基数排序(RadixSort)是一种线性时间复杂度的排序算法,其时间复杂度为O(d(n+k)),其中d是数字的位数,k是进制数。基数排序是一种非比较排序算法,它按照数位的大小来进行排序。它可以处理正整数、负整数和小数。基数排序的实现过程如下:找到最大数,并确定最大数的位数。从个位数开始,把所有数按照该位数进行排序。可以使用计数排序或桶排序。排序后,原数组变成了按照该位数排序后的数组。重复第二步,直
- java排序归纳(全世界最(不)全的排序)未完待续
夏木一秋
java排序算法算法
排序分好几种1.选择排序2.冒泡排序3.插入排序4.归并排序5.快速排序6.堆排序1.选择排序时间复杂度为O(n^2),空间复杂度为O(n)比较基础的遍历啦思想是很容易的,将数组先遍历一遍(0~length-1)找到最小的的值,将他放在第一位(索引为0),继续交换剩余数组(1~length-1)将他和第二个数进行交换(索引为1)一直到条件不满足。文字描述文化有限,我们来看看代码:for(inti=
- JAVA排序:快速排序算法
zzh969
java排序算法算法
Java实现快速排序算法快速排序算法体现了—分治思想:将大问题划分为多个相同独立的小问题,每个小问题的解决合在一起解决了大问题实现快速排序的思想:{2,4,1,0,3,5}是目标数组{0,1,2,3,4,5}是结果数组选取中心轴pivot(中心轴的值用于比较,坐标用于返回);中心轴左边=中心轴值(==因为指针也要移动,否则跳不出循环)返回中心轴坐标(此时中心轴100%是结果数组的位置)基于中心轴坐
- 四数之和-力扣18-java排序+双指针
TLJava^v^
#力扣-java力扣java四数之和排序双指针
一、题目描述给你一个由n个整数组成的数组nums,和一个目标值target。请你找出并返回满足下述全部条件且不重复的四元组[nums[a],nums[b],nums[c],nums[d]](若两个四元组元素一一对应,则认为两个四元组重复):0>fourSum(int[]nums,inttarget){intlen=nums.length;List>ans=newArrayList0&&nums[a
- 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