主頁 > 資料庫 > 第十一屆藍橋杯第三場軟體類省賽 C++ B組 題解

第十一屆藍橋杯第三場軟體類省賽 C++ B組 題解

2020-10-20 23:30:41 資料庫

試題 A: 數青蛙

“一只青蛙一張嘴,兩只眼睛四條腿,兩只青蛙兩張嘴,四只眼睛八條腿,三只青蛙三張嘴,六只眼睛十二條腿,……二十只青蛙二十張嘴,四十只眼睛八十條腿,”

請問上面這段文字,如果完全不省略,全部寫出來,從 1 到 20 只青蛙,總共有多少個漢字,

約定:數字 2 單獨出現讀成 “兩”,在其他數里面讀成 “二”,例如 “十二”,10 讀作 “十”,11 讀作 “十一”,22 讀作 “二十二”,請只計算漢字的個數,標點符號不計算,

答案353

上限20只青蛙,腿最多80只,所以只需要考慮1~80的漢字個數即可.

個位數一位;11~19以及10的倍數兩位;其余情況三位

#include<iostream>
#include<string>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<cstdio>
using namespace std;
int n(int x){
	if(x<=10) return 1;
	if(x%10==0) return 2;
	if(x<20) return 2;
	return 3;
}
int main(){
	int sum = 0;
	for(int i = 1 ; i <=20 ; i ++){
		int a = i;
		int b = i + i;
		int c = i *4;
		sum += 10;
		sum += n(a)*2;
		sum+=n(b) + n(c);
	}
	cout<<sum<<endl;
	return 0;
}

試題 B: 互質


今年是 2020 年,今天是 10 月 18 日,
請問在 1 到 2020 中,有多少個數與 1018 互質,

答案:1008

因為是填空題,所以不需要考慮什么演算法,直接暴力試就可

#include<iostream>
#include<string>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<cstdio>
using namespace std;

int gcd2(int a,int b){
	return b==0?a:gcd(b,a%b);
}
int main(){
	int sum = 0;
	for(int i = 1 ; i <= 2020; i ++){
		if(gcd2(1018,i) == 1){
			sum ++;
		}
	}
	cout<< sum <<endl;
	return 0;
}

試題 C: 車牌

A 市的車牌由六位組成,其中前三位可能為數字 0 至 9,或者字母 A 至 F,每位有 16 種可能,后三位只能是數字 0 至 9,為了減少攀比,車牌中不能有連續三位是相同的字符,

例如,202020 是合法的車牌,AAA202 不是合法的車牌,因為前三個字母相同,

請問,A 市有多少個合法的車牌?

答案:3997440


總共情況為16*16*16*10*10*10

第一位第二位第三位字符一致,可以看做一位,有16種情況,第四位第五位第六位分別有10種情況

第一位16種情況,第二位第三位第四位一致,看做一位,有10種情況,第五位第六位分別有10種情況

第一位16種情況,第二位16種情況,第三第四第五位一致看做一位,有10種情況,第六位10種情況

第一位第二位第三位分別16種情況,第四位第五位第六位一致,看做一位,有10種情況

采用正難則反的思想,總數減去排除情況數,就是答案

#include<iostream>
#include<string>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<cstdio>
using namespace std;

int main(){
	int sum = 16*16*16*10*10*10;
	sum -= 16*10*10*10;
	sum -= 16*10*10*10;
	sum -= 16*16*10*10;
	sum -= 16*16*16*10;
	cout<<sum<<endl;
	return 0;
}

試題 D: Fibonacci 集合

小藍定義了一個 Fibonacci 集合 F,集合的元素如下定義:

1. 最小的 5 個 Fibonacci 數 1, 2, 3, 5, 8 屬于集合 F,

2. 如果一個元素 x 屬于 F,則 3x + 2、5x + 3 和 8x + 5 都屬于集合 F,

3. 其他元素都不屬于 F,

請問,這個集合中的第 2020 小元素的值是多少?

答案 41269

標準深搜題,數字要求也不大,暴力即可

