九度互动社区IT名企招聘上机考试热身赛
生活随笔
收集整理的這篇文章主要介紹了
九度互动社区IT名企招聘上机考试热身赛
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
http://ac.jobdu.com/problem.php?pid=1326???? Waiting in Line
//簡單模擬題 #include<iostream> #include<cstdio> using namespace std; #include<memory.h>int pt[1001],leave[1001],start[21]; int n,m,k,q; inline bool scan_d(int &num) // 這個就是 加速的 關鍵了 {char in;bool IsN=false;in=getchar();if(in==EOF)return false;while(in!='-'&&(in<'0'||in>'9')) in=getchar();if(in=='-') { IsN=true;num=0;}else num=in-'0';while(in=getchar(),in>='0'&&in<='9'){num*=10,num+=in-'0';}if(IsN)num=-num;return true; }void solve() {int i,j,index,t,p,count=k;int num[21],window[21][13];memset(start,0,sizeof(start));memset(num,0,sizeof(num));j = index = 1;for(i = 1 ; i <= n*m && i <= k ; ++i) //剛開始時,n個窗口都是空的,客戶依次選擇隊伍最短的窗口{window[j][index] = i;num[j]++;j++;if(j>n){j = 1;++index;}}j = i; //剛開始的n個窗口已經都排滿了客戶t = 0;while(t <= 540){++t;for(i = 1 ; i <= n ; ++i){if(num[i] > 0 && pt[ window[i][1] ] == t - start[i]){leave[ window[i][1] ] = t;start[i] = t;--count; //一個用戶離開for(p = 2 ; p <= num[i] ; ++p)window[i][p-1] = window[i][p]; //每個窗口的第一個用戶離開后,后面的客戶依次往前移動--num[i];if(j <= k) //還有等待的客戶的時候,往窗口中再增加一個{window[i][p-1] = j;++num[i];++j;}}//if}//forif(!count) //所有客戶都處理完的時候,直接退出break;} }int main(void) {int i,j;while(scanf("%d %d %d %d",&n,&m,&k,&q)!=EOF){memset(leave,1,sizeof(leave));for(i = 1 ; i <= k ; ++i)scan_d(pt[i]);solve();for(i = 0 ; i < q ; ++i){scan_d(j);if(leave[j] > 540)puts("Sorry");elseprintf("%02d:%02d\n",leave[j]/60+8,leave[j]%60);}}return 0; }
與50位技術專家面對面20年技術見證,附贈技術全景圖
總結
以上是生活随笔為你收集整理的九度互动社区IT名企招聘上机考试热身赛的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 2005年上海交通大学计算机研究生机试真
- 下一篇: 实习生招聘笔试