2016 ACM-ICPC EC-Final题解
A. Number Theory Problem
题意:给你一个数N,求形如2k-1且小于2N的数中有多少能被7整除。
解法:观察二进制位找规律,答案是N/3。
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int n; int main() {
int T,kase=;
scanf("%d",&T);
while(T--) {
scanf("%d",&n);
printf("Case #%d: %d\n",++kase,n/);
}
return ;
}
B. Hemi Palindrome
题意:一个串是半回文串当且仅当它的奇数位是回文串或偶数位是回文串。给你两个数N,K,求长度为N的01串中字典序第K小的半回文串。
解法:从高到低枚举这个串的每一位,首先把这个位置上的数置0,然后算出以已放过数的位为前缀的半回文串有多少个,如果大于K则改为置1并把K减掉相应的个数,否则继续放下一位。
需要考虑的细节很多,如中心点的选取,临界判断,容斥,溢出处理等等。
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=1e5+;
int bit[N],n,mid,flag[],kase=;
ll k; int cntall(int l,int r) {return r-l+;}
int cntodd(int l,int r) {return (cntall(l,r)&)&&(r&)?cntall(l,r)/+:cntall(l,r)/;}
int cnteven(int l,int r) {return cntall(l,r)-cntodd(l,r);} ll f(int a,int b,int c) {
if(a>=||b>=)return 1ll<<;
return (a<?:(1ll<<a))+(b<?:(1ll<<b))-(c<?:(1ll<<c));
} void solve() {
flag[]=flag[]=;
for(int i=; i<=n; ++i) {
if(i<=mid) {
bit[i]=;
int a=cntall(i+,mid)+cntodd(mid+,n);
int b=cntall(i+,mid)+cnteven(mid+,n);
int c=cntall(i+,mid);
ll t=f(a,b,c);
if(t<k)bit[i]=,k-=t;
} else {
int op=n&?n-i+:(i&?n-i:n-i+);
bit[i]=;
if(bit[i]!=bit[op])flag[i&]++;
int a=flag[]?-:cntodd(i+,n);
int b=flag[]?-:cnteven(i+,n);
int c=flag[]||flag[]?-:;
ll t=f(a,b,c);
if(t<k) {
if(bit[i]!=bit[op])flag[i&]--;
bit[i]=,k-=t;
if(bit[i]!=bit[op])flag[i&]++;
}
}
}
printf("Case #%d: ",++kase);
if(k==)for(int i=; i<=n; ++i)printf("%d",bit[i]);
else printf("NOT FOUND!");
printf("\n");
} int main() {
int T;
scanf("%d",&T);
while(T--) {
scanf("%d%lld",&n,&k);
mid=(n+)/;
if(!(n&)&&((n/)&))mid++;
solve();
}
return ;
}
C. Mr. Panda and Strips
题意:给你一个数列,让你选择两段连续的区间(区间长度可以为0),使两段区间内所有的数互不相同,且区间长度尽可能大。求最大的区间长度。
解法:暴力枚举第一个区间,然后利用单调性尺取第二个区间。理论复杂度为O(N3),但加上剪枝会快很多。
#include<bits/stdc++.h>
typedef long long ll;
using namespace std;
const int N=+;
const int M=1e5+;
int a[N],c[M],n; int main() {
int T,kase=;
scanf("%d",&T);
while(T--) {
int ans=;
memset(c,,sizeof c);
scanf("%d",&n);
for(int i=; i<n; ++i)scanf("%d",&a[i]);
int l,r,L,R;
for(l=,r=-; l<n; c[a[l++]]--) {
if(n-l<=ans)break;
while(r<l-)c[a[++r]]++;
while(r+<n&&c[a[r+]]<=) {
c[a[++r]]++;
for(L=r+,R=L-; L<n; c[a[L++]]--) {
if(n-L+r-l+<=ans)break;
while(R+<n&&c[a[R+]]<=)c[a[++R]]++;
ans=max(ans,R+r-L-l+);
}
while(R<L-)c[a[++R]]++;
while(R>=L)c[a[R--]]--;
}
while(r>=l)c[a[r--]]--;
}
printf("Case #%d: %d\n",++kase,ans);
}
return ;
}
D. Ice Cream Tower
题意:有N个冰淇淋球,每K个可以组成一个冰淇淋塔,但要求下面的冰淇淋球的大小不得小于上面的2倍。给你每个冰淇淋球的大小,求最多能做多少个冰淇淋塔。
解法:如果能做x个冰淇淋塔的话,那么最优做法必然是先取最小的x个冰淇淋球作为第一层,然后一层一层往下铺。可以把冰淇淋球从小到大排序,然后二分枚举x的值,依次判断能否做成即可。复杂度O(NlogN)
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=3e5+;
int n,k;
ll a[N],b[N]; bool ok(int x) {
for(int i=; i<x; ++i)b[i]=a[i];
int t=,cnt=;
for(int i=x; i<n; ++i) {
if(a[i]/b[t]>=) {
if(t==x-)++cnt;
b[t]=a[i],t=(t+)%x;
}
}
return cnt>=k;
} int main() {
int T,kase=;
scanf("%d",&T);
while(T--) {
scanf("%d%d",&n,&k);
for(int i=; i<n; ++i)scanf("%lld",&a[i]);
sort(a,a+n);
int l=,r=n;
while(l<r) {
int mid=(l+r+)>>;
ok(mid)?l=mid:r=mid-;
}
printf("Case #%d: %d\n",++kase,l);
}
return ;
}
E. Bet
题意:你去投注一场比赛,这场比赛一共有N支队伍,每支队伍都有一个赔率Ai:Bi,代表假如你投进x元,如果该队伍赢了,那么你将得到x*(1+Bi/Ai)元,否则什么都得不到。问你最多能投注多少支队伍,使得只要你投注的任意一支队伍获胜,你就不会赔钱。
解法:假设你总共投注了x元钱,那么你至少要在每支队伍上投x/(1+Bi/Ai)元才能保证回本。把所有队伍按Bi/Ai的大小从大到小排序,然后从0开始加上每支队伍的1/(1+Bi/Ai),加到超过1为止,加过的队伍数就是最终答案。
这道题卡精度,用Java自带的高精度浮点数可破,long double加上一点玄学也可破。我求稳只写Java的好了。
import java.util.*;
import java.io.*;
import java.math.*; public class Main {
public static void main(String[] args) throws Exception {
//System.setIn(new FileInputStream("i.txt"));
Scanner in = new Scanner(System.in);
int kase = 0;
for (int T = in.nextInt(); T > 0; T--) {
int n = in.nextInt();
BigDecimal[] a = new BigDecimal[n];
for (int i = 0; i < n; ++i) {
String s = in.next();
String[] s2 = s.split(":");
BigDecimal x = new BigDecimal(s2[0]);
BigDecimal y = new BigDecimal(s2[1]);
a[i] = BigDecimal.ONE.divide(BigDecimal.ONE.add(y.divide(x, 20, RoundingMode.UP)), 20, RoundingMode.UP);
}
Arrays.sort(a);
int ans = 0;
BigDecimal now = BigDecimal.ZERO;
while (ans < n) {
now = now.add(a[ans]);
if (now.compareTo(BigDecimal.ONE) >= 0)
break;
ans++;
}
System.out.printf("Case #%d: %d\n", ++kase, ans);
}
in.close();
}
}
F. Mr. Panda and Fantastic Beasts
题意:给你N个字符串,让你从第一个字符串找到一个最短的并且没有在其他字符串中出现过的子串,如果有多解,输出字典序最小的。
解法:后缀数组或后缀自动机。
后缀数组解法:把所有字符串用没有出现过的字符连接起来求后缀数组,把第一个字符串中所有的后缀放进集合A,把其他字符串中的后缀放进集合B。依次枚举集合A中的每个后缀,二分或者利用单调性找到B中和该后缀字典序最接近的一个或两个后缀,求出它们的lcp,则该后缀的位置上长度大于lcp的子串都没有在B中出现,依次更新答案即可。复杂度O(NlogN)(二分),O(N)(单调性)(其实光求后缀数组就已经O(NlogN)了)。
#include<bits/stdc++.h>
using namespace std;
const int INF=0x3f3f3f3f;
const int N=3e5+;
char s[N],buf[N];
int n,k,len1,m,kase=;
vector<int> v1,v2;
struct SA {
static const int N=3e5+;
int bufa[N],bufb[N],c[N],sa[N],rnk[N],height[N],ST[N][];
void getsa(char* s,int n,int m=) {
int *x=bufa,*y=bufb;
x[n]=y[n]=-;
for(int i=; i<m; ++i)c[i]=;
for(int i=; i<n; ++i)c[x[i]=s[i]]++;
for(int i=; i<m; ++i)c[i]+=c[i-];
for(int i=n-; i>=; --i)sa[--c[x[i]]]=i;
for(int k=,p=; k<n; k<<=,m=p,p=) {
for(int i=n-k; i<n; ++i)y[p++]=i;
for(int i=; i<n; ++i)if(sa[i]>=k)y[p++]=sa[i]-k;
for(int i=; i<m; ++i)c[i]=;
for(int i=; i<n; ++i)c[x[y[i]]]++;
for(int i=; i<m; ++i)c[i]+=c[i-];
for(int i=n-; i>=; --i)sa[--c[x[y[i]]]]=y[i];
swap(x,y),x[sa[]]=,p=;
for(int i=; i<n; ++i)x[sa[i]]=y[sa[i]]==y[sa[i-]]&&y[sa[i]+k]==y[sa[i-]+k]?p-:p++;
if(p>=n)break;
}
}
void getheight(char* s,int n) {
for(int i=; i<n; ++i)rnk[sa[i]]=i;
for(int i=,k=; i<n; ++i) {
if(!rnk[i])continue;
if(k)k--;
while(s[i+k]==s[sa[rnk[i]-]+k])k++;
height[rnk[i]]=k;
}
height[]=height[n]=;
}
void initST(int n) {
for(int i=; i<n; ++i)ST[i][]=height[i];
for(int j=; (<<j)<=n; ++j)
for(int i=; i+(<<j)-<n; ++i)
ST[i][j]=min(ST[i][j-],ST[i+(<<(j-))][j-]);
}
void build(char* s,int n) {
getsa(s,n);
getheight(s,n);
initST(n);
}
int lcp(int l,int r) {
if(l==r)return n-sa[l];
if(l>r)swap(l,r);
l++;
int k=;
while(<<(k+)<=r-l+)k++;
return min(ST[l][k],ST[r-(<<k)+][k]);
}
void solve() {
v1.clear();
v2.clear();
for(int i=; i<n; ++i) {
if(sa[i]<len1)v1.push_back(sa[i]);
else v2.push_back(sa[i]);
}
int ansi,anslen=INF;
for(int i=,j=; i<v1.size(); ++i) {
while(j<v2.size()&&rnk[v2[j]]<rnk[v1[i]])++j;
int maxlen=-;
if(j<n)maxlen=max(maxlen,lcp(rnk[v1[i]],rnk[v2[j]]));
if(j>)maxlen=max(maxlen,lcp(rnk[v1[i]],rnk[v2[j-]]));
if(maxlen<anslen&&v1[i]+maxlen<len1)anslen=maxlen,ansi=v1[i];
}
printf("Case #%d: ",++kase);
if(anslen!=INF)for(int i=ansi; i<=ansi+anslen; ++i)printf("%c",s[i]);
else printf("Impossible");
printf("\n");
}
} sa;
int main() {
int T;
scanf("%d",&T);
while(T--) {
n=;
scanf("%d",&m);
for(int i=; i<m; ++i) {
scanf("%s",buf);
int len=strlen(buf);
if(i==)len1=len;
else s[n++]='z'+;
for(int i=; i<len; ++i)s[n++]=buf[i];
}
s[n]='\0';
sa.build(s,n);
sa.solve();
}
return ;
}
后缀自动机解法:把除第一个字符串以外的所有字符串用没有出现过的字符连接起来建立后缀自动机,拿第一个字符串在自动机上跑一遍,每次失配的时候找到失配点对应的最短子串更新答案即可。由于后缀自动机对字典序的处理不如后缀数组优秀,更新字典序的时候依然要用暴力,不过平摊下来的复杂度还是O(1)的,因此总的复杂度为O(N),比后缀数组略快一点。
#include<bits/stdc++.h>
using namespace std;
const int INF=0x3f3f3f3f;
const int N=3e5+;
char s1[N],buf[N];
int m,len1,kase=; struct SAM {
static const int N=5e5+;
static const int M=;
static const int root=;
int go[N][M],pre[N],maxlen[N],nnode,last,anslen,ansr;
void init() {
last=nnode=;
newnode();
pre[root]=-;
}
int newnode(int l) {
memset(go[nnode],,sizeof go[nnode]);
maxlen[nnode]=l;
return nnode++;
}
void extend(int ch) {
int p=last,np=last=newnode(maxlen[p]+);
while(~p&&!go[p][ch])go[p][ch]=np,p=pre[p];
if(!~p)pre[np]=root;
else {
int q=go[p][ch];
if(maxlen[q]==maxlen[p]+)pre[np]=q;
else {
int nq=newnode(maxlen[p]+);
memcpy(go[nq],go[q],sizeof go[nq]);
pre[nq]=pre[q],pre[q]=pre[np]=nq;
while(go[p][ch]==q)go[p][ch]=nq,p=pre[p];
}
}
}
void solve() {
anslen=INF;
for(int i=,p=; i<len1; ++i) {
int ch=s1[i]-'a';
while(~p&&!go[p][ch]) {
int minlen=p?maxlen[pre[p]]+:;
minlen++;
if(minlen<anslen||(minlen==anslen&&strncmp(s1+i-minlen+,s1+ansr-minlen+,minlen)<))ansr=i,anslen=minlen;
p=pre[p];
}
if(!~p)p=root;
p=go[p][ch];
}
printf("Case #%d: ",++kase);
if(anslen==INF)printf("Impossible\n");
else {
for(int i=ansr-anslen+; i<=ansr; ++i)printf("%c",s1[i]);
printf("\n");
}
}
} sam; int main() {
int T;
scanf("%d",&T);
while(T--) {
sam.init();
scanf("%d",&m);
scanf("%s",s1);
len1=strlen(s1);
for(int i=; i<m; ++i) {
scanf("%s",buf);
int len=strlen(buf);
if(i>)sam.extend('z'-'a'+);
for(int j=; j<len; ++j)sam.extend(buf[j]-'a');
}
sam.solve();
}
return ;
}
G. Pandaria
题意:给你一个有N个点和M条边的无向图,图上每个点都有一个编号代表颜色,每条边都有一个权值。然后给出Q组询问,每组询问有两个值x,w,让你求出从x点出发,所经过的所有边的权值都不超过w的条件下,能够到达的所有点中颜色最多的是哪一种。如果有多个答案,输出编号最小的颜色。要求强制在线。
解法:kruskal重构树+线段树合并+树上二分(倍增)。
首先对每个点建一棵权值线段树,记录这个点所在集合中每种颜色出现了多少次以及出现次数最多的颜色。然后把所有边按权值从小到大扫一遍,把各个点依次加进并查集。在合并两个集合的时候,需要新建一个结点,把两个集合的父节点指向它,并把两个集合对应的权值线段树合并,把答案更新到这个结点,同时在该结点上标注上合并这两个集合的边的花费。最后对重构树求出倍增数组,对每组询问二分找到对应时刻的答案即可。复杂度O(NlogN)。
#include<bits/stdc++.h> using namespace std;
const int N=2e5+;
int col[N],fa[N],f[N][],ans[N],rt[N],cost[N],ntree,ndsu;
int mx[N*],val[N*],ls[N*],rs[N*];
int n,m,Q,kase=; struct Edge {
int u,v,c;
bool operator<(const Edge& b)const {
return c<b.c;
}
} e[N]; void init() {
ntree=ndsu=;
fa[]=f[][]=;
mx[]=;
} int father(int u) {
return fa[u]?fa[u]=father(fa[u]):u;
} void pushup(int u) {
mx[u]=max(mx[ls[u]],mx[rs[u]]);
if(mx[u]==mx[ls[u]])val[u]=val[ls[u]];
else val[u]=val[rs[u]];
} int build(int l,int r,int x) {
int u=++ntree;
ls[u]=rs[u]=;
if(l==r) {
mx[u]=;
val[u]=l;
} else {
int mid=(l+r)>>;
if(x<=mid)ls[u]=build(l,mid,x);
else rs[u]=build(mid+,r,x);
pushup(u);
}
return u;
} int Merge(int u,int v,int l,int r) {
if(!u)return v;
if(!v)return u;
if(l==r) {
mx[u]+=mx[v];
} else {
int mid=(l+r)>>;
ls[u]=Merge(ls[u],ls[v],l,mid);
rs[u]=Merge(rs[u],rs[v],mid+,r);
pushup(u);
}
return u;
} void db() {
for(int j=; j<; ++j)
for(int i=; i<=ndsu; ++i)
f[i][j]=f[f[i][j-]][j-];
} int main() {
int T;
scanf("%d",&T);
while(T--) {
printf("Case #%d:\n",++kase);
init();
scanf("%d%d",&n,&m);
for(int i=; i<=n; ++i)scanf("%d",&col[i]);
for(int i=; i<m; ++i)scanf("%d%d%d",&e[i].u,&e[i].v,&e[i].c);
for(int i=; i<=n; ++i) {
fa[i]=f[i][]=;
cost[i]=;
rt[i]=build(,n,col[i]);
ans[i]=val[rt[i]];
}
ndsu=n;
sort(e,e+m);
for(int i=; i<m; ++i) {
int u=e[i].u,v=e[i].v,c=e[i].c;
int fu=father(u),fv=father(v);
if(fu==fv)continue;
int w=++ndsu;
fa[w]=f[w][]=;
cost[w]=c;
fa[fu]=fa[fv]=f[fu][]=f[fv][]=w;
rt[w]=Merge(rt[fu],rt[fv],,n);
ans[w]=val[rt[w]];
}
db();
scanf("%d",&Q);
int last=;
while(Q--) {
int u,c;
scanf("%d%d",&u,&c);
u^=last,c^=last;
for(int j=; j>=; --j)if(f[u][j]&&cost[f[u][j]]<=c)u=f[u][j];
printf("%d\n",ans[u]);
last=ans[u];
}
}
return ;
}
还有一种比较偷懒的解法是用map代替权值线段树,合并两个集合的时候把两个集合的map整合,比线段树略慢一点,思路都差不多就不再写了。
H. Great Cells
题意:给你一个N*M的矩阵,矩阵上每个数的取值范围是[1,K],如果该矩阵一个格子上的数比它所在的行以及列上的其他格子上的所有数都大,那么这个格子就称作Great cell。求∑ (g=0,NM) (g + 1) · Ag mod (1e9 + 7)的值,Ag代表使得该矩阵中恰有g个Great cell的状态总数。
解法:虽然这个式子看上去非常玄乎,但其实每个格子作为Great cell出现的局面总数加起来就是这个答案。随便选一个格子,如果这个格子是Great cell,那么它所在的行和列上的格子都必须比它小,其他的格子则不受限制。由于所有的格子都是等价的,所以最后乘上N*M即可。
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const ll mod=1e9+;
ll n,m,k; ll Pow(ll x,ll p) {
ll ret=;
while(p) {
if(p&)ret=ret*x%mod;
x=x*x%mod;
p>>=;
}
return ret;
} int main() {
int T,kase=;
scanf("%d",&T);
while(T--) {
ll ans=;
scanf("%lld%lld%lld",&n,&m,&k);
ans+=Pow(k,n*m);
for(ll i=; i<=k; ++i)ans=(ans+Pow(i-,n+m-)%mod*Pow(k,(n-)*(m-))%mod*n%mod*m%mod)%mod;
printf("Case #%d: %lld\n",++kase,ans);
}
return ;
}
I. Cherry Pick
留坑
J. Mr.Panda and TubeMaster
留坑
K. Justice Rains From Above
留坑
L. World Cup
题意:有4支队伍,每两支队伍之间打一场比赛,赢了计3分,平局计1分,输了不计分。给出赛后每支队伍的总分,问是否合理,如果合理的话求出每两支队伍之间的比赛胜负情况是否唯一。
解法:一共就36=729种情况,依次枚举出来看看是否合适即可。
#include<stdio.h>
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std;
int score[],cnt;
int a[][]= {
{,},
{,},
{,},
{,},
{,},
{,},
}; void dfs(int now) {
if(now==) {
if(score[]==&&score[]==&&score[]==&&score[]==)++cnt;
return;
}
score[a[now][]]-=;
dfs(now+);
score[a[now][]]+=;
score[a[now][]]-=;
score[a[now][]]-=;
dfs(now+);
score[a[now][]]+=;
score[a[now][]]+=;
score[a[now][]]-=;
dfs(now+);
score[a[now][]]+=;
} int main() {
int T,kase=;
scanf("%d",&T);
while(T--) {
printf("Case #%d: ",++kase);
cnt=;
for(int i=; i<; ++i)scanf("%d",&score[i]);
dfs();
if(cnt==)puts("Yes");
else if(cnt==)puts("Wrong Scoreboard");
else puts("No");
}
return ;
}
2016 ACM-ICPC EC-Final题解的更多相关文章
- 2016 ACM/ICPC Asia Regional Qingdao Online(2016ACM青岛网络赛部分题解)
2016 ACM/ICPC Asia Regional Qingdao Online(部分题解) 5878---I Count Two Three http://acm.hdu.edu.cn/show ...
- 2016 ACM/ICPC亚洲区青岛站现场赛(部分题解)
摘要 本文主要列举并求解了2016 ACM/ICPC亚洲区青岛站现场赛的部分真题,着重介绍了各个题目的解题思路,结合详细的AC代码,意在熟悉青岛赛区的出题策略,以备战2018青岛站现场赛. HDU 5 ...
- 2016 ACM/ICPC Asia Regional Shenyang Online 1009/HDU 5900 区间dp
QSC and Master Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) ...
- 2016 ACM/ICPC Asia Regional Shenyang Online 1003/HDU 5894 数学/组合数/逆元
hannnnah_j’s Biological Test Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K ...
- 2016 ACM/ICPC Asia Regional Qingdao Online 1001/HDU5878 打表二分
I Count Two Three Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others ...
- 2016 ACM/ICPC Asia Regional Shenyang Online 1007/HDU 5898 数位dp
odd-even number Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)T ...
- 2016 ACM/ICPC Asia Regional Dalian Online 1002/HDU 5869
Different GCD Subarray Query Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 65536/65536 K ( ...
- 2016 ACM/ICPC Asia Regional Dalian Online 1006 /HDU 5873
Football Games Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)To ...
- HDU 5874 Friends and Enemies 【构造】 (2016 ACM/ICPC Asia Regional Dalian Online)
Friends and Enemies Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Othe ...
- HDU 5889 Barricade 【BFS+最小割 网络流】(2016 ACM/ICPC Asia Regional Qingdao Online)
Barricade Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total S ...
随机推荐
- Centos---linux配置 集群搭建
网络配置 1.创建虚拟机mini1: 1.1.网络配置 NAT网络模式模式 直接修改 /etc/sysconfig/network-script/ifcfg-eth0 输入service netwo ...
- Python学习进程(13)文件与IO
本节介绍基本的IO函数和文件的读写操作. (1)读取键盘输入: Python用于读取键盘输入的函数有两个:raw_input与input. 1)raw_input函数 从标准输入读取一 ...
- 每天一个Linux命令(57)rpm命令
rpm是一个功能十分强大的软件包管理系统. (1)用法: 用法: rpm [参数] [包名] (2)功能: 功能: 使得在Linux下安装.升级和删除软 ...
- Qt5.2.1交叉编译,带tslib插件
一: 源码下载地址: 1.1: 平台: 主机:ubuntu 14.04 开发板: cpu arm-cortex-a8,故而我在配置我的qmake.conf的时候填写的为armV7-a QT版本: qt ...
- 修改redhat默认显示语言为中文
[delmore@localhost Desktop]$ su //切换到最高权限 Password: ...
- 通过join方法顺序执行多个线程
方法一:直接用多线程之间的通讯去解决 package com.toov5.test; import javax.imageio.ImageTypeSpecifier; class Res1{ char ...
- 通过代码或者配置文件 对log4net进行配置
1.通过代码进行配置 1.1代码 http://stackoverflow.com/questions/16336917/can-you-configure-log4net-in-code-inste ...
- windows编译hadoop 2.x Hadoop-eclipse-plugin插件
本文转载至:http://blog.csdn.net/congcong68/article/details/42098391 一.简介 Hadoop2.x之后没有Eclipse插件工具,我们就不能在E ...
- VC 模拟CMD 匿名管道
#include "stdafx.h" #include <Windows.h> #include <stdio.h> #include <stdli ...
- react列表中,当key改变后发生的事情
Main.jsx export default class Main extends PureComponent { constructor(props) { super(props); this.s ...