從最小的五個數開始搜索,把搜索到的數字置一,然后再找地2020個置一的數字即可

#include<iostream>
#include<string>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<cstdio>
using namespace std;
int fx[100010];
bool is[100010];
void dfs(int n){
	if(n > 100000) return ;
	is[n] = true;
	dfs(n*3+2);
	dfs(n*5+3);
	dfs(n*8+5);
}
int main(){
	dfs(1);
	dfs(2);
	dfs(3);
	dfs(5);
	dfs(8);
	int sum = 0;
	for(int i = 1;i<=100010;i++){
		if(is[i]){
			sum ++;
			cout<< sum << " ge  = " << i<<endl;
			if(sum == 2020){
				break;
			}
		}
	}
	return 0;
}

試題 E: 上升子串

小藍有一個字母矩陣,他喜歡和小伙伴們在這個矩陣上玩一些游戲,今天,他打算玩找上升子串的游戲,游戲是合作性質的,小藍和小伙伴們首先要在矩陣中指定一個位置,然后從這個位置開始,向上下左右相鄰位置移動,移動必須滿足所到達位置上的字母比當前位置大,小藍和小伙伴們可以移動任意多次,也可以隨時停下來,這樣就找到了一個上升子串,只要子串在矩陣中的位置不同,就認為是不同的子串,

小藍想知道,一共可以找到多少個上升子串,小藍的矩陣很大,已經放在了試題目錄下面,叫 inc.txt,為了更清楚的

描述問題,他還找了一個很小的矩陣用來解釋,

例如,對于矩陣:

AB
BC

可以找到 4 個長度為 1 的上升子串、4 個長度為 2 的上升子串、2 個長度

為 3 的上升子串,共 10 個,

現在,請你對于小藍的大矩陣,找到上升子串的數量,

答案未知

這題暴力過不去,比賽的時候跑了兩個多小時,還在跑......

#include<iostream>
#include<string>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<cstdio>
#include<queue>
using namespace std;
char a[102][102];
int sum;
struct mu{
	int x;
	int y;
	char maxChar;
	mu(int xx,int yy,char z){
		x = xx;
		y = yy;
		maxChar = z;
	}
};
bool check(int x){
	if(x<0 || x >= 100) return false;
	return true;
}
void bfs(int x,int y){
	queue<mu> q;
	q.push(mu(x,y,a[x][y]));
	while(!q.empty()){
		mu mm = q.front();
		sum ++;
		cout<<sum<<endl;
		q.pop();
		if(check(mm.x - 1) && mm.maxChar < a[mm.x - 1][mm.y]){
			mu m2 = mu(mm.x - 1,mm.y,a[mm.x - 1][mm.y]);
			q.push(m2);
		}
		if(check(mm.x + 1) && mm.maxChar < a[mm.x + 1][mm.y]){
			mu m3 = mu(mm.x + 1,mm.y,a[mm.x + 1][mm.y]);
			q.push(m3);
		}
		if(check(mm.y + 1) && mm.maxChar < a[mm.x][mm.y + 1]){
			mu m4 = mu(mm.x,mm.y + 1,a[mm.x][mm.y + 1]);
			q.push(m4);
		}
		if(check(mm.y - 1) && mm.maxChar < a[mm.x][mm.y - 1]){
			mu m5 = mu(mm.x,mm.y - 1,a[mm.x][mm.y - 1]);
			q.push(m5);
		}
	}
}
int main(){
	sum = 0;
	for(int i = 0 ; i < 100;i++){
		cin>>a[i];
	}
	for(int i = 0 ; i < 100;i++){
		for(int j = 0 ; j < 100 ; j ++){
			bfs(i,j);
		}
	}
	cout<<sum<<endl;
	return 0;
}

試題 F: 日期識別

