「一家人杯」程序設計大賽 標準程序
1、排隊出發
/*
ID:LXYXYNT
PROB:1
LANG:C++
*/
#include <iostream>
using namespace std;
const int maxn=50001;
int n,ans;
int a[maxn],b[maxn],c[maxn][2],d[maxn];
void sort(int l,int r)
{
int temp,s=l,t=r,k=c[(l+r)>>1][0];
do{
while (c[s][0]<k) ++s;
while (c[t][0]>k) --t;
if (s<=t)
{
temp=c[s][0];c[s][0]=c[t][0];c[t][0]=temp;
temp=c[s][1];c[s][1]=c[t][1];c[t][1]=temp;
++s;--t;
}
}while (s<=t);
if (l<t) sort(l,t);
if (s<r) sort(s,r);
return;
}
int main()
{
freopen("1.in","r",stdin);
freopen("1.out","w",stdout);
cin >> n;
for (int i=1;i<=n;++i)
{
cin >> a[i] >> b[i];
c[i][0]=a[i]+b[i];
c[i][1]=i;
}
sort(1,n);
c[0][0]=0;
c[0][1]=0;
b[0]=0;a[0]=0;
ans=-9999999;
for (int i=1;i<=n;++i)
{
d[i]=a[c[i-1][1]]+d[i-1];
if (d[i]>b[c[i][1]]+ans) ans=(d[i]-b[c[i][1]]);
}
cout << ans << endl;
return 0;
}
2、自動做作業機
/*
ID:LXYXYNT
PROB:2
LANG:C++
*/
#include <iostream>
using namespace std;
const int maxn=10002;
int p1,p2,n,s,dp[maxn],sumf[maxn],sumt[maxn],d[maxn];
double cal(int i,int j)
{
return((dp[i]-dp[j])/(sumt[i]-sumt[j]));
}
int main()
{
freopen("2.in","r",stdin);
freopen("2.out","w",stdout);
cin >> n >> s;
sumt[n+1]=0;sumf[n+1]=0;
for (int i=1;i<=n;++i) cin >> sumt[i] >> sumf[i];
for (int i=n;i>=1;--i)
{
sumf[i]+=sumf[i+1];
sumt[i]+=sumt[i+1];
}
dp[n+1]=0;
p1=1;p2=1;d[1]=n+1;
for (int i=n;i>=1;--i)
{
dp[i]=dp[d[p1]]+(s+sumt[i]-sumt[d[p1]])*sumf[i];
while ((p2>p1)&&(cal(d[p2],d[p2-1])>cal(i,d[p2]))) --p2;
d[++p2]=i;
while ((p2>p1)&&(cal(d[p1+1],d[p1])<sumf[i-1])) ++p1;
}
cout << dp[1] << endl;
return 0;
}
3、鬼火閃閃
/* ID: ceeji
PROG: 3
Key Point: 位運算
http://ceeji.net/
*/
#include <iostream>
#include <string>
#include <string.h>
#include <iomanip>
using namespace std;
int main()
{
freopen("3.in","r",stdin);
freopen("3.out","w",stdout);
unsigned long num,p,byte1,byte2;
scanf("%u",&num);
for (int i = 0; i < num; ++i)
{
scanf("%u",&p);
byte1 = p>>16;
byte2 = p<<16;
printf("%u\n",byte1|byte2);
}
fflush(stdout);
return 0;
}
4、險象叢生
/* ID: ceeji
PROG: 4
Key Point: Tree DP; Sort
http://ceeji.net/
*/
#include <stdio.h>
#include <stdlib.h>
#include <fstream>
#include <string.h>
#define getmin(x,y,z) ((x <= y)&&(x <= z)?x:((y <= z)&&(y <= x)?y:z))
#define min(x,y) (x <= y?x:y)
using namespace std;
const int maxn = 5010, len = 10010;
const char* inf = "4.in";
const char* outf = "4.out";
int edge[len], next[len], first[len], res[maxn];
int dp[maxn][3];
bool done[maxn];
int edge_count = 0;
// 添加邊。
void addedge(int i, int j)
{
int tmp = first[i];
first[i] = ++edge_count;
edge[edge_count] = j;
next[edge_count] = tmp;
}
int comp(const void* c1, const void* c2)
{
return *(static_cast<const int*>(c1)) - *(static_cast<const int*>(c2));
}
void treedp(int p)
{
if (done[p])
return;
done[p] = true;
dp[p][0] = 1;
int minc = 60000,s,zg = 0;
for (int i = first[p], x = edge[i]; i != 0; i = next[i], x = edge[i])
{
if (!done[x])
{
treedp(x);
zg++;
dp[p][0] += getmin(dp[x][0],dp[x][1],dp[x][2]);
s = min(dp[x][0],dp[x][1]);
dp[p][1] += s;
if ((s == dp[x][1]) && (dp[x][1] != dp[x][0]))
minc = min(minc,dp[x][0]-dp[x][1]);
else
minc = -1;
dp[p][2] += dp[x][1];
}
}
if (zg == 0)
{
dp[p][0] = 1;
dp[p][1] = 50000;
dp[p][2] = 0;
return;
}
if (minc != -1)
dp[p][1] += minc;
}
int main()
{
//init.
ifstream fin(inf); ofstream fout(outf);
memset(first,0,sizeof(first));
memset(done,0,sizeof(done));
//read data.
int n, m, tmp, e, tmp2;
fin >> n >> m >> e;
for (int i = 1; i <= e; ++i)
{
fin >> tmp >> tmp2;
addedge(tmp,tmp2);
addedge(tmp2,tmp);
}
int z = 0;
for (int i = 1; i <= n; ++i)
{
if (!done[i])
{
treedp(i);
res[z++] = min(dp[i][0],dp[i][1]);
}
}
qsort(res,z,sizeof(res[0]),comp);
for (int i = 0; i < z; ++i)
{
m -= res[i];
if (m < 0)
{
fout << i << endl << flush;
return 0;
}
}
fout << z << endl << flush;
return 0;
}
© 轉載需附帶本文連結,依 CC BY-NC-SA 4.0 釋出。