2019 藍橋杯省賽 B 組模擬賽(一)(Java)

結果填空:鐘錶

手動算一下

class Main {
    public static void main(String[] args) {
        System.out.println("07:55:41");
    }
}

結果填空:青蛙爬井

簡單的模擬

class Main {
    public static void main(String[] args) {
        System.out.println("863");
    }
}

結果填空:倍數

手動算,又快又準

class Main {
    public static void main(String[] args) {
        System.out.println("52573230519");
    }
}

結果填空:馬的管轄

二進制枚舉+搜索

class Main {
    public static void main(String[] args) {
        System.out.println("90");
    }
}

代碼填空:LIS

import java.util.*;
import java.math.*;

public class Main {
	public static final int N = (int)1e5 + 9;
	public static int n = 0;
	public static int[] f = new int[N];
	public static int[] a = new int[N];

	public static int find(int l, int r, int x) {
		while (l < r) {
			int mid = (l + r) / 2;
			if (f[mid] < x) {
				l = mid + 1;
			} else {
				r = mid;
			}
		}
		return l;
	}

	public static int lis() {
		int len = 0;
		for (int i = 0; i < n; i++) {
			int k = find(0, len, a[i]);
			f[k] = a[i];
			if (k == len) {
				len++;
			}
		}
		return len;
	}

	public static void main(String[] args) {
		Scanner cin = new Scanner(System.in);
		n = cin.nextInt();
		for (int i = 0; i < n; i++) {
			a[i] = cin.nextInt();
		}
		System.out.println(lis());
	}
}

程序設計:找質數

深刻懷疑這個題Java時限沒有拓寬,C++素數篩法一遍過了,Java優化了好多次還是隻能過60%。

//過60%
import java.util.*;
import java.math.*;
import java.io.*;

public class Main{
    public static void main(String[] args){
        Scanner cin = new Scanner(System.in);
        int maxn = 1000000 + 10;
        boolean[] a = new boolean[maxn];
        Arrays.fill(a, true);
        a[0] = a[1] = false;
        for(int i = 2; i * i < maxn; i++){
            if(a[i]){
                for(int j = 2; i * j < maxn; j++){
                    a[i*j] = false;
                }
            }
        }
        int[] p = new int[78555];
        int num = 0;
        for(int i = 2; i < maxn; i++){
            if(a[i]) p[num++] = i;
        }
        //System.out.println(num);
        int T = cin.nextInt();
        while(T-- > 0){
            int n = cin.nextInt();
            /*for(int i = 2; ; i++){
                if(a[i] && a[n-i]){
                    System.out.println(i + " " + (n-i));
                    break;
                }
            }*/
            for(int i = 0; i < num; i++){
                if(a[n-p[i]]){
                    System.out.println(p[i] + " " + (n-p[i]));
                    break;
                }
            }
        }
    }
}
//優化程度還沒有上述java的高,但是就是過了,玄學
#include<bits/stdc++.h>
using namespace std;
#define clr(a) memset(a, 0, sizeof(a))
#define line cout << "----------" << endl

typedef long long ll;
const int maxn = 1e5 + 10;
const int MAXN = 1e6 + 10;
const int INF = 0x3f3f3f3f;
const int MOD = 1e9 + 7;

bool p[MAXN];
void get_prime(){
	memset(p, true, sizeof(p));
	p[0] = p[1] = false;
	for(int i = 2; i*i < MAXN; i++){
		if(p[i]){
			for(int j = 2; i * j < MAXN; j++){
				p[i*j] = false;
			}
		}
	}
}

int main(int argc, char const *argv[]){
	get_prime();
	int T;
	scanf("%d", &T);
	while(T--){
		int n;
		scanf("%d", &n);
		for(int i = 2; ; i++){
			if(p[i] && p[n-i]){
				printf("%d %d\n", i, n-i);
				break;
			}
		}
	}
	return 0;
}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章