題目1
標題:分數
1/1 + 1/2 + 1/4 + 1/8 + 1/16 + ....
每項是前一項的一半,如果一共有20項,
求這個和是多少,結果用分數表示出來。
類似:
3/2
當然,這只是加了前2項而已。分子分母要求互質。注意:
需要提交的是已經約分過的分數,中間任何位置不能含有空格。
請不要填寫任何多余的文字或符號。
結果:1048575/524288
1 + 1/(2的19次方) ,寫個簡單程序計算即可。

#include <bits/stdc++.h> using namespace std; #define REP(i,n) for(int i=0;i<n;i++) #define FOR(i,a,b) for(int i=a;i<=b;i++) #define DOWN(i,b,a) for(int i=b;i>=a;i--) //#define LOCAL int main(){ #ifdef LOCAL freopen("input.txt","r",stdin); //freopen("output.txt","w",stdout); #endif // LOCAL long x=pow(2,19); printf("%d/%d",x+x-1,x); return 0; }
題目2
標題:星期一整個20世紀(1901年1月1日至2000年12月31日之間),一共有多少個星期一?
(不要告訴我你不知道今天是星期幾)注意:需要提交的只是一個整數,不要填寫任何多余的內容或說明文字。
結果:5217
計算一下一共有多少天,然后除以7算出一共有多少周即可。

#include <bits/stdc++.h> using namespace std; #define REP(i,n) for(int i=0;i<n;i++) #define FOR(i,a,b) for(int i=a;i<=b;i++) #define DOWN(i,b,a) for(int i=b;i>=a;i--) bool isLeap(int y){ return (y%400==0)||((y%100!=0)&&y%4==0); } //#define LOCAL int main(){ #ifdef LOCAL freopen("input.txt","r",stdin); //freopen("output.txt","w",stdout); #endif // LOCAL int day=0; FOR(i,1901,2000){ if(isLeap(i)) day+=366; else day+=365; } printf("%d",day/7); return 0; }
題目3
標題:乘積尾零如下的10行數據,每行有10個整數,請你求出它們的乘積的末尾有多少個零?
5650 4542 3554 473 946 4114 3871 9073 90 4329
2758 7949 6113 5659 5245 7432 3051 4434 6704 3594
9937 1173 6866 3397 4759 7557 3070 2287 1453 9899
1486 5722 3135 1170 4014 5510 5120 729 2880 9019
2049 698 4582 4346 4427 646 9742 7340 1230 7683
5693 7015 6887 7381 4172 4341 2909 2027 7355 5649
6701 6645 1671 5978 2704 9926 295 3125 3878 6785
2066 4247 4800 1578 6652 4616 1113 6205 3264 2915
3966 5291 2904 1285 2193 1428 2265 8730 9436 7074
689 5510 8243 6114 337 4096 8199 7313 3685 211注意:需要提交的是一個整數,表示末尾零的個數。不要填寫任何多余內容。
結果:31
如果將最終的乘積分解因數,末尾的零只能由 2 x 5 產生。 而2的個數遠遠比5多,所以我們只要統計 含有因數 5 的個數就可以啦。

#include <bits/stdc++.h> using namespace std; #define REP(i,n) for(int i=0;i<n;i++) #define FOR(i,a,b) for(int i=a;i<=b;i++) #define DOWN(i,b,a) for(int i=b;i>=a;i--) bool isLeap(int y){ return (y%400==0)||((y%100!=0)&&y%4==0); } #define LOCAL int main(){ #ifdef LOCAL freopen("input.txt","r",stdin); //freopen("output.txt","w",stdout); #endif // LOCAL int x; int cnt=0; while(scanf("%d",&x)!=EOF){ while(x%5==0){ x/=5; cnt++; } } printf("%d",cnt); return 0; }
題目4
標題:第幾個幸運數到x星球旅行的游客都被發給一個整數,作為游客編號。
x星的國王有個怪癖,他只喜歡數字3,5和7。
國王規定,游客的編號如果只含有因子:3,5,7,就可以獲得一份獎品。我們來看前10個幸運數字是:
3 5 7 9 15 21 25 27 35 45
因而第11個幸運數字是:49小明領到了一個幸運數字 59084709587505,他去領獎的時候,人家要求他准確地說出這是第幾個幸運數字,否則領不到獎品。
請你幫小明計算一下,59084709587505是第幾個幸運數字。
需要提交的是一個整數,請不要填寫任何多余內容。
結果:1905
遍歷一遍,統計可能比這個數小的“幸運數字”數量即可。