小藍要處理非常多的資料,其中有一些資料是日期,在小藍處理的日期中有兩種常用的形式:英文形式和數字形式,英文形式采用每個月的英文的前三個字母作為月份標識,后面跟兩位數字表示日期,月份標識第一個字母大寫,后兩個字母小寫,日期小于 10 時要補前導 0,1 月到 12 月英文的前三個字母分別是 Jan、Feb、Mar、Apr、May、Jun、Jul、Aug、Sep、Oct、Nov、Dec,數字形式直接用兩個整數表達,中間用一個空格分隔,兩個整數都不寫前導 0,其中月份用 1 至 12 分別表示 1 月到 12 月,

輸入一個日期的英文形式,請輸出它的數字形式,

【樣例輸入】
Feb08
【樣例輸出】
2 8
【樣例輸入】
Oct18
【樣例輸出】
10 18

話不多說,暴力

#include<iostream>
#include<string>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<cstdio>
using namespace std;
void run(string s){
	if(s[0] == 'J' && s[1] == 'a' && s[2] == 'n'){
		printf("1 ");
	}
	else if(s[0] == 'F' && s[1] == 'e' && s[2] == 'b'){
		printf("2 ");
	}
	else if(s[0] == 'M' && s[1] == 'a' && s[2] == 'r'){
		printf("3 ");
	}
	else if(s[0] == 'A' && s[1] == 'p' && s[2] == 'r'){
		printf("4 ");
	}
	else if(s[0] == 'M' && s[1] == 'a' && s[2] == 'y'){
		printf("5 ");
	}
	else if(s[0] == 'J' && s[1] == 'u' && s[2] == 'n'){
		printf("6 ");
	}
	else if(s[0] == 'J' && s[1] == 'u' && s[2] == 'l'){
		printf("7 ");
	}
	else if(s[0] == 'A' && s[1] == 'u' && s[2] == 'g'){
		printf("8 ");
	}
	else if(s[0] == 'S' && s[1] == 'e' && s[2] == 'p'){
		printf("9 ");
	}
	else if(s[0] == 'O' && s[1] == 'c' && s[2] == 't'){
		printf("10 ");
	}
	else if(s[0] == 'N' && s[1] == 'o' && s[2] == 'v'){
		printf("11 ");
	}
	else if(s[0] == 'D' && s[1] == 'e' && s[2] == 'c'){
		printf("12 ");
	}
	if(s[3] != '0'){
		cout<<s[3];
	}
	cout<<s[4]<<endl;
}
int main(){
	string str;
	while(cin>>str){
		run(str);
	}
	return 0;
}

試題 G: 乘法表

九九乘法表是學習乘法時必須要掌握的,在不同進制數下,需要不同的乘
法表,
例如,四進制下的乘法表如下所示:

1*1=1
2*1=2 2*2=10
3*1=3 3*2=12 3*3=21


請注意,乘法表中兩個數相乘的順序必須為樣例中所示的順序,不能隨意
交換兩個乘數,
給定 P,請輸出 P 進制下的乘法表,

【輸入格式】
輸入一個整數 P,
【輸出格式】
輸出 P 進制下的乘法表,P 進制中大于等于 10 的數字用大寫字母 A、B、 C、· · · 表示,
【樣例輸入】
4
【樣例輸出】
1*1=1
2*1=2 2*2=10
3*1=3 3*2=12 3*3=21

【樣例輸入】
8
【樣例輸出】
1*1=1
2*1=2 2*2=4
3*1=3 3*2=6 3*3=11
4*1=4 4*2=10 4*3=14 4*4=20
5*1=5 5*2=12 5*3=17 5*4=24 5*5=31
6*1=6 6*2=14 6*3=22 6*4=30 6*5=36 6*6=44
7*1=7 7*2=16 7*3=25 7*4=34 7*5=43 7*6=52 7*7=61

【評測用例規模與約定】

對于所有評測資料,2 ≤ P ≤ 36,

使用堆疊進行進制轉換即可,注意10以上進制的需要輸出字符A-F

