- HPC综合-心得与笔记【19】
sakura_sea
HPCand3DGraphicsEngine线性规划
Dijkstra算法【2】基础距离数组dist,设置起点距离为0,其他节点距离为无穷大(∞)用最小堆创建优先队列,将起点放入队列。从队列中取出当前距离最小的节点u。遍历u的每个邻接节点v,计算从起点到v的路径长度:alt=dist[u]+weight(u,v)。如果altdist[u]:continue#遍历邻接节点forv,weightingraph[u].items():alt=dist[u]
- 3.14学习总结
2402_88131930
学习
今天完成了几道关于二叉树的算法题关于二叉树的最小最大深度和数据流中的第k大元素,用到优先队列,学习了有关java的基础知识,学习了双指针法。
- LeetCode:215 数组中第k个最大元素 优先队列 / 堆
AkagiSenpai
LeetCode数据结构leetcode数据结构优先队列堆
在未排序的数组中找到第k个最大的元素。请注意,你需要找的是数组排序后的第k个最大的元素,而不是第k个不同的元素。示例1:输入:[3,2,1,5,6,4]和k=2输出:5示例2:输入:[3,2,3,1,2,4,5,5,6]和k=4输出:4说明:你可以假设k总是有效的,且1≤k≤数组的长度。来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/kth-l
- 分治思想--快速排序 | 优先队列:力扣215. 数组中的第K个最大元素
剑圣土豆
LeetCode高频面试题
1、题目描述:2、题解:哈希表:力扣347.前K个高频元素方法1:暴力解法:也就是我们进行排序(默认从小到大),然后倒序取第K个元素即可。classSolution:deffindKthLargest(self,nums:List[int],k:int)->int:nums.sort()returnnums[-k]方法2:分治思想,也即是快速排序中的主要部分进行变体,我们找到第len(nums)-
- 贪心算法--将数组和减半的最小操作数
4C++
数据结构与算法贪心算法算法
本题是力扣2208---点击跳转题目思路:要尽快的把数组和减小,那么每次挑出数组中最大的元素减半即可,由于每次都是找出最值元素,可以用优先队列来存储这些数组元素每次取出最值,减半后再放入优先队列中,操作次数+1,直到数组和小于等于原总和的一半代码:classSolution{public:inthalveArray(vector&nums){doublesum=0;intcnt=0;priorit
- 5、STL中priority_queue的使用方法
周Echo周
STLc++开发语言笔记c语言算法数据结构leetcode
一、了解priority_queue用于实现优先队列(堆)。它基于std::vector(默认使用vector)或std::deque实现,默认情况下是一个最大堆(即队首元素是最大的元素)。对于异常处理,空队列一般自定义,但是priority_queue会使用std::out_of_range异常。时间复杂度插入操作:O(logn)删除操作:O(logn)访问队首元素:O(1)常见问题1、如何从给
- LeetCode 热题 100_前 K 个高频元素(73_347_中等_C++)(堆)(哈希表+排序;哈希表+优先队列(小根堆))
Dream it possible!
LeetCode热题100leetcodec++散列表数据结构
LeetCode热题100_前K个高频元素(73_347)题目描述:输入输出样例:题解:解题思路:思路一(哈希表+排序):思路二(哈希表+优先队列(小根堆)):代码实现代码实现(思路一(哈希表+排序)):代码实现(思路二(哈希表+优先队列(小根堆))):以思路二为例进行调试部分代码解读题目描述:给你一个整数数组nums和一个整数k,请你返回其中出现频率前k高的元素。你可以按任意顺序返回答案。输入输
- 算法与竞赛(第7章) - C++与STL基础三:队列以及优先队列的应用
Ssaty.
算法c++动态规划
第1关:STL模板之queue实例一:最少个数本关任务:给定N个非负整数,求解至少需要选多少个连续的数,它们的和不小于给定的整数S,特别的,若没有解,则输出0。//请在这里补充代码,完成本关任务/*********Begin*********/intn;ints;queueque;intans=
- Java 常用命令总结(完)
羊不白丶
java开发语言后端
更新了版本,请移步Java常用命令总结持续更新中!!!目录基础输入保留几位小数Random数组SystemArraysHashMapHashSetStringStringBuilderArrayListDeque栈Queue队列PriorityQueue优先队列常用数学算法&&结论结论算法ScannerIntegerIterator迭代器MathComparator&&Comparable的使用其
- POJ 2227 The Wedding Juicer(优先队列+BFS)
幼儿园大哥~
数据结构算法
传送门题目大意一个矩形区域,高低起伏,求最多储水量。(边界不能储水)思路先将边界加入优先队列,每次取高度最小的点,找与其相邻且未访问过的点,若邻点高度大于等于它,直接加入优先队列更新边界,否则更新答案,并将邻点的高度置为该点高度,然后加入优先队列更新边界。代码structnode{intx;inty;llh;booloperatorX.h;}};intn,m;lla[500][500];intvi
- POJ 2227 -- The Wedding Juicer(bfs+优先队列)
Ac-try
队列/优先队列搜索
题目大意:一个W*H的网格,每个单位格的高度不一样,往这个网格注水,问能储存多少水;思路分析:四周不能注水,和木桶原理一样,要以最低的高度作为能储水的高度,否则水就会溢出;将网格最外层的点开始加入队列,每次去高度最小的点作为“木桶”最低边,看其连接的点,如果高度大于自己加入队列,否则注水至自己的高度加入队列。代码实现:#include#include#includeusingnamespacest
- C语言优先队列作用,优先队列(priority_queue)的C语言实现(原创)
福建低调
C语言优先队列作用
优先队列(priority_queue)和一般队列(queue)的函数接口一致,不同的是,优先队列每次出列的是整个队列中最小(或者最大)的元素。本文简要介绍一种基于数组二叉堆实现的优先队列,定义的数据结构和实现的函数接口说明如下:一、键值对结构体:KeyValue//=============KeyValueStruct==================================typed
- C语言优先队列作用,优先队列--C语言实现
CyberStar
C语言优先队列作用
优先队列--C语言实现向乔布斯致敬世界的今天因他而改变!世界的今天因他而多彩!JOBS优先队列--C语言实现/*binomial.h*/#ifndef_BINOMIAL_H_#define_BINOMIAL_H_typedeflongelement_type;#defineINFINITY(30000L)#defineMAX_TREES(14)#defineCAPACITY(16383)struc
- C语言实现优先队列
嵌入式系统攻城狮
AD18c语言数据结构开发语言
优先队列(堆)是允许至少下列两种操作的数据结构:Insert(插入),它的工作显而易见的,以及DeleteMin(删除最小者),它的工作是找出、返回和删除优先队列中最小的元素。如同大多数数据结构那样,有时可能要添加一些操作,但这些添加的操作属于扩展的操作,而不属于图1所描述的基本模型。使操作被快速执行的性质是堆序(heaporder)性,由于我们想要快速地找到最小元因此最小元应该在根上。应用这个逻
- 优先队列——C语言实现
昆昆欧粑粑
c语言学习优先队列堆C语言
队列的特点是,先进先出。优先队列的特点是,进来的,根据优先次序,一个个出来。我们可以使用堆的思想来解决这个问题。代码:堆的实现参照:堆——用C语言实现,里面会用到头文件(包含堆):#define_CRT_SECURE_NO_WARNINGS1#include#include#includetypedefintHeapDataType;typedefstructMaxHeap{HeapDataTyp
- 【路径规划】二维Dijkstra启发式改进算法
神精兵院院长
Python算法算法python动态规划
我们使用了A*算法的启发式(曼哈顿距离)来改进Dijkstra算法的性能。当我们将邻居节点添加到优先队列时,我们使用了distance+heuristic作为优先级,这样我们可以更快地找到通往目标节点的路径。importheapqimportnumpyasnpdefheuristic(a,b):(x1,y1)=a(x2,y2)=breturnabs(x1-x2)+abs(y1-y2)#使用曼哈顿距
- Python的标准库heapq模块的介绍和简单应用
新时代先锋
理论知识python算法开发语言数据结构
文章目录1.堆的基本概念2.`heapq`模块的基本使用2.1创建堆2.2插入元素2.3弹出元素3.其他重要函数3.1`heappushpop`3.2`heapreplace`3.3`nlargest`和`nsmallest`3.4`merge`4.堆的应用场景4.1优先队列4.2堆排序5.结论heapq是Python标准库中一个非常有用的模块,主要用于实现堆(Heap)数据结构,特别是最小堆(M
- 【Java常用容器】Map+Set+栈+队列+List+StringBuilder+Arrays+BigInteger+进制转换+保留小数
Roye_ack
java语法课javaHashMapSet栈队列BigIntegr算法
目录一、Map类1、HashMap2、TreeMap-补充3、遍历二、Set类1、HashSet2、TreeSet-补充三、栈Stack1、定义2、相关操作四、队列Queue1、定义2、相关操作3、优先队列PriorityQueue-补充4、双端队列-补充五、List1、定义2、list自定义排序3、浅拷贝和深拷贝4、二维List六、StringBuilder1、定义2、字符串链接append3、
- 【洛谷贪心算法】P1090合并果子
Reese_Cool
洛谷贪心算法算法c++蓝桥杯开发语言
为了使消耗的体力最小,每次都应该选择当前重量最小的两堆果子进行合并。可以使用优先队列(小根堆)来实现这个过程,优先队列可以自动维护元素的顺序,每次取出堆顶的两个元素(即最小的两个元素)进行合并,然后将合并后的结果重新插入堆中,重复这个过程直到堆中只剩下一个元素。【算法思路】优先队列的定义:使用priority_queue,greater>pq;定义一个小根堆,这样每次从堆中取出的元素都是当前最小的
- 【数据结构】 最大最小堆实现优先队列 python
查理零世
数据结构python
堆的定义堆(Heap)是一种特殊的完全二叉树结构,通常分为最大堆和最小堆两种类型。在最大堆中,父节点的值总是大于或等于其子节点的值;而在最小堆中,父节点的值总是小于或等于其子节点的值。堆常用于实现优先队列,在许多算法中也有重要应用,比如堆排序、Dijkstra算法等。堆的基本操作插入:向堆中添加一个新元素,并调整堆以保持其性质。删除:移除堆顶元素(最大或最小元素),并重新调整堆。获取最大/最小元素
- c++优先队列使用总结,简单易懂
01_
实用技巧c++开发语言优先队列重载仿函数
优先队列(PriorityQueue)是一种抽象数据类型,类似于常规的队列或栈,但每个元素都有一个优先级。元素的出队顺序不是按照它们进入队列的顺序,而是根据它们的优先级。优先级最高的元素最先出队。主要特点:元素优先级:每个元素都有一个优先级,通常用数值表示,数值越小(或越大)优先级越高。出队顺序:优先级最高的元素最先出队。实现方式:优先队列通常通过堆(Heap)数据结构实现,但也可以用其他方式(如
- 【GoLang】【算法模板】2、GoLang 算法模板整理
Ypuyu
GoLanggolang算法开发语言
文章目录0、前言1、GoLang算法必会技巧1.1、标准库1.1.1、sort包1.1.2、slice包1.2、数据结构1.2.1、常用数据结构1.2.1.1、优先队列1.2.2、冷门的数据结构1.2.2.1、跳表2、板子2.1、二分2.1.1、lower_bound、upper_bound2.2、字符串2.2.1、kmp0、前言整理一下golang的算法板子,作为备忘录使用。可能有些板子、博文是
- LeetCode热题100刷题12
Liwan95
LeetCodeleetcode算法职场和发展
23.合并K个升序链表给你一个链表数组,每个链表都已经按升序排列。请你将所有链表合并到一个升序链表中,返回合并后的链表。与合并两个有序链表类似,但是需要在k个链表节点中找到最小的。考虑使用优先队列。classSolution{classStatusimplementsComparable{intval;ListNodenode;publicStatus(intval,ListNodenode){t
- BZOJ 1726: [Usaco2006 Nov]Roadblocks第二短路 ——Dijkstra+玄学
通信男神杨丽斌
瞎写图论
这个题玄学冲过,规定每个点访问次数不能超过50次,然后找优先队列中第二次到达终点t的状态返回就ok记录一下,怕忘了#include#include#include#include#include#include#includeusingnamespacestd;constintmaxn=5010;constintINF=0x3f3f3f3f;structHeapNode{intd,u;HeapNo
- 【Python 语法】heapq 模块
一杯水果茶!
python
堆的应用场景主要功能示例:使用`heapq`实现优先队列heapq是Python标准库中用于实现堆队列(heapqueue)算法的模块。堆队列是一个基于堆(heap)数据结构的优先队列,它能在O(logn)时间内执行插入、删除最小元素等操作。Python中的heapq模块实现的是一个最小堆(min-heap),即堆顶元素是堆中的最小元素。堆的应用场景优先队列:heapq可以用来实现优先队列,按优先
- c/c++蓝桥杯经典编程题100道(22)最短路径问题
tamak
算法数据结构图论c语言c++蓝桥杯
最短路径问题->返回c/c++蓝桥杯经典编程题100道-目录目录最短路径问题一、题型解释二、例题问题描述三、C语言实现解法1:Dijkstra算法(正权图,难度★★)解法2:Bellman-Ford算法(含负权边,难度★★★)四、C++实现解法1:Dijkstra算法(优先队列优化,难度★★☆)解法2:Floyd-Warshall算法(多源最短路径,难度★★★)五、总结对比表六、特殊方法与内置函数
- 图论- Dijkstra算法
左灯右行的爱情
图论算法python
Dijkstra算法前言概念BFS基础模版DijkstraDijkstra函数签名State类distTo记录最短路径伪代码模版第一个问题解答第二个问题解答第三个问题解答前言学习这个算法之间,必须要对BFS遍历比较熟悉,它的本质就是一个特殊改造过的BFS算法.概念Dijkstra算法是一种计算图中单源最短路径算法,本质上是一个经过特殊改造的BFS算法,改造点有两个:使用优先队列,而不是普通队列进行
- C++,STL容器适配器,priority_queue:优先队列深入解析
智驾
C/C++c++开发语言STL
文章目录一、容器概览与核心特性核心特性速览二、底层实现原理1.二叉堆结构2.容器适配器架构三、核心操作详解1.容器初始化2.元素操作接口3.自定义优先队列四、实战应用场景1.任务调度系统2.合并K个有序链表五、性能优化策略1.底层容器选择2.批量建堆优化六、注意事项与陷阱1.常见错误操作2.比较函数要求七、C++新标准增强1.C++11移动语义2.C++17节点操作(需要底层容器支持)总结与最佳实
- 学习总结3
落木*
学习java前端
(1)《PriorityQueue》title:输入多个对优先队列S的操作被给出。每个操作在一行中给出,格式为"insertk"、"extract"或"end"。这里,k表示要插入优先队列的整数元素。输入以"end"操作结束。输出对于每个"extract"操作,打印从优先队列S中提取的元素,每个元素占一行。约束操作的数量≤2,000,0000≤k≤2,000,000,000解题思路:初始化最大堆:
- 图论 —— SPFA 模板
努力的老周
OI笔记算法模板笔记图论算法数据结构SPFA算法
概述本文使用优先队列优化的SPFA算法。时间复杂度一般为O(m)O(m)O(m),最坏为O
- 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