#include <bits/stdc++.h> using namespace std; #define REP(i,n) for(int i=0;i<n;i++) #define FOR(i,a,b) for(int i=a;i<=b;i++) #define DOWN(i,b,a) for(int i=b;i>=a;i--) #define ll long long ll getNum(int a,int b,int c){ ll num=1; REP(i,a)num*=3; REP(i,b)num*=5; REP(i,c)num*=7; return num; } #define LOCAL int main(){ #ifdef LOCAL freopen("input.txt","r",stdin); //freopen("output.txt","w",stdout); #endif // LOCAL ll x; scanf("%lld",&x); int a,b,c; a=b=c=0; while(x%3==0){ x/=3; a++; } while(x%5==0){ x/=5; b++; } while(x%7==0){ x/=7; c++; } x=getNum(a,b,c); int cnt=0; REP(i,a+2*(b+c)){ REP(j,a+b+2*c){ REP(k,a+b+c){ ll tmp=getNum(i,j,k); if(tmp>=3&&tmp<=x) cnt++; } } } printf("%d",cnt); return 0; }
題目5
標題:打印圖形如下的程序會在控制台繪制分形圖(就是整體與局部自相似的圖形)。
當n=1,2,3的時候,輸出如下:
請仔細分析程序,並填寫划線部分缺少的代碼。n=1時:
o
ooo
on=2時:
o
ooo
o
o o o
ooooooooo
o o o
o
ooo
on=3時:
o
ooo
o
o o o
ooooooooo
o o o
o
ooo
o
o o o
ooo ooo ooo
o o o
o o o o o o o o o
ooooooooooooooooooooooooooo
o o o o o o o o o
o o o
ooo ooo ooo
o o o
o
ooo
o
o o o
ooooooooo
o o o
o
ooo
o源程序:
#include <stdio.h>
#include <stdlib.h>void show(char* buf, int w){
int i,j;
for(i=0; i<w; i++){
for(j=0; j<w; j++){
printf("%c", buf[i*w+j]==0? ' ' : 'o');
}
printf("\n");
}
}void draw(char* buf, int w, int x, int y, int size){
if(size==1){
buf[y*w+x] = 1;
return;
}
int n = _________________________ ; //填空
draw(buf, w, x, y, n);
draw(buf, w, x-n, y ,n);
draw(buf, w, x+n, y ,n);
draw(buf, w, x, y-n ,n);
draw(buf, w, x, y+n ,n);
}int main()
{
int N = 3;
int t = 1;
int i;
for(i=0; i<N; i++) t *= 3;
char* buf = (char*)malloc(t*t);
for(i=0; i<t*t; i++) buf[i] = 0;
draw(buf, t, t/2, t/2, t);
show(buf, t);
free(buf);
return 0;
}
注意:只提交划線部分缺少的代碼,不要抄寫任何已經存在的代碼或符號。
結果:size/3
題目6
標題:航班時間【問題背景】
小h前往美國參加了藍橋杯國際賽。小h的女朋友發現小h上午十點出發,上午十二點到達美國,於是感嘆到“現在飛機飛得真快,兩小時就能到美國了”。小h對超音速飛行感到十分恐懼。仔細觀察后發現飛機的起降時間都是當地時間。由於北京和美國東部有12小時時差,故飛機總共需要14小時的飛行時間。
不久后小h的女朋友去中東交換。小h並不知道中東與北京的時差。但是小h得到了女朋友來回航班的起降時間。小h想知道女朋友的航班飛行時間是多少。
【問題描述】
對於一個可能跨時區的航班,給定來回程的起降時間。假設飛機來回飛行時間相同,求飛機的飛行時間。【輸入格式】
從標准輸入讀入數據。
一個輸入包含多組數據。輸入第一行為一個正整數T,表示輸入數據組數。
每組數據包含兩行,第一行為去程的 起降 時間,第二行為回程的 起降 時間。
起降時間的格式如下h1:m1:s1 h2:m2:s2
或
h1:m1:s1 h3:m3:s3 (+1)
或
h1:m1:s1 h4:m4:s4 (+2)
表示該航班在當地時間h1時m1分s1秒起飛,第一種格式表示在當地時間 當日 h2時m2分s2秒降落
第二種格式表示在當地時間 次日 h3時m3分s3秒降落。
第三種格式表示在當地時間 第三天 h4時m4分s4秒降落。對於此題目中的所有以 h:m:s 形式給出的時間, 保證 ( 0<=h<=23, 0<=m,s<=59 ).
【輸出格式】
輸出到標准輸出。對於每一組數據輸出一行一個時間hh:mm:ss,表示飛行時間為hh小時mm分ss秒。
注意,當時間為一位數時,要補齊前導零。如三小時四分五秒應寫為03:04:05。【樣例輸入】
3
17:48:19 21:57:24
11:05:18 15:14:23
17:21:07 00:31:46 (+1)
23:02:41 16:13:20 (+1)
10:19:19 20:41:24
22:19:04 16:41:09 (+1)【樣例輸出】
04:09:05
12:10:39
14:22:05【限制與約定】
保證輸入時間合法,飛行時間不超過24小時。
資源約定:
峰值內存消耗(含虛擬機) < 256M
CPU消耗 < 1000ms
請嚴格按要求輸出,不要畫蛇添足地打印類似:“請您輸入...” 的多余內容。注意:
main函數需要返回0;
只使用ANSI C/ANSI C++ 標准;
不要調用依賴於編譯環境或操作系統的特殊函數。
所有依賴的函數必須明確地在源文件中 #include <xxx>
不能通過工程設置而省略常用頭文件。提交程序時,注意選擇所期望的語言類型和編譯器類型。
題目7
標題:三體攻擊【題目描述】
三體人將對地球發起攻擊。為了抵御攻擊,地球人派出了 A × B × C 艘戰艦,在太空中排成一個 A 層 B 行 C 列的立方體。其中,第 i 層第 j 行第 k 列的戰艦(記為戰艦 (i, j, k))的生命值為 d(i, j, k)。三體人將會對地球發起 m 輪“立方體攻擊”,每次攻擊會對一個小立方體中的所有戰艦都造成相同的傷害。具體地,第 t 輪攻擊用 7 個參數 lat, rat, lbt, rbt, lct, rct, ht 描述;
所有滿足 i ∈ [lat, rat],j ∈ [lbt, rbt],k ∈ [lct, rct] 的戰艦 (i, j, k) 會受到 ht 的傷害。如果一個戰艦累計受到的總傷害超過其防御力,那么這個戰艦會爆炸。地球指揮官希望你能告訴他,第一艘爆炸的戰艦是在哪一輪攻擊后爆炸的。
【輸入格式】
從標准輸入讀入數據。第一行包括 4 個正整數 A, B, C, m;
第二行包含 A × B × C 個整數,其中第 ((i − 1)×B + (j − 1)) × C + (k − 1)+1 個數為 d(i, j, k);
第 3 到第 m + 2 行中,第 (t − 2) 行包含 7 個正整數 lat, rat, lbt, rbt, lct, rct, ht。【輸出格式】
輸出到標准輸出。輸出第一個爆炸的戰艦是在哪一輪攻擊后爆炸的。保證一定存在這樣的戰艦。
【樣例輸入】
2 2 2 3
1 1 1 1 1 1 1 1
1 2 1 2 1 1 1
1 1 1 2 1 2 1
1 1 1 1 1 1 2【樣例輸出】
2【樣例解釋】
在第 2 輪攻擊后,戰艦 (1,1,1) 總共受到了 2 點傷害,超出其防御力導致爆炸。【數據約定】
對於 10% 的數據,B = C = 1;
對於 20% 的數據,C = 1;
對於 40% 的數據,A × B × C, m ≤ 10, 000;
對於 70% 的數據,A, B, C ≤ 200;
對於所有數據,A × B × C ≤ 10^6, m ≤ 10^6, 0 ≤ d(i, j, k), ht ≤ 10^9。
資源約定:
峰值內存消耗(含虛擬機) < 256M
CPU消耗 < 2000ms
請嚴格按要求輸出,不要畫蛇添足地打印類似:“請您輸入...” 的多余內容。注意:
main函數需要返回0;
只使用ANSI C/ANSI C++ 標准;
不要調用依賴於編譯環境或操作系統的特殊函數。
所有依賴的函數必須明確地在源文件中 #include <xxx>
不能通過工程設置而省略常用頭文件。提交程序時,注意選擇所期望的語言類型和編譯器類型。
題目8
標題:全球變暖
【題目描述】
你有一張某海域NxN像素的照片,"."表示海洋、"#"表示陸地,如下所示:.......
.##....
.##....
....##.
..####.
...###.
.......其中"上下左右"四個方向上連在一起的一片陸地組成一座島嶼。例如上圖就有2座島嶼。
由於全球變暖導致了海面上升,科學家預測未來幾十年,島嶼邊緣一個像素的范圍會被海水淹沒。具體來說如果一塊陸地像素與海洋相鄰(上下左右四個相鄰像素中有海洋),它就會被淹沒。
例如上圖中的海域未來會變成如下樣子:
.......
.......
.......
.......
....#..
.......
.......請你計算:依照科學家的預測,照片中有多少島嶼會被完全淹沒。
【輸入格式】
第一行包含一個整數N。 (1 <= N <= 1000)
以下N行N列代表一張海域照片。照片保證第1行、第1列、第N行、第N列的像素都是海洋。
【輸出格式】
一個整數表示答案。【樣例輸入】
7
.......
.##....
.##....
....##.
..####.
...###.
.......【樣例輸出】
1
資源約定:
峰值內存消耗(含虛擬機) < 256M
CPU消耗 < 1000ms
請嚴格按要求輸出,不要畫蛇添足地打印類似:“請您輸入...” 的多余內容。注意:
main函數需要返回0;
只使用ANSI C/ANSI C++ 標准;
不要調用依賴於編譯環境或操作系統的特殊函數。
所有依賴的函數必須明確地在源文件中 #include <xxx>
不能通過工程設置而省略常用頭文件。提交程序時,注意選擇所期望的語言類型和編譯器類型。
題目9
標題:倍數問題【題目描述】
眾所周知,小蔥同學擅長計算,尤其擅長計算一個數是否是另外一個數的倍數。但小蔥只擅長兩個數的情況,當有很多個數之后就會比較苦惱。現在小蔥給了你 n 個數,希望你從這 n 個數中找到三個數,使得這三個數的和是 K 的倍數,且這個和最大。數據保證一定有解。【輸入格式】
從標准輸入讀入數據。第一行包括 2 個正整數 n, K。
第二行 n 個正整數,代表給定的 n 個數。【輸出格式】
輸出到標准輸出。
輸出一行一個整數代表所求的和。【樣例入】
4 3
1 2 3 4【樣例輸出】
9【樣例解釋】
選擇2、3、4。【數據約定】
對於 30% 的數據,n <= 100。
對於 60% 的數據,n <= 1000。
對於另外 20% 的數據,K <= 10。
對於 100% 的數據,1 <= n <= 10^5, 1 <= K <= 10^3,給定的 n 個數均不超過 10^8。
資源約定:
峰值內存消耗(含虛擬機) < 256M
CPU消耗 < 1000ms
請嚴格按要求輸出,不要畫蛇添足地打印類似:“請您輸入...” 的多余內容。注意:
main函數需要返回0;
只使用ANSI C/ANSI C++ 標准;
不要調用依賴於編譯環境或操作系統的特殊函數。
所有依賴的函數必須明確地在源文件中 #include <xxx>
不能通過工程設置而省略常用頭文件。提交程序時,注意選擇所期望的語言類型和編譯器類型。
題目10
標題:付賬問題【題目描述】
幾個人一起出去吃飯是常有的事。但在結帳的時候,常常會出現一些爭執。現在有 n 個人出去吃飯,他們總共消費了 S 元。其中第 i 個人帶了 ai 元。幸運的是,所有人帶的錢的總數是足夠付賬的,但現在問題來了:每個人分別要出多少錢呢?
為了公平起見,我們希望在總付錢量恰好為 S 的前提下,最后每個人付的錢的標准差最小。這里我們約定,每個人支付的錢數可以是任意非負實數,即可以不是1分錢的整數倍。你需要輸出最小的標准差是多少。
標准差的介紹:標准差是多個數與它們平均數差值的平方平均數,一般用於刻畫這些數之間的“偏差有多大”。形式化地說,設第 i 個人付的錢為 bi 元,那么標准差為 : [參見p1.png]
【輸入格式】
從標准輸入讀入數據。第一行包含兩個整數 n、S;
第二行包含 n 個非負整數 a1, ..., an。【輸出格式】
輸出到標准輸出。輸出最小的標准差,四舍五入保留 4 位小數。
保證正確答案在加上或減去 10^−9 后不會導致四舍五入的結果發生變化。【樣例1輸入】
5 2333
666 666 666 666 666【樣例輸出】
0.0000【樣例解釋】
每個人都出 2333/5 元,標准差為 0。再比如:
【樣例輸入】
10 30
2 1 4 7 4 8 3 6 4 7【樣例輸出】
0.7928【數據說明】
對於 10% 的數據,所有 ai 相等;
對於 30% 的數據,所有非 0 的 ai 相等;
對於 60% 的數據,n ≤ 1000;
對於 80% 的數據,n ≤ 10^5;
對於所有數據,n ≤ 5 × 10^5, 0 ≤ ai ≤ 10^9。
資源約定:
峰值內存消耗(含虛擬機) < 256M
CPU消耗 < 1000ms
請嚴格按要求輸出,不要畫蛇添足地打印類似:“請您輸入...” 的多余內容。注意:
main函數需要返回0;
只使用ANSI C/ANSI C++ 標准;
不要調用依賴於編譯環境或操作系統的特殊函數。
所有依賴的函數必須明確地在源文件中 #include <xxx>
不能通過工程設置而省略常用頭文件。提交程序時,注意選擇所期望的語言類型和編譯器類型。
遞歸實現了一個... 精度可能會存在問題。據說可以直接貪心,更簡單。

#include <bits/stdc++.h> using namespace std; #define REP(i,n) for(int i=0;i<n;i++) #define FOR(i,a,b) for(int i=a;i<=b;i++) #define DOWN(i,b,a) for(int i=b;i>=a;i--) const int maxn = 5e5+10; int N,S; int a[maxn]; double QAQ(int *a,int n,double remain,double AVG){ double avg=remain/(double)n; double sqr_sum=0; REP(i,n){ if(a[i]<avg){ sqr_sum+=(a[i]-AVG)*(a[i]-AVG); remain-=a[i]; }else{ if(i==0){ REP(j,n){ sqr_sum+=(avg-AVG)*(avg-AVG); remain-=avg; } break; } else sqr_sum+=QAQ(a+i,n-i,remain,AVG);// break; } } return sqr_sum; } void TAT(){ REP(i,N){ scanf("%d",&a[i]); } sort(a,a+N); printf("%f\n",sqrt(QAQ(a,N,S,(double)S/(double)N)/N)); } #define LOCAL int main(){ #ifdef LOCAL freopen("input.txt","r",stdin); //freopen("output.txt","w",stdout); #endif // LOCAL while(scanf("%d %d",&N,&S)!=EOF){ TAT(); } return 0; }