#include<iostream>
#include<string>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<cstdio>
#include<stack>
using namespace std;
void printNum(int num,int p){
	stack<int> s;
	while(num>0){
		s.push(num%p);
		num/=p;
	}
	while(!s.empty()){
		if(s.top() > 9){
			printf("%c",'A'+ s.top() - 10);
		}
		else{
			cout<<s.top();
		}
		s.pop();
	}
}
void run(int p){
	for(int i = 1 ; i < p ; i ++){
		for(int j = 1;j <= i;j ++){
			int sum = i * j;
			if(j!=1){
				printf(" ");
			}
			if(i > 9){
				printf("%c",'A'+i-10);
			}else{
				printf("%d", i);
			}
			printf("*");
			if(j > 9){
				printf("%c",'A'+j-10);
			}else{
				printf("%d", j);
			}
			printf("=");
			printNum(sum,p);
		}
		printf("\n");
	}
}
int main(){
	int p;
	while(cin>>p){
		run(p);
	}
	return 0;
}

試題 H: 限高桿

【問題描述】

某市有 n 個路口,有 m 段道路連接這些路口,組成了該市的公路系統,其中一段道路兩端一定連接兩個不同的路口,道路中間不會穿過路口,由于各種原因,在一部分道路的中間設定了一些限高桿,有限高桿的路段貨車無法通過,在該市有兩個重要的市場 A 和 B,分別在路口 1 和 n 附近,貨車從市場 A出發,首先走到路口 1 ,然后經過公路系統走到路口 n,才能到達市場 B,

兩個市場非常繁華,每天有很多貨車往返于兩個市場之間,市長發現,由于限高桿很多,導致貨車可能需要繞行才能往返于市場之間,這使得貨車在公路系統中的行駛路程變長,增加了對公路系統的損耗,增加了能源的消耗,同時還增加了環境污染,市長決定要將兩段道路中的限高桿拆除,使得市場 A 和市場 B 之間的路程變短,請問最多能減少多長的距離?

【輸入格式】


輸入的第一行包含兩個整數 n, m,分別表示路口的數量和道路的段數,
接下來 m 行,每行四個整數 a, b, c, d,表示路口 a 和路口 b 之間有一段長度為 c 的道路,如果 d 為 0,表示這段道路上沒有限高桿;如果 d 為 1,表示這段道路上有限高桿,兩個路口之間可能有多段道路,
輸入資料保證在不拆除限高桿的情況下,貨車能通過公路系統從路口 1 正常行駛到路口 n,

【輸出格式】
輸出一行,包含一個整數,表示拆除兩段道路的限高桿后,市場 A 和市場B 之間的路程最大減少多長距離,

【樣例輸入】
5 7
1 2 1 0
2 3 2 1
1 3 9 0
5 3 8 0
4 3 5 1
4 3 9 0
4 5 4 0
【樣例輸出】
6

【樣例說明】


只有兩段道路有限高桿,全部拆除后,1 到 n 的路程由原來的 17 變為了
11,減少了 6,


【評測用例規模與約定】


對于 30% 的評測樣例,2 ≤ n ≤ 10,1 ≤ m ≤ 20, 1 ≤ c ≤ 100,
對于 50% 的評測樣例,2 ≤ n ≤ 100,1 ≤ m ≤ 1000, 1 ≤ c ≤ 1000,
對于 70% 的評測樣例,2 ≤ n ≤ 1000,1 ≤ m ≤ 10000, 1 ≤ c ≤ 10000,
對于所有評測樣例,2 ≤ n ≤ 10000,2 ≤ m ≤ 100000, 1 ≤ c ≤ 10000,至少
有兩段道路有限高桿,

先計算不拆限高架的情況下,即d等于1的輸入資料,我們先保存起來,其中ganx保存起點,gany保存終點,ganLi保存距離

因為藍橋杯是閉卷考試,dijkstra演算法一下子想不起來了,所以使用了floyd演算法,暴力三層for回圈,找到每個點之間的最短路徑保存在li1陣列中,把1到n的最短路徑保存在 qianAns 中

然后再兩層for回圈遍歷限高的道路,使用li2臨時陣列復制li1的最短路資料,然后嘗試把兩個拆掉限高的路加進去,再求一遍最短路

