- Codeforces Round 1004(Div.2) B. Two Large Bags 补题 + 题解 python
查理零世
python算法
B.TwoLargeBagshttps://codeforces.com/contest/2067/problem/B题目描述timelimitpertest:1secondmemorylimitpertest:256megabytesYouhavetwolargebagsofnumbers.Initially,thefirstbagcontainsnnnnumbers:a1,a2,…,ana_1
- Remove Exactly Two ( [Codeforces Round 1000 (Div. 2)](httpsmirror.codeforces.comcontest2063) )
BoBoo文睡不醒
acm训练集合搜索dfs数据结构
RemoveExactlyTwo(CodeforcesRound1000(Div.2))Recently,LittleJohngotatreefromhisaunttodecoratehishouse.Butasitseems,justonetreeisnotenoughtodecoratetheentirehouse.LittleJohnhasanidea.Maybehecanremoveafe
- Codeforces Round 977 (Div. 2)E1 Digital Village (Easy Version)(Floyd,贪心)
Auto114514
Codeforces算法c++数据结构图论
题目链接CodeforcesRound977(Div.2)E1DigitalVillage(EasyVersion)思路首先,我们注意到nnn的最大值只有400400400。因此,我们可以先用FloydFloydFloyd算法预处理出任意两座城市之间的最大延迟时间。之后,我们通过在线操作,每次贪心地选出最优的一个城市,并不断更新答案。即,我们先选出k=1k=1k=1时的最优解,之后从剩下的点里面挑
- CF Round 1004 记录 & 题解(div.1 A - D1 & div.2 D - F)
JeremyHe1209
算法
今天上午VPCodeforcesRound1004(Div.2),下午改CodeforcesRound1004(Div.1)。上午C题因为少判了一个条件,罚时吃饱了。[Codeforces2066A&2067D]ObjectIdentification神奇交互题。观察到一个性质:对象AAA的答案可能是000,但对象BBB的答案不可能是000。若x1,x2,…,xnx_1,x_2,\dots,x_n
- SMU winter 2025 Personal Round 2
osir.
枚举
Problem-D-Codeforces思路://在给定数中取x,y,z使得(x-y)^2+(y-z)^2+(z-x)^2最值.//容易发现是找最接近的三个数字,但是怎么找呢//经验总结(没想到是枚举中间那个),其中一个数字是枚举的(总是枚举中间那个,对于这个题中间那个就是中间大那个).剩下两个数字呢?--可以二分//假设xusingnamespacestd;#defineintlonglong#
- Codeforces Educational Codeforces Round 170 (Rated for Div. 2)
关于SPFA它死了
Codeforces算法c++
A-TwoScreens大意:给两个字符串,每次在两个空子符串进行两种操作1、字符串末尾加一个任意字母2、一个字符串全部复制给另一个字符串求得到给定的两个字符串的最小操作数思路:看最前面有多少相等即可当时想多了。。。代码:#includeusingnamespacestd;#defineintlonglongconstintN=2e5+10,INF=0x3f3f3f3f;constintmod=1
- [CodeForces]8
天之道,利而不害
codeforce
G.MaximizetheRemainingString由小写字母组成的字符串sss,每次从中选取重复的字母进行删除,直到该字符串中的每个字母都只出现一次。问:最终形成的字典序最大的字符串,比如ababababababababab,答案为bababa。1≤len(s)≤2000001\leqlen(s)\leq2000001≤len(s)≤200000题解记s=a1a2a3⋯ans=a_1a_2a
- C - Nastya Is Transposing Matrices CodeForces - 1136C
Gee_Zer
思维
C.NastyaIsTransposingMatricestimelimitpertest1secondmemorylimitpertest256megabytesinputstandardinputoutputstandardoutputNastyacametoherinformaticslesson,andherteacherwhois,bytheway,alittlebitfamousher
- An impassioned circulation of affection ( Codeforces Round 418 (Div. 2) )
BoBoo文睡不醒
acm训练集合暴力枚举dp双指针
Animpassionedcirculationofaffection(CodeforcesRound418(Div.2))Nadeko’sbirthdayisapproaching!Asshedecoratedtheroomfortheparty,alonggarlandofDianthus-shapedpaperpieceswasplacedonaprominentpartofthewall.
- Codeforces Round 988 (Div. 3)
BoBoo文睡不醒
codeforces笔记
CodeforcesRound988(Div.3)C.Superultra’sFavoritePermutationtimelimitpertest2secondsmemorylimitpertest256megabytesSuperultra,alittleredpanda,desperatelywantsprimogems.Inhisdreams,avoicetellshimthathe
- Nastya Is Transposing Matrices ( Codeforces Round 546 (Div. 2) )
BoBoo文睡不醒
acm训练集合构造
NastyaIsTransposingMatrices(CodeforcesRound546(Div.2))Nastyacametoherinformaticslesson,andherteacherwhois,bytheway,alittlebitfamousheregaveherthefollowingtask.TwomatricesAAAandBBBaregiven,eachofthemha
- Not Escaping ( Codeforces Round 766 (Div. 2) )
BoBoo文睡不醒
acm训练集合dp数据结构模拟最短路
NotEscaping(CodeforcesRound766(Div.2))MajorRamisbeingchasedbyhisarchenemyRaghav.Rammustreachthetopofthebuildingtoescapeviahelicopter.Thebuilding,however,isonfire.Rammustchoosetheoptimalpathtoreachthet
- 【codeforces 764B】Timofey and cubes
adgnfega11455
数据结构与算法
timelimitpertest1secondmemorylimitpertest256megabytesinputstandardinputoutputstandardoutputYoungTimofeyhasabirthdaytoday!Hegotkitofncubesasabirthdaypresentfromhisparents.Everycubehasanumberai,whichisw
- Codeforces Round 130 (Div. 2) E. Blood Cousins(LCA+DFS序+二分)【2100】
Auto114514
ACM—树深度优先算法图论
题目链接https://codeforces.com/contest/208/problem/E思路此题有两个要点:第一,快速找到节点uuu的ppp级祖先。第二,在以节点uuu为根的子树中找到与节点uuu深度相同的节点的个数。对于第一点,我们可以使用LCA算法在树上倍增,实现快速查询。对于第二点,我们可以按照深度,将所有节点的DFS序全部存储到vector中,因为DFS序的单调性,直接二分查找即可
- Codeforces Round 276 (Div. 1) B. Maximum Value(数学+二分)【2100】
Auto114514
ACM—数学算法
题目链接https://codeforces.com/contest/484/problem/B思路a mod ba\,mod\,bamodb可以转化成a−k×ba-k\timesba−k×b,其中k=⌊ab⌋k=\left\lfloor\frac{a}{b}\right\rfloork=⌊ba⌋。我们发现k×busingnamespacestd;#defineintlonglong#define
- Codeforces Round 642 (Div. 3) E. K-periodic Garland(DP+前缀和)
Auto114514
ACM—DP动态规划算法
题目链接https://codeforces.com/contest/1353/problem/E思路令dp[i][0/1]dp[i][0/1]dp[i][0/1]分别表示第iii个字符是000或者111时的前iii个字符组成的花环所需的最少操作次数。如果第iii个字符变为111,分为两种情况:第一种情况是第i−ki-ki−k个字符必须为111,且[i−k+1,i−1][i-k+1,i-1][i−
- Codeforces Round 974 (Div. 3) H题 Robin Hood Archery(基础莫队,随机异或哈希)
Auto114514
Codeforces哈希算法散列表算法c++数据结构
题目链接CodeforcesRound974(Div.3)H题RobinHoodArchery思路1因为警长是后手,按照最优的策略,只有每一种数的个数是偶数个的时候,警长会平局,否则警长会输。随着询问区间端点的变化,答案的转移是O(1)O(1)O(1)的。因此,我们可以使用基础莫队进行离线求解。代码1#pragmaGCCoptimize("O2")#pragmaGCCoptimize("O3")#
- F. Greetings
L_M_TY
算法归并排序求逆序对
题目链接:Problem-F-Codeforces题目大意:给你n个线段,求有多少对(两个)线段满足完全覆盖,例如:设一个线段有a,b两点,满足aiusingnamespacestd;usingi64=longlong;usingi128=__int128;//求逆序对i64msort(vector&a,vector&b,intL,intR){if(L==R)return0;i64res=0;in
- Epidemic in Monstropolis( Codeforces Round 378 (Div. 2) )
BoBoo文睡不醒
acm训练集合模拟双指针贪心
EpidemicinMonstropolis(CodeforcesRound378(Div.2))TherewasanepidemicinMonstropolisandallmonstersbecamesick.Torecover,allmonsterslinedupinqueueforanappointmenttotheonlydoctorinthecity.Soon,monstersbecam
- F. Ira and Flamenco
L_M_TY
算法滑动窗口乘法原理乘法逆元
题目链接:Problem-F-Codeforces题目大意:给n,mn个数让从中选m个数满足一下条件:1.m个数互不相同2.里面的任意两个数相减的绝对值不能超过m求这n个数有多少组数据满足。第一行包含一个整数t(1≤t≤1e4)-测试用例数。每个测试用例的第一行包含整数n和m(1≤m≤n≤2⋅1e5)每个测试用例的第二行包含n个整数a1,a2,…,an(1≤ai≤1e9)。保证所有测试用例的n之和
- 【题解】Codeforces Round 996 C.The Trail D.Scarecrow
所以遗憾是什么呢?
算法数据结构贪心算法
CodeforcesRound996比赛地址:https://codeforces.com/contest/2055ProblemC.TheTrail1.从数学上看,未知的数有n+m-1个位置的a[i]值,和行列总和x,解出他们需要n+m个独立的方程。对每一个未知的位置,有行和等于列和的方程,共n+m-1个,还有一个行和/列和=x的方程,恰好可解。所以只需要找到一种易于用代码表达的解方程方法即可。
- D. Unique Median【Codeforces Round 997 (Div. 2)】
Flower#
题解/补题c++算法
D.UniqueMedian思路:长度为奇数的一定是好数组,很容易相当找长度为偶数中的好数组数量,但是过于复杂。正向解决困难的情况下可以尝试反向思考,即找长度为偶数的非好数组数量,总答案就等于n*(n+1)/2-非好数组数量。每次枚举一个iii作为较大的那个中位数,那么这个数组不好的条件为大于等于i的数的数量等于小于i的数的数量。如果将数组a中大于等于i的数记为1,小于i的数记为-1,得到一个新的
- Codeforces Round 925 (Div. 3)
louisdlee.
AtCoderCF题解算法
CodeforcesRound925(Div.3)文章目录CodeforcesRound925(Div.3)A.RecoveringaSmallStringB.MakeEqualC.MakeEqualAgainD.DivisiblePairsE.AnnaandtheValentine'sDayGiftA.RecoveringaSmallString暴搜一共就三个字母,我们只要每次从第一个字母开始,
- CodeForces 1622F Quadratic Set(结论+异或哈希+散列表)
ikrvxt
结论和构造哈希算法散列表算法
problem洛谷链接solution最后子集大小一定≥n−3\gen-3≥n−3,下面考虑证明这个结论。假设n=2kn=2kn=2k。∏i=1n(i!)=∏i=1k(2i−1)!(2i)!=∏i=1k(((2i−1)!)22i)=∏i=1k((2i−1)!)2⋅∏i=1k2i=∏i=1k((2i−1)!)2⋅2k⋅k!\prod_{i=1}^n(i!)=\prod_{i=1}^{k}(2i-1)
- Tree Queries( Codeforces Round 629 (Div. 3) )
BoBoo文睡不醒
acm训练集合笔记
TreeQueries(CodeforcesRound629(Div.3))Youaregivenarootedtreeconsistingofnnnverticesnumberedfrom111tonnn.Therootofthetreeisavertexnumber111.Atreeisaconnectedundirectedgraphwithn−1n-1n−1edges.Youaregive
- leetcode 3095. 或值至少 K 的最短子数组 I
fks143
leetcodeleetcode
题目:3095.或值至少K的最短子数组I-力扣(LeetCode)加班用手机刷水题classSolution{public:intminimumSubarrayLength(vector&nums,intk){intn=nums.size();intm,l,ret=n+10;for(inti=0;i=k){if(ln){return-1;}returnret;}};
- F. Gardening Friends
L_M_TY
算法数据结构
题目链接:Problem-F-Codeforces题目大意:给一颗n结点的树,起初根结点为1,树的成本定义为树上所有顶点中从根到顶点的最大距离,现在你可以有一种操作,将根结点转移到相邻的结点,但会有操作成本成本的消耗。现将求最大利润(因为他要卖)。利润==树的成本-操作的总成本。输入的第一行包含一个整数t(1≤t≤1e4)-测试用例数。测试用例说明如下。每个测试用例的第一行都包含一个整数n、k、c
- Codeforces Round 1000 (Div. 2)-C题(树上两个节点不同边数最大值)
Colinnian
算法
https://codeforces.com/contest/2063/problem/C牢记一棵树上两个节点如果相邻,它们有一条边会重叠,两个节点延伸出去的所有不同边是两个节点入度之和-1而不是入度之和,那么如果这棵树上有三个节点它们的入度都相同,那么优先选择非相邻的两个节点才能使所有不同边的数量最大!!然后思路就是:暴力templatestructSegmentTree{intn;std::v
- 周报(2025.1.20 ~ 2025.1.26)
@Happiness.
cocoamacosobjective-c
一、CodeforcesRound998(Div.3)E题用到并查集并查集模板#includeusingnamespacestd;#definelllonglong#definePIIpair#defineendl'\n'structDSU{vectorf,siz;DSU(){}DSU(lln){init(n);}voidinit(lln){f.resize(n);iota(f.begin(),f
- 题解 CodeForces 131D Subway BFS C++
qwq_ovo_pwp
c++广度优先算法
题目传送门Problem-131D-Codeforceshttps://codeforces.com/problemset/problem/131/Dhttps://codeforces.com/problemset/problem/131/Dhttps://codeforces.com/problemset/problem/131/D翻译地铁方案,对于Berland城市来说是一种经典的表示,由一
- 对于规范和实现,你会混淆吗?
yangshangchuan
HotSpot
昨晚和朋友聊天,喝了点咖啡,由于我经常喝茶,很长时间没喝咖啡了,所以失眠了,于是起床读JVM规范,读完后在朋友圈发了一条信息:
JVM Run-Time Data Areas:The Java Virtual Machine defines various run-time data areas that are used during execution of a program. So
- android 网络
百合不是茶
网络
android的网络编程和java的一样没什么好分析的都是一些死的照着写就可以了,所以记录下来 方便查找 , 服务器使用的是TomCat
服务器代码; servlet的使用需要在xml中注册
package servlet;
import java.io.IOException;
import java.util.Arr
- [读书笔记]读法拉第传
comsci
读书笔记
1831年的时候,一年可以赚到1000英镑的人..应该很少的...
要成为一个科学家,没有足够的资金支持,很多实验都无法完成
但是当钱赚够了以后....就不能够一直在商业和市场中徘徊......
- 随机数的产生
沐刃青蛟
随机数
c++中阐述随机数的方法有两种:
一是产生假随机数(不管操作多少次,所产生的数都不会改变)
这类随机数是使用了默认的种子值产生的,所以每次都是一样的。
//默认种子
for (int i = 0; i < 5; i++)
{
cout<<
- PHP检测函数所在的文件名
IT独行者
PHP函数
很简单的功能,用到PHP中的反射机制,具体使用的是ReflectionFunction类,可以获取指定函数所在PHP脚本中的具体位置。 创建引用脚本。
代码:
[php]
view plain
copy
// Filename: functions.php
<?php&nbs
- 银行各系统功能简介
文强chu
金融
银行各系统功能简介 业务系统 核心业务系统 业务功能包括:总账管理、卡系统管理、客户信息管理、额度控管、存款、贷款、资金业务、国际结算、支付结算、对外接口等 清分清算系统 以清算日期为准,将账务类交易、非账务类交易的手续费、代理费、网络服务费等相关费用,按费用类型计算应收、应付金额,经过清算人员确认后上送核心系统完成结算的过程 国际结算系
- Python学习1(pip django 安装以及第一个project)
小桔子
pythondjangopip
最近开始学习python,要安装个pip的工具。听说这个工具很强大,安装了它,在安装第三方工具的话so easy!然后也下载了,按照别人给的教程开始安装,奶奶的怎么也安装不上!
第一步:官方下载pip-1.5.6.tar.gz, https://pypi.python.org/pypi/pip easy!
第二部:解压这个压缩文件,会看到一个setup.p
- php 数组
aichenglong
PHP排序数组循环多维数组
1 php中的创建数组
$product = array('tires','oil','spark');//array()实际上是语言结构而不 是函数
2 如果需要创建一个升序的排列的数字保存在一个数组中,可以使用range()函数来自动创建数组
$numbers=range(1,10)//1 2 3 4 5 6 7 8 9 10
$numbers=range(1,10,
- 安装python2.7
AILIKES
python
安装python2.7
1、下载可从 http://www.python.org/进行下载#wget https://www.python.org/ftp/python/2.7.10/Python-2.7.10.tgz
2、复制解压
#mkdir -p /opt/usr/python
#cp /opt/soft/Python-2
- java异常的处理探讨
百合不是茶
JAVA异常
//java异常
/*
1,了解java 中的异常处理机制,有三种操作
a,声明异常
b,抛出异常
c,捕获异常
2,学会使用try-catch-finally来处理异常
3,学会如何声明异常和抛出异常
4,学会创建自己的异常
*/
//2,学会使用try-catch-finally来处理异常
- getElementsByName实例
bijian1013
element
实例1:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/x
- 探索JUnit4扩展:Runner
bijian1013
java单元测试JUnit
参加敏捷培训时,教练提到Junit4的Runner和Rule,于是特上网查一下,发现很多都讲的太理论,或者是举的例子实在是太牵强。多搜索了几下,搜索到两篇我觉得写的非常好的文章。
文章地址:http://www.blogjava.net/jiangshachina/archive/20
- [MongoDB学习笔记二]MongoDB副本集
bit1129
mongodb
1. 副本集的特性
1)一台主服务器(Primary),多台从服务器(Secondary)
2)Primary挂了之后,从服务器自动完成从它们之中选举一台服务器作为主服务器,继续工作,这就解决了单点故障,因此,在这种情况下,MongoDB集群能够继续工作
3)挂了的主服务器恢复到集群中只能以Secondary服务器的角色加入进来
2
- 【Spark八十一】Hive in the spark assembly
bit1129
assembly
Spark SQL supports most commonly used features of HiveQL. However, different HiveQL statements are executed in different manners:
1. DDL statements (e.g. CREATE TABLE, DROP TABLE, etc.)
- Nginx问题定位之监控进程异常退出
ronin47
nginx在运行过程中是否稳定,是否有异常退出过?这里总结几项平时会用到的小技巧。
1. 在error.log中查看是否有signal项,如果有,看看signal是多少。
比如,这是一个异常退出的情况:
$grep signal error.log
2012/12/24 16:39:56 [alert] 13661#0: worker process 13666 exited on s
- No grammar constraints (DTD or XML schema).....两种解决方法
byalias
xml
方法一:常用方法 关闭XML验证
工具栏:windows => preferences => xml => xml files => validation => Indicate when no grammar is specified:选择Ignore即可。
方法二:(个人推荐)
添加 内容如下
<?xml version=
- Netty源码学习-DefaultChannelPipeline
bylijinnan
netty
package com.ljn.channel;
/**
* ChannelPipeline采用的是Intercepting Filter 模式
* 但由于用到两个双向链表和内部类,这个模式看起来不是那么明显,需要仔细查看调用过程才发现
*
* 下面对ChannelPipeline作一个模拟,只模拟关键代码:
*/
public class Pipeline {
- MYSQL数据库常用备份及恢复语句
chicony
mysql
备份MySQL数据库的命令,可以加选不同的参数选项来实现不同格式的要求。
mysqldump -h主机 -u用户名 -p密码 数据库名 > 文件
备份MySQL数据库为带删除表的格式,能够让该备份覆盖已有数据库而不需要手动删除原有数据库。
mysqldump -–add-drop-table -uusername -ppassword databasename > ba
- 小白谈谈云计算--基于Google三大论文
CrazyMizzz
Google云计算GFS
之前在没有接触到云计算之前,只是对云计算有一点点模糊的概念,觉得这是一个很高大上的东西,似乎离我们大一的还很远。后来有机会上了一节云计算的普及课程吧,并且在之前的一周里拜读了谷歌三大论文。不敢说理解,至少囫囵吞枣啃下了一大堆看不明白的理论。现在就简单聊聊我对于云计算的了解。
我先说说GFS
&n
- hadoop 平衡空间设置方法
daizj
hadoopbalancer
在hdfs-site.xml中增加设置balance的带宽,默认只有1M:
<property>
<name>dfs.balance.bandwidthPerSec</name>
<value>10485760</value>
<description&g
- Eclipse程序员要掌握的常用快捷键
dcj3sjt126com
编程
判断一个人的编程水平,就看他用键盘多,还是鼠标多。用键盘一是为了输入代码(当然了,也包括注释),再有就是熟练使用快捷键。 曾有人在豆瓣评
《卓有成效的程序员》:“人有多大懒,才有多大闲”。之前我整理了一个
程序员图书列表,目的也就是通过读书,让程序员变懒。 程序员作为特殊的群体,有的人可以这么懒,懒到事情都交给机器去做,而有的人又可以那么勤奋,每天都孜孜不倦得
- Android学习之路
dcj3sjt126com
Android学习
转自:http://blog.csdn.net/ryantang03/article/details/6901459
以前有J2EE基础,接触JAVA也有两三年的时间了,上手Android并不困难,思维上稍微转变一下就可以很快适应。以前做的都是WEB项目,现今体验移动终端项目,让我越来越觉得移动互联网应用是未来的主宰。
下面说说我学习Android的感受,我学Android首先是看MARS的视
- java 遍历Map的四种方法
eksliang
javaHashMapjava 遍历Map的四种方法
转载请出自出处:
http://eksliang.iteye.com/blog/2059996
package com.ickes;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;
/**
* 遍历Map的四种方式
- 【精典】数据库相关相关
gengzg
数据库
package C3P0;
import java.sql.Connection;
import java.sql.SQLException;
import java.beans.PropertyVetoException;
import com.mchange.v2.c3p0.ComboPooledDataSource;
public class DBPool{
- 自动补全
huyana_town
自动补全
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml&quo
- jquery在线预览PDF文件,打开PDF文件
天梯梦
jquery
最主要的是使用到了一个jquery的插件jquery.media.js,使用这个插件就很容易实现了。
核心代码
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.
- ViewPager刷新单个页面的方法
lovelease
androidviewpagertag刷新
使用ViewPager做滑动切换图片的效果时,如果图片是从网络下载的,那么再子线程中下载完图片时我们会使用handler通知UI线程,然后UI线程就可以调用mViewPager.getAdapter().notifyDataSetChanged()进行页面的刷新,但是viewpager不同于listview,你会发现单纯的调用notifyDataSetChanged()并不能刷新页面
- 利用按位取反(~)从复合枚举值里清除枚举值
草料场
enum
以 C# 中的 System.Drawing.FontStyle 为例。
如果需要同时有多种效果,
如:“粗体”和“下划线”的效果,可以用按位或(|)
FontStyle style = FontStyle.Bold | FontStyle.Underline;
如果需要去除 style 里的某一种效果,
- Linux系统新手学习的11点建议
刘星宇
编程工作linux脚本
随着Linux应用的扩展许多朋友开始接触Linux,根据学习Windwos的经验往往有一些茫然的感觉:不知从何处开始学起。这里介绍学习Linux的一些建议。
一、从基础开始:常常有些朋友在Linux论坛问一些问题,不过,其中大多数的问题都是很基础的。例如:为什么我使用一个命令的时候,系统告诉我找不到该目录,我要如何限制使用者的权限等问题,这些问题其实都不是很难的,只要了解了 Linu
- hibernate dao层应用之HibernateDaoSupport二次封装
wangzhezichuan
DAOHibernate
/**
* <p>方法描述:sql语句查询 返回List<Class> </p>
* <p>方法备注: Class 只能是自定义类 </p>
* @param calzz
* @param sql
* @return
* <p>创建人:王川</p>
* <p>创建时间:Jul