- 【加密社】深入理解TON智能合约 (FunC语法)
加密社
闲侃Nethereum教程区块链智能合约
king:摘要:在TON(TheOpenNetwork)区块链平台中,智能合约扮演着举足轻重的角色。本文将通过分析一段TON智能合约代码带领读者学习dict(字典)和list(列表)在FunC语言中的用法,以及如何在实际场景中实现高效的验证者选举。一、引言TON区块链平台的智能合约采用FunC语法一、引言TON区块链平台的智能合约采用FunC语言编写,该语言提供了丰富的数据结构,如dict和lis
- ssm——整合,前端页面设计,分页
2401_86367399
面试辅导大厂内推前端java开发语言
empMapper.updateEmpById(m);}//用于批量的插入数据@TestpublicvoidinsertDeptByBATCH(){DeptMapperOCM=sqlSession.getMapper(DeptMapper.class);for(inti=0;iindex.jsp页面发送出查询信息列表的请求->EmpController来接受请求,然后查询出员工数据->跳转到lis
- 蒙特卡罗——三门问题python代码实现
潮汐退涨月冷风霜
python开发语言蒙特卡罗
三门问题b站李永乐老师讲解三门问题python蒙特卡罗模拟#模拟三门问题importrandomasrd#n:模拟次数,m:中奖次数n=100000m=0foriinrange(n):#车位于的门号car=rd.randint(0,2)#人随机选择一个门door=rd.randint(0,2)#主持人展示空门empties={0,1,2}-{car,door}empty=rd.choice(lis
- 23. 如何使用Collections.synchronizedList()方法来创建线程安全的集合?有哪些注意事项?
这孩子叫逆
面试题java集合java
Collections.synchronizedList()方法用于将一个普通的List包装成线程安全的List。通过这个方法生成的List,所有的访问和修改操作都会被自动加锁,从而确保在多线程环境下对集合的并发访问是安全的。如何使用Collections.synchronizedList()创建线程安全的集合以下是使用Collections.synchronizedList()创建线程安全Lis
- Python 递归迭代器实现全排列算法
JHC000000
pythonjava前端
defpermutations(lis,ind=0):#保存原始列表old_lis=copy.deepcopy(lis)ifind==len(lis):yieldold_lisforiinrange(ind,len(lis)):#交换lis[ind],lis[i]=lis[i],lis[ind]yieldfrompermutations(lis,ind+1)#恢复原来的列表lis=old_lisl
- Springboot医院信息管理系统源码 带电子病历和LIS Saas应用+前后端分离+B/S架构
源码技术栈
云HIS系统源码springboot后端云HIS医院信息管理HIS系统区域his源代码
目录系统特点技术架构系统功能1、标准数据维护2、收费(门诊/住院)系统3、药剂管理系统4、医生工作站系统5、护士工作站系统6、电子病历系统系统优点云HIS系统简介云HIS系统功能模块门急诊挂号管理门诊收费管理门诊医生工作站药房管理系统药库管理系统住院管理系统住院医生工作站住院护士工作站系统解决方案云HIS系统是一款满足基层医院各类业务需要的健康云产品。该产品能帮助基层医院完成日常各类业务,提供病患
- 备战蓝桥杯 Day7(序列dp)
了一li
insist蓝桥杯算法图论
基本分类(1)单序列a.最大子段和b.最长上升子序列LIS(2)多序列a.最长公共子序列b.编辑距离最大子段和单序列dp一般开一维数组最大子段和-洛谷https://www.luogu.com.cn/problem/P1115分析:写出状态和状态转移方程:状态dp[i]--以第i个元素作为结尾的最大子段和状态转移方程--dp[i]=max(dp[i-1]+a[i],a[i])a[]1234567(
- 数据代理 、 模板解析、 数据绑定
BJ000
7.1.说明1)分析vue作为一个MVVM框架的基本实现原理数据代理模板解析数据绑定2)不直接看vue.js的源码3)剖析github上某基友仿vue实现的mvvm库4)地址:https://github.com/DMQ/mvvm7.2.准备知识1)[].slice.call(lis):将伪数组转换为真数组2)node.nodeType:得到节点类型3)Object.defineProperty(
- 可变参数(c/c++)
薄荷冰ovo
c/c++知识点c语言c++开发语言
目录一、C语言版本二、C++的实现方法2.1数据包2.2sizeof...运算符2.3可变参数模板的使用2.4emplace_back()有时候我们在编写函数时,可能不知道要传入的参数个数,类型。比如我们要实现一个叠加函数,再比如c语言中的printf,c++中的emplace_last()。那么这些函数是如何实现的呢?一、C语言版本在C中,可变参数通过头文件中的宏来处理。最常用的宏是va_lis
- 【算法题】102. 二叉树的层序遍历
YifengGuo233
LeetCode练习手册算法数据结构
题目给你二叉树的根节点root,返回其节点值的层序遍历。(即逐层地,从左到右访问所有节点)。示例1:输入:root=[3,9,20,null,null,15,7]输出:[[3],[9,20],[15,7]]示例2:输入:root=[1]输出:[[1]]示例3:输入:root=[]输出:[]提示:树中节点数目在范围[0,2000]内-1000>levelOrder(TreeNoderoot){Lis
- 1.蓝桥勇士
爱跑步的程序员~
算法模板蓝桥云课动态规划
Problem:蓝桥勇士文章目录思路解题方法复杂度Code思路这是一个典型的动态规划问题,我们可以使用最长递增子序列(LIS)的思想来解决。我们可以定义一个数组dp,其中dp[i]表示以第i个对手结束的最长挑战序列的长度。对于每一个对手,我们都尝试将其加入到所有在其之前的对手所能形成的挑战序列中,如果当前对手的战力值大于前面对手的战力值,那么就可以将其加入到挑战序列中,更新dp[i]的值。最后,我
- 从一道板子题了解LIS(最长上升子序列)
Cx_330_PLT
算法
在理解LIS之前,需要理解什么是子序列,子序列指的是一个序列中,按照原顺序选出若干个不一定连续的元素所组成的序列,在求解LIS时,一般我们会设dp[i]表示1~i序列中以a[i]结尾的最长上升子序列的长度,状态转移方程为:dp[i]=max(dp[j]+1),ifa[i]>a[j]//表示a[i]要插入到不同子序列后面的情况LIS的简单模板为:for(inti=1;ia[j])dp[i]=max(
- 最长公共子序列
北渡dull
算法c++动态规划c语言
最长公共子序列,英文缩写为LCS(LongestCommonSubsequence)。其定义是,一个序列S,如果分别是两个或多个已知序列的子序列,且是所有符合此条件序列中最长的,则S称为已知序列的最长公共子序列。子串、子序列还有公共子序列的概念(在上篇LIS中也曾涉及过),我们以字符子串和字符子序列为例,更为形象,也能顺带着理解字符的子串和子序列:(1)字符子串:指的是字符串中连续的n个字符,如a
- BZOJ5442 [Ceoi2018]Global warming
yjjr
DP数据结构bzojOI成长历程
标签:LIS,DP,树状数组题目题目传送门Description给定n(n≤200,000)n(n\leq200,000)n(n≤200,000),你可以将任意a[l]a[l]a[l]至a[r](1≤l≤r≤n)a[r](1\leql\leqr\leqn)a[r](1≤l≤r≤n)每一个元素加上一个d(−x≤d≤x)d(-x\leqd\leqx)d(−x≤d≤x),求aaa数组的最大严格上升子序列
- 算法笔记------DP
_AC繁星S_
算法笔记算法
基础DP最大字段和:转移方程:f[i]=max(a[i],f[i-1]+a[i])对于要求字段起止位置的for(inti=1;i=0){f[i]=f[i-1]+a[i];}else{f[i]=a[i];ti=i;}if(f[i]>ans){ans=f[i];start=ti;ed=i;}}LIS模型暴力动态规划只采用最朴素的动态规划,复杂度O(N2)O(N^2)O(N2)for(inti=1;i#
- 【20211214】【Python】查找数组中最值元素、中值元素及其索引
Satisfying
Pythonpython算法开发语言
一、最大值1.最大值元素np.max(lis)2.最大值索引np.argmax(lis)或np.where(lis==np.max(lis))二、最小值1.最小值元素np.min(lis)2.最小值索引np.argmin(lis)或np.where(lis==np.min(lis))三、中值1.中值元素np.median(lis)2.中值索引Python没有直接argmedian的命令,但可以使用
- 标签获取元素和循环
卑微小利
window.onload=function(){varlis=document.getElementsByTagName('li');lis[0].style.backgroundColor='gold';lis[1].style.backgroundColor='gold';}document.getElementsByTagName();标签获取元素循环1.for循环window.onloa
- Python数据容器(上)——list(列表)
Feelings◎
python开发语言
一、什么是数据容器1、定义:一种可以存储多个元素的Python数据类型2、Python中有哪些数据类型:list(列表)、tuple(元组)、str(字符串)、set(集合)、dict(字典)二、数据容器:list(列表)1、列表的定义基本语法:#字面量[元素1,元素2,元素3,元素4,...]#定义变量变量名称=[元素1,元素2,元素3,元素4,...]#定义空列表变量名称=[]变量名称=lis
- List集合去重的常见及常用的四种方式
易寻资料
工具类javaandroid
List集合去重的常见及常用的四种方式01实现思路:使用两个for循环遍历集合所有元素,然后进行判断是否有相同元素,如果有,则去除。这种方式是大部分最先想到的,也是最简单的实现方式。其中,这种方式可以保证List集合原来的顺序不变。/***notes:使用两个for循环实现List去重*@paramlist*@return*/publicstaticListrepeatListWayOne(Lis
- 原来ES7~12分别增加了这些属性呀
一颗冰淇淋
ES6也称为ES2015,于2015年发布,此后每年都有新增一些属性,分别命名为ES7~12,发布的年份分别对应2016年到2021年ES7includes方法数组中新增了includes方法,用来判断数组中是否存在某一元素,在此之前进行这样的判断是使用indexOf判断下标值,小于0时则代表不存在。constlist=['alice','kiki','macus']console.log(lis
- 【C语言 - 哈希表 - 力扣 - 相交链表】
六月悉茗
C语言学习报告c语言散列表leetcode
相交链表题目描述给你两个单链表的头节点headA和headB,请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点,返回null。图示两个链表在节点c1开始相交:题目数据保证整个链式结构中不存在环。注意,函数返回结果后,链表必须保持其原始结构。自定义评测:评测系统的输入如下(你设计的程序不适用此输入):intersectVal-相交的起始节点的值。如果不存在相交节点,这一值为0lis
- python 动态数据 展示 ,数据是由51单片机发送过来的,温度传感器。
laocooon523857886
python开发语言
importtkinterastkimportrandomimportseriallis=[]foriinrange(50):lis.append(i+1)#打开串行端口ser=serial.Serial('COM3',9600)#9600为波特率,根据实际情况进行调整#初始化数据lis=[random.randint(15,35)for_inrange(50)]defupdate_data():
- 仪器接口设计
小乌鱼
java数据库开发语言
不是所有设备都是TCP连接模式,有读文件的、读数据库的设备,为此还需要一个客户端仪器接口程序,面向接口编程是一个良好的思想,他使得调用者和接口实现者不用绑定太死,只要双方按约定实现即可。仪器有读文件的、写文件的、读数据库的、写数据库的、定时取图的等,从PDF提取数据的、从Excel提取数据、读csv等。虽然很繁杂,但是对业务解析大家是固定的,都是要解析数据行,再把数据存入LIS。所以可以抽取接口,
- 双非本科准备秋招(17.1)—— 力扣二叉树
随心自风流
leetcode数据结构算法java秋招求职招聘
1、257.二叉树的所有路径要求返回根节点到叶子节点的所有路径,这里用前序遍历就好。每次递归前,都让字符串s加上当前节点的值和“->”,然后判断是否为叶子节点,如果是的话,说明这条路径是一个答案,因为最后多一个->,所以用substring去掉。如果root是null,那么root.left和root.right可能会空指针异常。所以每次递归的时候都要做一下判断。classSolution{Lis
- Python数据结构与算法:列表转链表
吮指原味张
#python链表数据结构python
参考:Python:listtolinklist.列表转链表代码可视化工具1.代码classListNode:def__init__(self,val=0,next=None):self.val=valself.next=nextdeflist2link(list_):head=ListNode(list_[0])p=headforiinrange(1,len(list_)):p.next=Lis
- QML用ListView实现带section的GridView
龚建波
QML三言两语QMLGridView
QML自带的GridView只能定义delegate,没有section,类似手机相册带时间分组标签的样式就没法做。最简单的方式就是组合ListView+GridView,或者ListView+Flow,但是嵌套View时,子级View一般是完全展开的,只显示该分组几行就得把该分组全部加载了,这样就没有了View在需要时才实例化Item的优势,所以最好还是在单层View实现最终效果。QML的Lis
- Day4 链表专项 — 交换、双指针、交点、环
DuanDuan0820
算法学习算法c++链表
LeetCode24.两两交换链表中的节点解题思路:明确交换步骤,记录必要的临时节点ListNode*swapPairs(ListNode*head){ListNode*dummy_head=newListNode(0);dummy_head->next=head;ListNode*cur=dummy_head;while(cur->next&&cur->next->next){//临时记录Lis
- LeetCode 109. 有序链表转换二叉搜索树 题解+测试 C/C++
【止心】
LeetCode链表二叉搜索树中位数c++算法
主要思路构造平衡的二叉搜索树:首先使用快慢指针法找到中位数,作为根节点,然后递归构造左子树与右子树#include#includeusingnamespacestd;#includestructListNode{intval;ListNode*next;ListNode():val(0),next(nullptr){}ListNode(intx):val(x),next(nullptr){}Lis
- Go语言每日一练——链表篇(四)
落雨便归尘
Go语言每日一题golang链表开发语言数据结构算法
传送门牛客面试笔试必刷101题----------------合并两个排序的链表题目以及解析题目解题代码及解析packagemainimport_"fmt"import."nc_tools"/**typeListNodestruct{*Valint*Next*ListNode*}*//***代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可***@parampHead1Lis
- 第六十一天 服务攻防-中间件安全&CVE复现&K8S&Docker&Jetty&Websphere
清歌secure
网络安全全栈学习笔记中间件安全kubernetesweb安全网络安全
第61天服务攻防-中间件安全&CVE复现&K8S&Docker&Jetty&Websphere知识点:中间件及框架列表:lIS,Apache,Nginx,Tomcat,Docker,Weblogic,JBoos,WebSphere,Jenkins,GlassFish,Jira,Struts2,Laravel,Solr,Shiro,Thinkphp,Sprng,Flask,jQuery0、中间件-K
- Algorithm
香水浓
javaAlgorithm
冒泡排序
public static void sort(Integer[] param) {
for (int i = param.length - 1; i > 0; i--) {
for (int j = 0; j < i; j++) {
int current = param[j];
int next = param[j + 1];
- mongoDB 复杂查询表达式
开窍的石头
mongodb
1:count
Pg: db.user.find().count();
统计多少条数据
2:不等于$ne
Pg: db.user.find({_id:{$ne:3}},{name:1,sex:1,_id:0});
查询id不等于3的数据。
3:大于$gt $gte(大于等于)
&n
- Jboss Java heap space异常解决方法, jboss OutOfMemoryError : PermGen space
0624chenhong
jvmjboss
转自
http://blog.csdn.net/zou274/article/details/5552630
解决办法:
window->preferences->java->installed jres->edit jre
把default vm arguments 的参数设为-Xms64m -Xmx512m
----------------
- 文件上传 下载 解析 相对路径
不懂事的小屁孩
文件上传
有点坑吧,弄这么一个简单的东西弄了一天多,身边还有大神指导着,网上各种百度着。
下面总结一下遇到的问题:
文件上传,在页面上传的时候,不要想着去操作绝对路径,浏览器会对客户端的信息进行保护,避免用户信息收到攻击。
在上传图片,或者文件时,使用form表单来操作。
前台通过form表单传输一个流到后台,而不是ajax传递参数到后台,代码如下:
<form action=&
- 怎么实现qq空间批量点赞
换个号韩国红果果
qq
纯粹为了好玩!!
逻辑很简单
1 打开浏览器console;输入以下代码。
先上添加赞的代码
var tools={};
//添加所有赞
function init(){
document.body.scrollTop=10000;
setTimeout(function(){document.body.scrollTop=0;},2000);//加
- 判断是否为中文
灵静志远
中文
方法一:
public class Zhidao {
public static void main(String args[]) {
String s = "sdf灭礌 kjl d{';\fdsjlk是";
int n=0;
for(int i=0; i<s.length(); i++) {
n = (int)s.charAt(i);
if((
- 一个电话面试后总结
a-john
面试
今天,接了一个电话面试,对于还是初学者的我来说,紧张了半天。
面试的问题分了层次,对于一类问题,由简到难。自己觉得回答不好的地方作了一下总结:
在谈到集合类的时候,举几个常用的集合类,想都没想,直接说了list,map。
然后对list和map分别举几个类型:
list方面:ArrayList,LinkedList。在谈到他们的区别时,愣住了
- MSSQL中Escape转义的使用
aijuans
MSSQL
IF OBJECT_ID('tempdb..#ABC') is not null
drop table tempdb..#ABC
create table #ABC
(
PATHNAME NVARCHAR(50)
)
insert into #ABC
SELECT N'/ABCDEFGHI'
UNION ALL SELECT N'/ABCDGAFGASASSDFA'
UNION ALL
- 一个简单的存储过程
asialee
mysql存储过程构造数据批量插入
今天要批量的生成一批测试数据,其中中间有部分数据是变化的,本来想写个程序来生成的,后来想到存储过程就可以搞定,所以随手写了一个,记录在此:
DELIMITER $$
DROP PROCEDURE IF EXISTS inse
- annot convert from HomeFragment_1 to Fragment
百合不是茶
android导包错误
创建了几个类继承Fragment, 需要将创建的类存储在ArrayList<Fragment>中; 出现不能将new 出来的对象放到队列中,原因很简单;
创建类时引入包是:import android.app.Fragment;
创建队列和对象时使用的包是:import android.support.v4.ap
- Weblogic10两种修改端口的方法
bijian1013
weblogic端口号配置管理config.xml
一.进入控制台进行修改 1.进入控制台: http://127.0.0.1:7001/console 2.展开左边树菜单 域结构->环境->服务器-->点击AdminServer(管理) &
- mysql 操作指令
征客丶
mysql
一、连接mysql
进入 mysql 的安装目录;
$ bin/mysql -p [host IP 如果是登录本地的mysql 可以不写 -p 直接 -u] -u [userName] -p
输入密码,回车,接连;
二、权限操作[如果你很了解mysql数据库后,你可以直接去修改系统表,然后用 mysql> flush privileges; 指令让权限生效]
1、赋权
mys
- 【Hive一】Hive入门
bit1129
hive
Hive安装与配置
Hive的运行需要依赖于Hadoop,因此需要首先安装Hadoop2.5.2,并且Hive的启动前需要首先启动Hadoop。
Hive安装和配置的步骤
1. 从如下地址下载Hive0.14.0
http://mirror.bit.edu.cn/apache/hive/
2.解压hive,在系统变
- ajax 三种提交请求的方法
BlueSkator
Ajaxjqery
1、ajax 提交请求
$.ajax({
type:"post",
url : "${ctx}/front/Hotel/getAllHotelByAjax.do",
dataType : "json",
success : function(result) {
try {
for(v
- mongodb开发环境下的搭建入门
braveCS
运维
linux下安装mongodb
1)官网下载mongodb-linux-x86_64-rhel62-3.0.4.gz
2)linux 解压
gzip -d mongodb-linux-x86_64-rhel62-3.0.4.gz;
mv mongodb-linux-x86_64-rhel62-3.0.4 mongodb-linux-x86_64-rhel62-
- 编程之美-最短摘要的生成
bylijinnan
java数据结构算法编程之美
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
public class ShortestAbstract {
/**
* 编程之美 最短摘要的生成
* 扫描过程始终保持一个[pBegin,pEnd]的range,初始化确保[pBegin,pEnd]的ran
- json数据解析及typeof
chengxuyuancsdn
jstypeofjson解析
// json格式
var people='{"authors": [{"firstName": "AAA","lastName": "BBB"},'
+' {"firstName": "CCC&
- 流程系统设计的层次和目标
comsci
设计模式数据结构sql框架脚本
流程系统设计的层次和目标
 
- RMAN List和report 命令
daizj
oraclelistreportrman
LIST 命令
使用RMAN LIST 命令显示有关资料档案库中记录的备份集、代理副本和映像副本的
信息。使用此命令可列出:
• RMAN 资料档案库中状态不是AVAILABLE 的备份和副本
• 可用的且可以用于还原操作的数据文件备份和副本
• 备份集和副本,其中包含指定数据文件列表或指定表空间的备份
• 包含指定名称或范围的所有归档日志备份的备份集和副本
• 由标记、完成时间、可
- 二叉树:红黑树
dieslrae
二叉树
红黑树是一种自平衡的二叉树,它的查找,插入,删除操作时间复杂度皆为O(logN),不会出现普通二叉搜索树在最差情况时时间复杂度会变为O(N)的问题.
红黑树必须遵循红黑规则,规则如下
1、每个节点不是红就是黑。 2、根总是黑的 &
- C语言homework3,7个小题目的代码
dcj3sjt126com
c
1、打印100以内的所有奇数。
# include <stdio.h>
int main(void)
{
int i;
for (i=1; i<=100; i++)
{
if (i%2 != 0)
printf("%d ", i);
}
return 0;
}
2、从键盘上输入10个整数,
- 自定义按钮, 图片在上, 文字在下, 居中显示
dcj3sjt126com
自定义
#import <UIKit/UIKit.h>
@interface MyButton : UIButton
-(void)setFrame:(CGRect)frame ImageName:(NSString*)imageName Target:(id)target Action:(SEL)action Title:(NSString*)title Font:(CGFloa
- MySQL查询语句练习题,测试足够用了
flyvszhb
sqlmysql
http://blog.sina.com.cn/s/blog_767d65530101861c.html
1.创建student和score表
CREATE TABLE student (
id INT(10) NOT NULL UNIQUE PRIMARY KEY ,
name VARCHAR
- 转:MyBatis Generator 详解
happyqing
mybatis
MyBatis Generator 详解
http://blog.csdn.net/isea533/article/details/42102297
MyBatis Generator详解
http://git.oschina.net/free/Mybatis_Utils/blob/master/MybatisGeneator/MybatisGeneator.
- 让程序员少走弯路的14个忠告
jingjing0907
工作计划学习
无论是谁,在刚进入某个领域之时,有再大的雄心壮志也敌不过眼前的迷茫:不知道应该怎么做,不知道应该做什么。下面是一名软件开发人员所学到的经验,希望能对大家有所帮助
1.不要害怕在工作中学习。
只要有电脑,就可以通过电子阅读器阅读报纸和大多数书籍。如果你只是做好自己的本职工作以及分配的任务,那是学不到很多东西的。如果你盲目地要求更多的工作,也是不可能提升自己的。放
- nginx和NetScaler区别
流浪鱼
nginx
NetScaler是一个完整的包含操作系统和应用交付功能的产品,Nginx并不包含操作系统,在处理连接方面,需要依赖于操作系统,所以在并发连接数方面和防DoS攻击方面,Nginx不具备优势。
2.易用性方面差别也比较大。Nginx对管理员的水平要求比较高,参数比较多,不确定性给运营带来隐患。在NetScaler常见的配置如健康检查,HA等,在Nginx上的配置的实现相对复杂。
3.策略灵活度方
- 第11章 动画效果(下)
onestopweb
动画
index.html
<!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/
- FAQ - SAP BW BO roadmap
blueoxygen
BOBW
http://www.sdn.sap.com/irj/boc/business-objects-for-sap-faq
Besides, I care that how to integrate tightly.
By the way, for BW consultants, please just focus on Query Designer which i
- 关于java堆内存溢出的几种情况
tomcat_oracle
javajvmjdkthread
【情况一】:
java.lang.OutOfMemoryError: Java heap space:这种是java堆内存不够,一个原因是真不够,另一个原因是程序中有死循环; 如果是java堆内存不够的话,可以通过调整JVM下面的配置来解决: <jvm-arg>-Xms3062m</jvm-arg> <jvm-arg>-Xmx
- Manifest.permission_group权限组
阿尔萨斯
Permission
结构
继承关系
public static final class Manifest.permission_group extends Object
java.lang.Object
android. Manifest.permission_group 常量
ACCOUNTS 直接通过统计管理器访问管理的统计
COST_MONEY可以用来让用户花钱但不需要通过与他们直接牵涉的权限
D