多次遍歷完成,計算出最短值

相減就是答案,演算法非常差,但基礎樣例可以過

#include<iostream>
#include<string>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<cstdio>
#include<queue>
using namespace std;
int li1[10002][10002]; // qian
int li2[10002][10002]; // hou
int ganx[10002];
int gany[10002];
int ganLi[10002];
int main(){
	
	int n,m;
	
	while(cin>>n>>m){
		memset(li1,1,sizeof(li1));
		int ganGe = 0;
		for(int i = 0 ; i <= n ; i ++){
			li1[i][i] = 0;
		}
		for(int i = 0 ; i < m ; i ++){
			int a,b,c,d;
			scanf("%d%d%d%d",&a,&b,&c,&d);
			if(d == 0){
				if(li1[a][b] > c){
					li1[a][b] = c;
				}
				if(li1[b][a] > c){
					li1[b][a] = c;
				}
			}else{
				ganx[ganGe] = a;
				gany[ganGe] = b;
				ganLi[ganGe++] = c;
			}
		}
		for(int i = 1 ; i <= n ; i ++ ){
			for(int j = 1 ; j <= n ; j++ ){
				for(int k = 1 ; k <= n ; k ++ ){
					if(li1[i][j] > li1[i][k] + li1[k][j] ){
						li1[i][j] = li1[i][k] + li1[k][j];
					}
				}
			}
		}
		int qianAns = li1[1][n];
		int houAns = 99999;
		for(int g1 = 0 ; g1<ganGe ; g1 ++ ){
			for(int g2 = g1 + 1 ; g2 < ganGe ; g2++){
				for(int i = 1;i<=n;i++){
					for(int j = 1 ; j <= n ; j ++){
						li2[i][j] = li1[i][j];
					}
				}
				if(li2[ganx[g1]][gany[g1]] > ganLi[g1]){
					li2[ganx[g1]][gany[g1]] = ganLi[g1];
				}
				if(li2[gany[g1]][ganx[g1]] > ganLi[g1]){
					li2[gany[g1]][ganx[g1]] = ganLi[g1];
				}
				if(li2[ganx[g2]][gany[g2]] > ganLi[g2]){
					li2[ganx[g2]][gany[g2]] = ganLi[g2];
				}
				if(li2[gany[g2]][ganx[g2]] > ganLi[g2]){
					li2[gany[g2]][ganx[g2]] = ganLi[g2];
				}
				for(int i = 1 ; i <= n ; i ++ ){
					for(int j = 1 ; j <= n ; j++ ){
						for(int k = 1 ; k <= n ; k ++ ){
							if(li2[i][j] > li2[i][k] + li2[k][j] ){
								li2[i][j] = li2[i][k] + li2[k][j];
							}
						}
					}
				}
				if(li2[1][n] < houAns){
					houAns = li2[1][n];
				}
			}
		}
		
		// cout<<qianAns << endl;
		// cout<<houAns<<endl;
		cout<<qianAns - houAns<<endl;
	}
	return 0;
}

試題 I: 畫中漂流

【問題描述】

在夢境中,你踏上了一只木筏,在江上漂流,根據對當地的了解,你知道在你下游 D 米處有一個峽谷,如果你向下游前
進大于等于 D 米則必死無疑,現在你打響了急救電話,T 秒后救援隊會到達并將你救上岸,水流速度是1 m/s,你現在有 M 點體力,每消耗一點體力,你可以劃一秒槳使船向上游前進 1m,否則會向下游前進 1m (水流),M 點體力需在救援隊趕來前花光,因為江面太寬了,憑借你自己的力量不可能上岸,請問,有多少種劃槳的方案可以讓你得救,

兩個劃槳方案不同是指:存在某一秒鐘,一個方案劃槳,另一個方案不劃,

【輸入格式】

輸入一行包含三個整數 D, T, M,


【輸出格式】
輸出一個整數,表示可以讓你得救的總方案數,答案可能很大,請輸出方
案數除以 1, 000, 000, 007 的余數,

