- 最大公因数与最小公倍数的关系(公式推导)
Geometry Fu
最大公因数最小公倍数
最大公因数与最小公倍数公式概览a,ba,ba,b的最小公倍数lcm(a,b)lcm(a,b)lcm(a,b)a,ba,ba,b的最大公因数gcd(a,b)gcd(a,b)gcd(a,b)a,b,ca,b,ca,b,c的最小公倍数lcm(lcm(a,b),c)lcm(lcm(a,b),c)lcm(lcm(a,b),c)(二者先求最小公倍数,结果与第三个数求最小公倍数)a,b,ca,b,ca,b,c的
- 第十六届蓝桥杯模拟赛(第一期)-c++/c
shix .
算法竞赛c++蓝桥杯c语言
c++/c蓝桥杯模拟赛题解,非常详细质因数1、填空题【问题描述】如果一个数p是个质数,同时又是整数a的约数,则p称为a的一个质因数。请问2024有多少个质因数。【答案提交】这是一道结果填空的题,你只需要算出结果后提交即可。本题的结果为一个整数,在提交答案时只填写这个整数,填写多余的内容将无法得分.写一个判断质数和约数的函数判断即可约数判断可以直接使用c++的__gcd(最大公因数)函数,当然也可以
- 最大公因数/最大公倍数
X_Eartha_815
C++/算法/数据结构算法数据结构
目录一、最大公因数-辗转相除法二、最大公倍数-(有了最大公因数)最多个数的最大公倍数三、实战-L1-009N个数求和思路:代码:一、最大公因数-辗转相除法递归-精简形式intgcd(inta,intb)//求最大公约数{returnb==0?a:gcd(b,a%b);}二、最大公倍数-(有了最大公因数)//最大公倍数intgcm(inta,intb){intgcds=b==0?a:gcd(b,a%
- STL学习笔记
2301_76962440
c++学习笔记
包含数据结构和数学函数#includeusingnamespacestd;boolcmp(paira,pairb){//第二位从小到大if(a.second!=b.second)returna.secondb.first;}intgcd(inta,intb){if(!b)returna;elsereturngcd(b,a%b);}intlcm(inta,intb){returna/gcd(a,b)
- 常见JVM命令
yyueshen
JVMjvmjava
1.java-XX:+PrintCommandLineFlagsHelloGC作用:打印JVM启动时的命令行参数,包括用户显式设置的参数和JVM自动默认设置的参数。用于确认JVM实际使用的配置。2.java-Xmn10M-Xms40M-Xmx60M-XX:+PrintCommandLineFlags-XX:+PrintGC-XX:+PrintGCDetails-XX:+PrintGCTimeSta
- SpringBoot的两种启动方式原理
seven97_top
SpringBootspringboot后端java
使用内置tomcat启动配置案例启动方式IDEA中main函数启动mvnspringboot-runjava-jarXXX.jar使用这种方式时,为保证服务在后台运行,会使用nohupnohupjava-jar-Xms128m-Xmx128m-Xss256k-XX:+PrintGCDetails-XX:+PrintHeapAtGC-Xloggc:/data/log/web-gc.logweb.ja
- leetcode[1447]最简分数 python3实现 (判断互质,gcd求最大公约数)
zhang35
LeetCodeleetcode算法
#给你一个整数n,请你返回所有0到1之间(不包括0和1)满足分母小于等于n的最简分数。分数可以以任意顺序返回。####示例1:##输入:n=2#输出:["1/2"]#解释:"1/2"是唯一一个分母小于等于2的最简分数。##示例2:##输入:n=3#输出:["1/2","1/3","2/3"]###示例3:
- LeetCode 1447 最简分数[枚举] HERODING的LeetCode之路
HERODING77
LeetCodeleetcode算法排序算法数据结构程序设计
解题思路:解决该问题一个非常简单的方法是枚举法,通过枚举所有符合条件的分数求得最后的集合,这里需要用到辗转相除法,以达到最简分数,而且通过这种方法不会重复。枚举所有的分母和分子,判断分子分母是否互质,然后放入ans数组中,代码如下:intgcd(inta,intb){returna%b==0?b:gcd(b,a%b);}classSolution{public:vectorsimplifiedFr
- LeetCode 1447 最简分数
雾月55
leetcode算法职场和发展
0到1之间的最简分数求解(Java实现)一、题目描述给定整数n,返回所有满足以下条件的分数:数值在(0,1)区间内(不包含0和1)分母小于等于n最简分数(分子分母互质)示例:输入n=4,输出["1/2","1/3","1/4","2/3","3/4"]二、核心思路分析1.数学本质最简分数的核心条件是分子与分母互质(最大公约数GCD为1)。遍历所有可能的分母d(2≤d≤n),对每个分母遍历分子n(1
- 求最大公约数问题(信息学奥赛一本通-1207)
Doopny@
信息学奥赛一本通算法数据结构
【题目描述】给定两个正整数,求它们的最大公约数。【输入】输入一行,包含两个正整数(usingnamespacestd;intgcd(intm,intn){if(n==0)returnm;returngcd(n,m%n);}intmain(){intm,n;cin>>m>>n;cout<<gcd(m,n);return0;}
- 2025-03-01 学习记录--C/C++-PTA 7-35 有理数均值
小呀小萝卜儿
学习-C/C++学习c语言
合抱之木,生于毫末;九层之台,起于累土;千里之行,始于足下。一、题目描述⭐️二、代码(C语言)⭐️#include//【关键】计算最大公约数(GCD)longlonggcd(longlonga,longlongb){while(b!=0){//当b不为0时循环longlongtemp=b;//临时变量存储b的值b=a%b;//计算a除以b的余数,赋值给ba=temp;//将之前存储的b的值赋值给a
- 最大公约数和最小公倍数
王嘉俊925
算法算法c++C++
最大公约数和最小公倍数最大公约数两个数a和b的最大公约数是指它们所有公约数中最大的那个,通常记作gcd(a,b)。定义公约数:能同时整除a和b的正整数。最大公约数:所有公约数集合中的最大值。例如:gcd(12,18)=6,因为6是12和18的最大公约数。求解方法1.欧几里得算法(辗转相除法)原理:对于正整数a和b,有gcd(a,b)=gcd(b,a%b),其中%表示取模运算(求余数)。该方法通过不
- 欧几里得算法
王嘉俊925
算法算法c++
欧几里得算法(辗转相除法)欧几里得算法(EuclideanAlgorithm)是一种高效计算两个非负整数最大公约数(GCD)的方法。它不仅简单易懂,而且在数学和计算机科学中有着广泛的应用。以下是对该算法的深入讲解,包括其原理、扩展、时间复杂度分析以及实际应用。1.算法原理欧几里得算法的核心思想基于以下数学原理:辗转相除法:对于两个整数a和b(a≥b)(a\geqb)(a≥b),它们的最大公约数gc
- nsq 源码解读(1): debug 环境搭建
nsqgokafka
一、环境准备cd~/work/github/
[email protected]:nsqio/go-nsq.gitcdnsqgomodtidy&&gomodvendor二、本地debugcd/Users/yz/work/github/nsq/appscp-rnsqdnsqd2/cp-rnsqdnsqd3/本人使用的IDE是cursor(vscode)也一样,创建launch.json文件c
- 《Python 中的数学魔法:轻松计算最大公约数和最小公倍数》
清水白石008
pythonPython题库python开发语言
标题:《Python中的数学魔法:轻松计算最大公约数和最小公倍数》在数学和编程中,最大公约数(GreatestCommonDivisor,GCD)和最小公倍数(LeastCommonMultiple,LCM)是两个非常重要的概念。它们在分数运算、密码学、计算几何等领域都有广泛应用。今天,我们将深入探讨如何使用Python编写一个高效、实用的函数来计算两个数的最大公约数和最小公倍数。理解基本概念在开
- 数学--GCD和LCM
wperseverance
蓝桥杯算法
GCD/LCM一、提前说明二、实现1.GCD(1)快速上手,内置函数(2)自己实现,理解原理2.LCM(1)快速上手,内置函数(2)自己实现,理解原理总结提示:以下是本篇文章正文内容,下面案例可供参考一、提前说明1.最大公约数(GCD)2.最小公倍数(LCM)3.从Python3.5开始,math模块提供了math.gcd()函数,可以直接计算两个数的最大公约数。4.最小公倍数可以通过公式LCM(
- 算法学习笔记之数学基础
threesevens
算法与数据结构算法
例1(最小公倍数与最大公约数)计算最小公倍数公式:LCM(A,B)=A*B/GCD(A,B)A与B的最小公倍数等于A*B除以A与B的最大公约数计算最大公约数:辗转相除法原理:设A与B的最大公约数为x,则A是x的倍数,B也是x的倍数,令A=ax,B=bx,A/B取整为c,则A-cB=(a-bc)x。即A与B的余数也是x的倍数 intgcd(inta,intb) { inttemp; whil
- ACM培训4
ZIZIZIZIZ()
算法笔记
学习总结--基础数论大多为模板一、GCD(最大公约数)①辗转相除法longlonggcd(longa,longb){longlongr;while(b!=0){r=a%b;a=b;b=r;}returna;}②扩展欧几里得算法intexgcd(inta,intb,int&x,int&y){if(b==0){x=1;y=0;returnaa;}intans=exgcd(b,a%b,x,y);intk
- C++求最大公因数的几种方法
暮希溪
c++算法开发语言
①直接函数求解cin>>a>>b;c=__gcd(a,b);cout>a>>b;intm=min(a,b);//求a和b的较小值intans;for(inti=1;i>a>>b;c=a%b;while(c!=0){a=b;b=c;c=a%b;}cout<<b;三种方法都能用,看题目适用哪种
- 【密码学基础】RSA加密算法
Mr.zwX
隐私计算及密码学基础密码学安全
1RSA介绍RSA是一种非对称加密算法,即加密和解密时用到的密钥不同。加密密钥是公钥,可以公开;解密密钥是私钥,必须保密保存。基于一个简单的数论事实:两个大质数相乘很容易,但想要对其乘积进行因式分解却极其困难,因此可以将乘积公开作为加密密钥,即公钥;而两个大质数组合成私钥。2密钥对的生成step1生成N(公钥和私钥的一部分)首先选取两个互为质数的数ppp和qqq(p≠q,gcd(p,q)=1p\n
- 1246. 等差数列
Taoger_Xu
算法
文章目录题目大意:题目分析AC代码题目大意:题目分析读题的时候首先想到了差分,后来发现是一道思维题,Si=Ai-Ai-1,如果满足等差数列,假设所给的n项之间间隔分别为S1,S2...Sk,设公差为d,则满足Si=ki*d,如果Si=kd,那么ai-1后面要添加的数为k,例如2,88-2=6=3*2,则2后面需要添加4,6,8三项构成等差。所以等差d为差分数组的gcdAC代码#include#in
- 【16届蓝桥杯寒假刷题营】第2期DAY5
qystca
算法数据结构c++蓝桥杯
2.最大公因数-蓝桥云课问题描述给你2个正整数N,M。你需要构造一个有N个数的正整数序列a,满足以下条件:∑i=1Nai=M。求gcd(a),可能的最大值。输入描述输入一行两个正整数N,M,表示数组的长度和数组元素总和。输出描述输出一行,表示答案。输入格式19189114514输出格式2评测数据范围1≤N≤M≤109思路:如果m/n可以整除,那么这个m/n就是最大公因数,因为平均分配了。如果不可以
- gcd之和(一维)
骑狗看夕阳
算法c++
gcd之和求∑i=1ngcd(n,i)\sum_{i=1}^{n}\gcd(n,i)∑i=1ngcd(n,i)。那么我们这一道题讲得详细一点。因为这一道题目的n≤109n\leq10^9n≤109。这也就导致了一些算法是过不了的,那么我们就先从最简单的讲起:对每一项来一遍gcd\gcdgcd,然后gcd\gcdgcd我们也使用最简单的哪一种去做,也就是从小到大跑,时间复杂度O(n2)O(n^
- 二进制 GCD 学习笔记
PandaLYL
数学学习笔记
前言欧几里得算法可以在log的时间复杂度内求出个数的GCD,但是这还是太慢了。在一些题目中,欧几里得算法就会TLE。欧几里得算法理论:gcd(a,b)=gcd(b,a mod b)\gcd(a,b)=\gcd(b,a\bmodb)gcd(a,b)=gcd(b,amodb)二进制GCD更相减损术已知两个数aaa,bbb,求gcd(a,b)\gcd(a,b)gcd(a,b)。设a≥ba\geba
- 蓝桥杯Python组最后几天冲刺———吐血总结,练题总结,很管用我学会了
晚风时亦鹿
学习笔记Python算法笔记python
一、重要知识要点1、穷举法2、枚举法3、动态规划4、回溯法5、图论6、深度优先搜索(DFS)7、广度优先搜索(BFS)8、二叉树9、递归10、分治法、矩阵法11、排列组合12、素数、质数、水仙花数13、欧几里得定理gcd14、求最大公约数、最小公倍数15、海伦公式(求三角形面积)16、博弈论17、贪心18、二分查找法19、hash表20、日期计算21、矩形快速幂22、树形DP23、最短路径24、最
- Swift语言的多线程编程
Code侠客行
包罗万象golang开发语言后端
Swift语言的多线程编程在现代软件开发中,多线程编程是提高应用性能和响应速度的重要手段。尤其是在iOS和macOS开发中,由于用户界面(UI)的交互性和复杂性,合理利用多线程可以极大地提升用户体验。本文将深入探讨Swift语言中的多线程编程机制,包括GCD(GrandCentralDispatch)、NSOperation、线程的基本概念及其使用场景。一、什么是多线程多线程是一种程序设计理念,通
- Python内置模块-Math
-MaoKe-
Python模块python前端
文章目录Python内置模块-Math一、模块介绍二、数值运算1.math.ceil()2.math.floor()3.math.fabs()4.math.modf()5.math.trunc()6.math.factorial()7.math.fmod()8.math.fsum()9.math.gcd()10.math.frexp()11.math.ldexp()12.math.copysign
- 2807. 在链表中插入最大公约数
不玩return的马可乐
链表数据结构leetcode算法职场和发展c++
在本篇博客文章中,我们将探讨如何实现一个算法,该算法可以在链表中相邻节点之间插入一个新的节点,新节点的值为相邻两个节点值的最大公约数(GCD)。这个问题是LeetCode上的一个中等难度问题,涉及到链表操作和最大公约数的计算。问题描述解题思路理解问题首先,我们需要理解问题的核心:在链表的相邻节点之间插入新节点,新节点的值为相邻节点值的最大公约数。计算最大公约数我们需要一个函数来计算两个数的最大公约
- 最详细G1垃圾回收器日志解读
齐梦星空
jvm
首先,开启gc日志。-XX:+PrintGCDetails疏散阶段疏散阶段,主要是将内存中的数据从一些分区复制到其他分区0.522:[GCpause(young),0.15877971secs]#这次疏散只涉及年轻代,总耗时0.15877971.如果是混合gc则可能是[GCpause(mixed),0.32714353secs][ParallelTime:157.1ms]#并行疏散,总耗时157.
- G1原理—G1的GC日志分析解读
液态不合群
jvmjava算法
1.TLAB的GC日志解读(1)一套基本的参数设置首先参数上要有一套基本的设置:-XX:InitialHeapSize=128M-XX:MaxHeapSize=128M-XX:+UseG1GC-XX:+PrintGCDetails-XX:+PrintGCTimeStamps-XX:+PrintTLAB-XX:+UnlockExperimentalVMOptions-XX:G1LogLevel=fi
- 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