Merge pull request #13 from Kiritow/master

Catch up with you~
This commit is contained in:
KiritoTRw 2016-06-15 12:16:52 +08:00 committed by GitHub
commit 4217e27f44
2 changed files with 109 additions and 0 deletions

43
QUSTOJ/1426.cpp Normal file
View File

@ -0,0 +1,43 @@
#include<cstring>
#include<cstdio>
#include<iostream>
using namespace std;
int s[30][10010];
int a[400],F[30],t[30][30],d[30][30],p[30];
int n,m;
int main()
{
scanf("%d%d",&m,&n);
for (int i=1;i<=n*m;i++) scanf("%d",&a[i]);
for (int i=1;i<=n;i++)
for (int j=1;j<=m;j++)
scanf("%d",&d[i][j]);
for (int i=1;i<=n;i++)
for (int j=1;j<=m;j++)
scanf("%d",&t[i][j]);
memset(s,0,sizeof(s));
memset(F,0,sizeof(F));
memset(p,0,sizeof(p));
int Max,odle,pos;
Max=-1;
for (int i=1;i<=n*m;i++)
{
odle=0; p[a[i]]++;
for (int j=F[a[i]]+1;;j++)
{
if (s[d[a[i]][p[a[i]]]][j]) odle=0;
else odle++;
if (odle>=t[a[i]][p[a[i]]])
{
pos=j; break;
}
}
for (int k=pos-odle+1;k<=pos;k++)
s[d[a[i]][p[a[i]]]][k]=1;
F[a[i]]=pos;
if (pos>Max) Max=pos;
}
printf("%d\n",Max);
return 0;
}

66
TYVJ/1058_c_y__chou.c Normal file
View File

@ -0,0 +1,66 @@
#include <stdio.h>
#include <string.h>
int train[361];
int machine[19][19];
int time[19][19];
int used[19];
int finished[19];
char cpu[19][361];
int main(void)
{
int i,j,k;
int m,n;
int t;
int ans;
scanf("%d%d",&m,&n);
for(i=0;i<m*n;i++)
{
scanf("%d",&train[i]);
train[i]--;
}
for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
{
scanf("%d",&machine[i][j]);
machine[i][j]--;
}
}
for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
{
scanf("%d",&time[i][j]);
}
}
ans = 0;
for(i=0;i<m*n;i++)
{
t=train[i];
j=finished[t]-1; //  因为当查找失败时j的值需要向前增一
do{ //所以在赋值的时候就减了一然后用do-while
j++; //的形式一进来就对j递增。
for(k=0;k<time[t][used[t]];k++)
{
if(cpu[machine[t][used[t]]][j+k]){
j=k+j; //  在最开始我就错在这行代码j = k + j
break; //的位置上我把位置放在while(..)的上面,
} //也就导致了在有时候选择了处理器新的位置
} //时在底下的memset功能工作不正常。因为我
//是使用的finished而不是j则在选择了位置
//之后会导致一些预想不到的问题。
}while(cpu[machine[t][used[t]]][j]);
memset(cpu[machine[t][used[t]]]+j,t+1,time[t][used[t]]);
if(ans<j+time[t][used[t]])
{
ans=j+time[t][used[t]];
}
finished[t]=j+k;
used[t]++;
}
//  最后还来一点注释我把求ans集成
//到了主循环里面,牺牲了一些可读性,对
//各位朋友说声Sorry..
printf("%d\n",ans);
return 0;
}