【樣例輸入】
1 6 3
【樣例輸出】
5


【評測用例規模與約定】

對于 50% 的評測用例,1 ≤ T ≤ 350,
對于所有評測用例,1 ≤ T ≤ 3000, 1 ≤ D ≤ T, 1 ≤ M ≤ 1500,

我運用了廣搜,結構體的weizhi是相對于起點的位置,tili為當前還剩下的體力,time是當前剩余的時間

注意題目要求,必須在救援隊來之前把體力用完,如果沒用完,不計數

#include<iostream>
#include<string>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<cstdio>
#include<queue>
using namespace std;
struct mu{
	int weizhi;
	int tili;
	int time;
	mu(int x,int y,int z){
		weizhi = x;
		tili = y;
		time = z;
	}
};
void bfs(int d,int t,int m){
	int ans = 0;
	d = -d;
	queue<mu> q;
	q.push(mu(0,m,t));
	while(!q.empty()){
		mu mm = q.front();
		if(mm.weizhi <= d){ // si
			q.pop();
			continue;
		}
		if(mm.tili == 0 && mm.time == 0){
			ans ++;
		}
		if(mm.time <= 0){
			q.pop();
			continue;
		}
		if(mm.tili > 0){ // up
			mu m1 = mu(mm.weizhi + 1,mm.tili -1 , mm.time - 1);
			q.push(m1);
		}
		// down
		mu m2 = mu(mm.weizhi - 1,mm.tili , mm.time - 1);
		q.push(m2);
		q.pop();
	}
	cout<<ans<<endl;
}
int main(){
	int d,t,m;
	while(cin>>d>>t>>m){
		bfs(d,t,m);
	}
	return 0;
}

試題 J: 旅行家


【問題描述】

從前,在海上有 n 個島嶼,編號 1 至 n,居民們深受洋流困擾,無法到達比自己當前所在島嶼編號更小的島嶼,經過數年以后,島嶼上的人數隨著島嶼的編號遞增(可能相等),作為一名出色的旅行家(RP 學家),你想從 1 號島嶼出發開啟一次旅程,以獲得更多的 RP,因為受到海洋的洋流影響,你只能去到比當前島嶼編號更大的島嶼,因為你比較善良,你會在離開一個島嶼的時候將你的 RP 分散給島民,具體的:你的 RP 會除以 2(用去尾法取整,或者說向零取整)(當你的 RP 小于零時,島民也依舊要幫你分擔,畢竟你們已經建立起了深厚的友誼),第 i 號島嶼有 Ti 人, 但是你很挑剔,每次你從 j 號島嶼到達 i 號島嶼時,你只會在到達的島嶼上做 Ti × T j 件好事(一件好事可以獲得 1 點 RP),

唯一不足的是,由于你在島上住宿,勞民傷財,你會扣除巨量 RP,第 i 號島嶼的住宿扣除 Fi 點 RP,注意:將離開一個島嶼時,先將 RP 扣除一半,再扣除住宿的 RP,最后在新到達的島嶼上做好事,增加 RP,離開 1 號島嶼時需要扣除在 1 號島嶼住宿的 RP,當到達這段旅程的最后一個島嶼上時,要做完好事,行程才能結束,也就是說不用扣除在最后到達的島嶼上住宿的 RP,你因為熱愛旅行 (RP),所以從 1 號島嶼開始旅行,初始時你有 0 點 RP,

你希望選擇一些島嶼經過,最終選擇一個島嶼停下來,求最大的 RP 值是多少?

【輸入格式】

輸入的第一行包含一個數 n , 表示島嶼的總數,

第二行包含 n 個整數 T1, T2, · · · , Tn , 表示每個島嶼的人口數,

第三行包含 n 個整數 F1, F2, · · · , Fn , 表示每個島嶼旅館損失的 RP,

【輸出格式】

輸出一個數,表示最大獲得的 RP 值,

【樣例輸入】
3
4 4 5
1 10 3
【樣例輸出】
19

