霍尔快排代码:voidSwap(int*a,int*b){inttmp=0;tmp=*a;*a=*b;*b=tmp;}voidQuickSort(int*a,intbegin,intend){if(begin>=end)return;intleft=begin,right=end;intkeyi=left;while(left=a[keyi])right--;while(left
C++ 数论相关题目(快速幂求逆元)
伏城无嗔
数论力扣算法笔记c++算法
给定n组ai,pi,其中pi是质数,求ai模pi的乘法逆元,若逆元不存在则输出impossible。注意:请返回在0∼p−1之间的逆元。乘法逆元的定义若整数b,m互质,并且对于任意的整数a,如果满足b|a,则存在一个整数x,使得ab≡a×x(modm),则称x为b的模m乘法逆元,记为b−1(modm)。b存在乘法逆元的充要条件是b与模数m互质。当模数m为质数时,bm−2即为b的乘法逆元。输入格式第
【数学】二元一次不定方程、裴蜀定理、扩展欧几里得算法与乘法逆元
OIer-zyh
数学#数论c++算法OI数论数学
二元一次不定方程形如ax+by=cax+by=cax+by=c的方程称为二元一次不定方程。在数论中一般研究该方程的整数解。明显原方程无整数解或有无穷多组整数解。裴蜀定理裴蜀定理:当且仅当gcd(a,b)∣c\gcd(a,b)|cgcd(a,b)∣c时,二元一次不定方程有整数解。一方面,ax+by≡0≡c(modgcd(a,b))ax+by\equiv0\equivc\pmod{\gcd(a,b
作业六
Whalawhala
1.设G是群,H是G的子群。任取g1,g2属于G,则g1H=g2H当且仅当g1-1g2属于H。充分性由于g1H=g2H,即存在h1,h2属于H,使g1h1=g2h2,由消去律可得g1-1g2=h1h2-1,则g-1g2属于H。必要性由于g1-1g2属于H,以及群的封闭性所以g1-1,g2属于H,有群公理又易得g-1的乘法逆元g属于H,故g1H=g2H。2.如果群H是群G的子群,且[G:H]=2,请
数论-乘法逆元【裴蜀定理+欧拉定理/费马小定理】
舍舍发抖
数论算法
具体逆元相关看这个博客,更详细裴蜀定理定义:若a,b是整数,且gcd(a,b)=d,那么对于任意的整数x,y,ax+by都一定是d的倍数,特别地,一定存在整数x,y,使ax+by=d成立。(根据拓展欧几里得定理得出ax+by=gcd(a,b))这篇博客提到拓展欧几里的公式及推导这篇也参考一下一个重要推论是:a,b互质的充要条件是存在整数x,y使ax+by=1证明这里就不详细说了,参考博客:http
乘法逆元())
哑巴湖大水怪1
算法
时间复杂度比用费马小定理高,小费马是O(log(p))O(log(p)).但是,小费马要求p是质数,而欧拉定理仅仅要求a,p互质。另外一点就是,用扩欧做得话,时间复杂度也是O(log(p))O(log(p)),且也是要求a,p互质就可以。综合看,扩欧是最优选择。快速幂求逆元时p要求为质数,而扩展欧几里得只要两者互质
乘法逆元学习笔记(初学但易理解)
liaoxiyan123
———数论———逆元抽象代数线性代数
基本概念所谓乘法逆元,就是两个整数a和x相乘再用一个(非1正整数)数p对它们取模,若取模后所得的值等于1,那么x和a在模p条件下互为乘法逆元.用同余方程表达即:a∗x≡1(modp){a*x≡1(mod~p)}a∗x≡1(modp),用一般方程表达为:a∗x−k∗p=1,(k∈z){a*x-k*p=1,(k∈z)}a∗x−k∗p=1,(k∈z).(a存在逆元时有一充要条件:gcd(a,p)=1即a
【数论】一些数论知识
ssllth
数论&数学数论同余约数欧拉定理费马小定理
文章目录前言内容素数关于素数无限个的证明n以内的素数个数算术基本定理约数一个数的正约数个数(约数个数定理)一个数的正约数和(约数和定理)最大公约数和最小公倍数gcd(a,b)*lcm(a,b)=a*b的证明更相减损术欧几里得算法欧拉函数积性函数一些性质同余一些性质欧拉定理费马小定理贝祖定理(裴蜀定理)代码求通解ax+by=nax+by=nax+by=n方程的主要解题步骤线性同余方程乘法逆元线性求逆
使用CKKS全同态求近似倒数(近似乘法逆元)
咸鱼菲菲
同态加密python
求倒数的算法两个数互为倒数,是说这两个数乘起来等1.比如a和b互为倒数,那么ab=1.5的倒数是0.2,我们可以很简单的求出来,但是如何在密文域中求一个数的倒数呢?文章《Aninvestigationofcomplexoperationswithword-sizehomomorphicencryption》中给出了一个算法。我们假设y=1-x,y的模小于(对于实数来说,就是绝对值)0.5,那么有下
上海计算机学会11月月赛 乙组题解
超哥聊信奥
上海计算机学会月赛题解算法c++数据结构动态规划深度优先广度优先
上海计算机学会11月月赛乙组题解本次比赛涉及算法:字符串、贪心、二分、思维、树形动态规划、乘法逆元、状态压缩、折半枚举。比赛链接:https://iai.sh.cn/contest/57第一题:T1连接数字标签:字符串、贪心题意:给定nnn个十进制正整数a1,a2,…,ana_1,a_2,…,a_na1,a2,…,an,将它们重新排列后拼接起来,尽可能地变成一个大数字,输出这个巨大的数字。(1us
rsa算法乘法逆元java_扩展欧几里得算法(求逆元)总结
雪鱼子
rsa算法乘法逆元java
1、在RSA算法生成私钥的过程中涉及到了扩展欧几里得算法(简称exgcd),用来求解模的逆元。2、首先引入逆元的概念:逆元是模运算中的一个概念,我们通常说A是B模C的逆元,实际上是指A*B=1modC,也就是说A与B的乘积模C的余数为1。可表示为A=B^(-1)modC。打个比方,7模11的逆元,即:7^(-1)mod11=8,这是因为7×8=5×11+1,所以说7模11的逆元是8。3、在RSA算
BZOJ-2242: [SDOI2011]计算器(快速幂+拓展欧几里德+Baby Step Giant Step)
AmadeusChan
题目:http://www.lydsy.com/JudgeOnline/problem.php?id=2242第一个操作,直接快速幂即可第二个操作,拆了之后拓展欧几里德,然后调调看有没有合适的解第三个操作,BabyStepGiantStep算法,事实上就是分块思想?:令L=int(sqrt(P)),x=kL+i则y^(kL+i)=Z(modP),那么假如y存在关于P的乘法逆元,则yi=Z*(y(k
费马小定理(求逆元)
Zqchang
#蓝桥杯c++
首先解释一下什么是逆元若整数b,m互质,并且对于任意的整数a,如果满足b|a,则存在一个整数x,使得a/b≡a×x(modm),则称x为b的模m乘法逆元,记为b−1(modm)。b存在乘法逆元的充要条件是b与模数m互质。当模数m为质数时,bm−2b^{m-2}bm−2即为b的乘法逆元。然后我们就会发现,,好家伙,这定义真难懂,然后我们用人话通俗的解释一下紧接着我们来进行一些推导这就是一般的利用快速
java实现仿射密码_java实现仿射密码加密解密
YUNYA麻麻
java实现仿射密码
本文实例为大家分享了java实现仿射密码加密解密的具体代码,供大家参考,具体内容如下加密:将明文转化为对应的数字,如‘a'->0,‘b'->1,…,'1'->26,'2'->27,…然后将数字进行仿射运算,求取出来的数字再转化为字符。即密文=(K1*明文+K2)mod36解密:密文转化为对应数字,然后进行仿射的逆运算,得到对应数字,然后将其转化为字符明文。解密K3是K1的乘法逆元importjav
Java实现仿射密码加密解密
降妖问问你敢不敢
java
Java实现仿射密码加密解密仿射密码加密:将明文转化为对应的数字,如‘a’->0,‘b’->1,…,’1’->26,’2’->27,…然后将数字进行仿射运算,求取出来的数字再转化为字符。即密文=(K1*明文+K2)mod36解密:密文转化为对应数字,然后进行仿射的逆运算,得到对应数字,然后将其转化为字符明文。解密K3是K1的乘法逆元importjava.util.Scanner;publiccla
同余-费马小定理-乘法逆元与线性同余方程
litian355
数学相关算法
update1:初等数论部分(是对下面拓展欧几里得算法的铺垫):update2:由于第一开始学习理解不够深入,出现众多错误,现在看来真是误人子弟(实在太烂了),现在修改了一些错误,同时润滑了一下语言。线性方程ax+by=gcd(a,b)的解:假设特解(x0,y0)是方程组的一组解,d=gcd(a,b),那么通解就是x=x0+b/d*k,y=y0-a/d*k;例如10x+35y=5,的一组特解(-3
乘法逆元的模板代码
想不出来_6
c++算法
//乘法逆元多取模#includeusingnamespacestd;usingll=longlong;constintN=2e6+9;constllp=998244353;//取模的值llqmi(lla,llb)//快速幂模板{llres=1;while(b){if(b&1)res=res*a%p;//b为奇数,实际上还要进行b--,变为一个偶数a=a*a%p,b>>=1;//b为偶数}retu
AcWing 876. 快速幂求逆元
在森林中麋了鹿
早年算法竞赛学过的知识点乘法逆元
题目链接:点击查看题目描述:给定n组ai,pi,其中pi是质数,求ai模pi的乘法逆元,若逆元不存在则输出impossible。注意:请返回在0∼p−1之间的逆元。乘法逆元的定义若整数b,m互质,并且对于任意的整数a,如果满足b|a,则存在一个整数x,使得a/b≡a×x(modm),则称x为b的模m乘法逆元,记为b−1(modm)。b存在乘法逆元的充要条件是b与模数m互质。当模数m为质数时,bm−
大数据安全 | 【实验】RSA加密解密
啦啦右一
#大数据安全大数据与数据分析密码学RSA
文章目录关于RSA实验目的流程梳理Step1:求解乘法逆元Step2:生成密钥Step3:加密解密Step4:最后数据导入实验结果关于RSA实验目的编程实现RSA算法对下列数据实现加密与解密:p=3;q=11,e=7;M=5p=5;q=11,e=3;M=9p=7;q=11,e=17;M=8p=11;q=13,e=11;M=7p=17;q=31;e=7;M=2流程梳理Step1:求解乘法逆元因为已经
ex_gcd 乘法逆元
mrcoderrev
扩展欧几里德
乘法逆元编辑本词条缺少概述,补充相关内容使词条更完整,还能快速升级,赶紧来编辑吧!中文名乘法逆元外文名Multiplicativeinversemodulo适用领域范围数学领域定义群G中任意一个元素a例如4关于1模7的乘法逆元为多少目录1定义2例3代码实现定义编辑群G中任意一个元素a,都在G中有唯一的逆元a‘,具有性质aa'=a'a=e,其中e为群的单位元。例编辑例如:4关于1模7的乘法逆元为多少
费马小定理,876. 快速幂求逆元
Landing_on_Mars
数论数学算法数论逆元
876.快速幂求逆元-AcWing题库给定n组ai,pi,其中pi是质数,求ai模pi的乘法逆元,若逆元不存在则输出impossible。注意:请返回在0∼p−1之间的逆元。乘法逆元的定义若整数b,m互质,并且对于任意的整数a,如果满足b|a,则存在一个整数x,使得a/b≡a×x(modm),则称x为b的模m乘法逆元,记为b−1(modm)。b存在乘法逆元的充要条件是b与模数m互质。当模数m为质数
【数据结构】点分治
SY奇星
高级数据结构数据结构算法
一.介绍点分治(CentroidDecomposition)是一种树分治的技术,主要用于解决树上路径问题。在树结构中,点分治的目标是将原树分解为若干棵子树,使得每个子树的大小都不超过原树大小的一半。这样的分解可以有效地减小问题的规模,从而提高算法的效率。点分治的基本思想是选择一个合适的树节点作为"重心"(Centroid),然后以该节点为根进行递归处理。选取重心的方法是找到使得删除该节点后最大子树
【Luogu】 P3206 [HNOI2010] 城市建设
Farmer_D
Luogu算法
题目链接点击打开链接题目解法动态mstmstmst板板题~考虑类似于线段树分治的做法我们需要把边划分成静态边和动态边动态边是当前分治区间[l,r][l,r][l,r]中修改的边,其他边是静态边我们考虑到静态边的边集太大,考虑缩小范围,不难想到答案加上必选边和删去无用边令动态边的边权为−∞-\infty−∞,这样仍在mstmstmst中的边就是必选边(在区间[l,r][l,r][l,r]中的任何一个
[密码学入门]仿射密码(Affine)
RAVEN_1452
密码学
加密算法y=(ax+b)modN解密算法x=*(y-b)modN(此处的为a关于N的乘法逆元,不是幂的概念)如何求,涉及的知识挺多,还没想好怎么写,丢番图方程,贝祖定理(又译裴蜀定理),扩展欧几里得算法。存在需要满足(a,n)=1。python中可以这么写pow(a,-1,n)
密码学之欧几里得求逆元
幼稚鬼&海南仙女
网络安全【学习笔记】
什么是逆元逆元:官方解释是:逆元素是指一个可以取消另一给定元素运算的元素,在数学里,逆元素广义化了加法中的加法逆元和乘法中的倒数;听起来有一丝不太容易懂;那我们换成例子试一下:(24+4)/mod26=2(24-22)/mod26=2此时,4和22就是mod26下的加法逆元;乘法逆元也是同理原理步骤求A关于模N的逆元B,即求整数B,使得A*BmodN=1对余数进行辗转相除(a是商,r是余数)对除了
312个免费高速HTTP代理IP(能隐藏自己真实IP地址)
yangshangchuan
高速免费superwordHTTP代理
124.88.67.20:843
190.36.223.93:8080
117.147.221.38:8123
122.228.92.103:3128
183.247.211.159:8123
124.88.67.35:81
112.18.51.167:8123
218.28.96.39:3128
49.94.160.198:3128
183.20
pull解析和json编码
百合不是茶
androidpull解析json
n.json文件:
[{name:java,lan:c++,age:17},{name:android,lan:java,age:8}]
pull.xml文件
<?xml version="1.0" encoding="utf-8"?>
<stu>
<name>java
[能源与矿产]石油与地球生态系统
comsci
能源
按照苏联的科学界的说法,石油并非是远古的生物残骸的演变产物,而是一种可以由某些特殊地质结构和物理条件生产出来的东西,也就是说,石油是可以自增长的....
那么我们做一个猜想: 石油好像是地球的体液,我们地球具有自动产生石油的某种机制,只要我们不过量开采石油,并保护好
类与对象浅谈
沐刃青蛟
java基础
类,字面理解,便是同一种事物的总称,比如人类,是对世界上所有人的一个总称。而对象,便是类的具体化,实例化,是一个具体事物,比如张飞这个人,就是人类的一个对象。但要注意的是:张飞这个人是对象,而不是张飞,张飞只是他这个人的名字,是他的属性而已。而一个类中包含了属性和方法这两兄弟,他们分别用来描述对象的行为和性质(感觉应该是
新站开始被收录后,我们应该做什么?
IT独行者
PHPseo
新站开始被收录后,我们应该做什么?
百度终于开始收录自己的网站了,作为站长,你是不是觉得那一刻很有成就感呢,同时,你是不是又很茫然,不知道下一步该做什么了?至少我当初就是这样,在这里和大家一份分享一下新站收录后,我们要做哪些工作。
至于如何让百度快速收录自己的网站,可以参考我之前的帖子《新站让百
oracle 连接碰到的问题
文强chu
oracle
Unable to find a java Virtual Machine--安装64位版Oracle11gR2后无法启动SQLDeveloper的解决方案
作者:草根IT网 来源:未知 人气:813标签:
导读:安装64位版Oracle11gR2后发现启动SQLDeveloper时弹出配置java.exe的路径,找到Oracle自带java.exe后产生的路径“C:\app\用户名\prod
Swing中按ctrl键同时移动鼠标拖动组件(类中多借口共享同一数据)
小桔子
java继承swing接口监听
都知道java中类只能单继承,但可以实现多个接口,但我发现实现多个接口之后,多个接口却不能共享同一个数据,应用开发中想实现:当用户按着ctrl键时,可以用鼠标点击拖动组件,比如说文本框。
编写一个监听实现KeyListener,NouseListener,MouseMotionListener三个接口,重写方法。定义一个全局变量boolea
linux常用的命令
aichenglong
linux常用命令
1 startx切换到图形化界面
2 man命令:查看帮助信息
man 需要查看的命令,man命令提供了大量的帮助信息,一般可以分成4个部分
name:对命令的简单说明
synopsis:命令的使用格式说明
description:命令的详细说明信息
options:命令的各项说明
3 date:显示时间
语法:date [OPTION]... [+FORMAT]
eclipse内存优化
AILIKES
javaeclipsejvmjdk
一 基本说明 在JVM中,总体上分2块内存区,默认空余堆内存小于 40%时,JVM就会增大堆直到-Xmx的最大限制;空余堆内存大于70%时,JVM会减少堆直到-Xms的最小限制。 1)堆内存(Heap memory):堆是运行时数据区域,所有类实例和数组的内存均从此处分配,是Java代码可及的内存,是留给开发人
关键字的使用探讨
百合不是茶
关键字
//关键字的使用探讨/*访问关键词private 只能在本类中访问public 只能在本工程中访问protected 只能在包中和子类中访问默认的 只能在包中访问*//*final 类 方法 变量 final 类 不能被继承 final 方法 不能被子类覆盖,但可以继承 final 变量 只能有一次赋值,赋值后不能改变 final 不能用来修饰构造方法*///this()
JS中定义对象的几种方式
bijian1013
js
1. 基于已有对象扩充其对象和方法(只适合于临时的生成一个对象):
<html>
<head>
<title>基于已有对象扩充其对象和方法(只适合于临时的生成一个对象)</title>
</head>
<script>
var obj = new Object();
表驱动法实例
bijian1013
java表驱动法TDD
获得月的天数是典型的直接访问驱动表方式的实例,下面我们来展示一下:
MonthDaysTest.java
package com.study.test;
import org.junit.Assert;
import org.junit.Test;
import com.study.MonthDays;
public class MonthDaysTest {
@T
LInux启停重启常用服务器的脚本
bit1129
linux
启动,停止和重启常用服务器的Bash脚本,对于每个服务器,需要根据实际的安装路径做相应的修改
#! /bin/bash
Servers=(Apache2, Nginx, Resin, Tomcat, Couchbase, SVN, ActiveMQ, Mongo);
Ops=(Start, Stop, Restart);
currentDir=$(pwd);
echo
【HBase六】REST操作HBase
bit1129
hbase
HBase提供了REST风格的服务方便查看HBase集群的信息,以及执行增删改查操作
1. 启动和停止HBase REST 服务 1.1 启动REST服务
前台启动(默认端口号8080)
[hadoop@hadoop bin]$ ./hbase rest start
后台启动
hbase-daemon.sh start rest
启动时指定
大话zabbix 3.0设计假设
ronin47
What’s new in Zabbix 2.0?
去年开始使用Zabbix的时候,是1.8.X的版本,今年Zabbix已经跨入了2.0的时代。看了2.0的release notes,和performance相关的有下面几个:
:: Performance improvements::Trigger related da
http错误码大全
byalias
http协议javaweb
响应码由三位十进制数字组成,它们出现在由HTTP服务器发送的响应的第一行。
响应码分五种类型,由它们的第一位数字表示:
1)1xx:信息,请求收到,继续处理
2)2xx:成功,行为被成功地接受、理解和采纳
3)3xx:重定向,为了完成请求,必须进一步执行的动作
4)4xx:客户端错误,请求包含语法错误或者请求无法实现
5)5xx:服务器错误,服务器不能实现一种明显无效的请求
J2EE设计模式-Intercepting Filter
bylijinnan
java设计模式数据结构
Intercepting Filter类似于职责链模式
有两种实现
其中一种是Filter之间没有联系,全部Filter都存放在FilterChain中,由FilterChain来有序或无序地把把所有Filter调用一遍。没有用到链表这种数据结构。示例如下:
package com.ljn.filter.custom;
import java.util.ArrayList;
修改jboss端口
chicony
jboss
修改jboss端口
%JBOSS_HOME%\server\{服务实例名}\conf\bindingservice.beans\META-INF\bindings-jboss-beans.xml
中找到
<!-- The ports-default bindings are obtained by taking the base bindin
c++ 用类模版实现数组类
CrazyMizzz
C++
最近c++学到数组类,写了代码将他实现,基本具有vector类的功能
#include<iostream>
#include<string>
#include<cassert>
using namespace std;
template<class T>
class Array
{
public:
//构造函数
hadoop dfs.datanode.du.reserved 预留空间配置方法
daizj
hadoop预留空间
对于datanode配置预留空间的方法 为:在hdfs-site.xml添加如下配置
<property>
<name>dfs.datanode.du.reserved</name>
<value>10737418240</value>
 
mysql远程访问的设置
dcj3sjt126com
mysql防火墙
第一步: 激活网络设置 你需要编辑mysql配置文件my.cnf. 通常状况,my.cnf放置于在以下目录: /etc/mysql/my.cnf (Debian linux) /etc/my.cnf (Red Hat Linux/Fedora Linux) /var/db/mysql/my.cnf (FreeBSD) 然后用vi编辑my.cnf,修改内容从以下行: [mysqld] 你所需要: 1
ios 使用特定的popToViewController返回到相应的Controller
dcj3sjt126com
controller
1、取navigationCtroller中的Controllers
NSArray * ctrlArray = self.navigationController.viewControllers;
2、取出后,执行,
[self.navigationController popToViewController:[ctrlArray objectAtIndex:0] animated:YES
Linux正则表达式和通配符的区别
eksliang
正则表达式通配符和正则表达式的区别通配符
转载请出自出处:http://eksliang.iteye.com/blog/1976579
首先得明白二者是截然不同的
通配符只能用在shell命令中,用来处理字符串的的匹配。
判断一个命令是否为bash shell(linux 默认的shell)的内置命令
type -t commad
返回结果含义
file 表示为外部命令
alias 表示该
Ubuntu Mysql Install and CONF
gengzg
Install
http://www.navicat.com.cn/download/navicat-for-mysql
Step1: 下载Navicat ,网址:http://www.navicat.com/en/download/download.html
Step2:进入下载目录,解压压缩包:tar -zxvf navicat11_mysql_en.tar.gz
批处理,删除文件bat
huqiji
windowsdos
@echo off
::演示:删除指定路径下指定天数之前(以文件名中包含的日期字符串为准)的文件。
::如果演示结果无误,把del前面的echo去掉,即可实现真正删除。
::本例假设文件名中包含的日期字符串(比如:bak-2009-12-25.log)
rem 指定待删除文件的存放路径
set SrcDir=C:/Test/BatHome
rem 指定天数
set DaysAgo=1
跨浏览器兼容的HTML5视频音频播放器
天梯梦
html5
HTML5的video和audio标签是用来在网页中加入视频和音频的标签,在支持html5的浏览器中不需要预先加载Adobe Flash浏览器插件就能轻松快速的播放视频和音频文件。而html5media.js可以在不支持html5的浏览器上使video和audio标签生效。 How to enable <video> and <audio> tags in
Bundle自定义数据传递
hm4123660
androidSerializable自定义数据传递BundleParcelable
我们都知道Bundle可能过put****()方法添加各种基本类型的数据,Intent也可以通过putExtras(Bundle)将数据添加进去,然后通过startActivity()跳到下一下Activity的时候就把数据也传到下一个Activity了。如传递一个字符串到下一个Activity
把数据放到Intent
C#:异步编程和线程的使用(.NET 4.5 )
powertoolsteam
.net线程C#异步编程
异步编程和线程处理是并发或并行编程非常重要的功能特征。为了实现异步编程,可使用线程也可以不用。将异步与线程同时讲,将有助于我们更好的理解它们的特征。
本文中涉及关键知识点
1. 异步编程
2. 线程的使用
3. 基于任务的异步模式
4. 并行编程
5. 总结
异步编程
什么是异步操作?异步操作是指某些操作能够独立运行,不依赖主流程或主其他处理流程。通常情况下,C#程序
spark 查看 job history 日志
Stark_Summer
日志sparkhistoryjob
SPARK_HOME/conf 下:
spark-defaults.conf 增加如下内容
spark.eventLog.enabled true spark.eventLog.dir hdfs://master:8020/var/log/spark spark.eventLog.compress true
spark-env.sh 增加如下内容
export SP
SSH框架搭建
wangxiukai2015eye
springHibernatestruts
MyEclipse搭建SSH框架 Struts Spring Hibernate
1、new一个web project。
2、右键项目,为项目添加Struts支持。
选择Struts2 Core Libraries -<MyEclipes-Library>
点击Finish。src目录下多了struts