【樣例說明】

從一號島嶼直接走到三號島嶼最優,初始 0 點 RP,扣除一半取整變成 0點,扣除在一號節點住宿的 1 RP,在三號島嶼做好事產生 4 × 5 = 20 點 RP,最終得到 19 點 RP,

【樣例輸入】
5
969 980 1013 1016 1021
888423 945460 865822 896150 946615
【樣例輸出】
246172


【評測用例規模與約定】

對于 20% 的評測用例,1 ≤ n ≤ 15;
對于 70% 的評測用例,1 ≤ n ≤ 5000;
對于所有評測用例,1 ≤ n ≤ 500000, 1 ≤ Ti ≤ 20000, 1 ≤ Fi ≤ 200, 000, 000,
給定的 Ti 已經按照升序排序,建議使用 64 位有符號整數進行運算,

我是完全模擬題目的思路寫得代碼,注意n等于1的時候需要特判

#include<iostream>
#include<string>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<cstdio>
#include<queue>
using namespace std;
long long a[500010];
long long b[500010];
int n;
long long maxRp;
void dfs(long long rp,int index,long long qianRen){
	// ting
	if(index +1 > n) return ;
	if(rp + qianRen * a[index + 1] > maxRp){
		maxRp = rp + qianRen * a[index + 1];
	}
	dfs((rp + qianRen * a[index + 1])/2 - b[index + 1],index + 1,a[index + 1]);
	//buting
	dfs(rp,index+1,qianRen);
}
int main(){
	while(cin>>n){
		
		for(int i = 1 ; i <= n ; i ++){
			scanf("%lld",&a[i]);
		}
		for(int i = 1 ; i <= n ; i ++){
			scanf("%lld",&b[i]);
		}
		if(n == 1) {
			cout<<"0"<<endl;
		}else{
			maxRp = -b[1];
			dfs(-b[1],1,a[1]);
			cout << maxRp << endl;
		}
	}
	return 0;
}

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/182964.html

標籤:其他

上一篇:2020第十一屆藍橋杯真題JAVA B組省賽答案分享(2020.10.17)

下一篇:廣東工業大學2020級年ACM第一次月賽

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:33:24 more
  • MySQL中binlog備份腳本分享

    關于MySQL的二進制日志(binlog),我們都知道二進制日志(binlog)非常重要,尤其當你需要point to point災難恢復的時侯,所以我們要對其進行備份。關于二進制日志(binlog)的備份,可以基于flush logs方式先切換binlog,然后拷貝&壓縮到到遠程服務器或本地服務器 ......

    uj5u.com 2023-04-20 08:28:06 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:27:27 more
  • 快取與資料庫雙寫一致性幾種策略分析

    本文將對幾種快取與資料庫保證資料一致性的使用方式進行分析。為保證高并發性能,以下分析場景不考慮執行的原子性及加鎖等強一致性要求的場景,僅追求最終一致性。 ......

    uj5u.com 2023-04-20 08:26:48 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:26:35 more
  • 云時代,MySQL到ClickHouse資料同步產品對比推薦

    ClickHouse 在執行分析查詢時的速度優勢很好的彌補了MySQL的不足,但是對于很多開發者和DBA來說,如何將MySQL穩定、高效、簡單的同步到 ClickHouse 卻很困難。本文對比了 NineData、MaterializeMySQL(ClickHouse自帶)、Bifrost 三款產品... ......

    uj5u.com 2023-04-20 08:26:29 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:25:13 more
  • Redis 報”OutOfDirectMemoryError“(堆外記憶體溢位)

    Redis 報錯“OutOfDirectMemoryError(堆外記憶體溢位) ”問題如下: 一、報錯資訊: 使用 Redis 的業務介面 ,產生 OutOfDirectMemoryError(堆外記憶體溢位),如圖: 格式化后的報錯資訊: { "timestamp": "2023-04-17 22: ......

    uj5u.com 2023-04-20 08:24:54 more
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:24:03 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:23:11 more