您的位置:首页 > 其它

蓝桥杯-基础练习-BASIC-1-5

2015-02-07 02:46 351 查看
BASIC-1.

蓝桥杯-基础练习 闰年判断



问题描述

给定一个年份,判断这一年是不是闰年。

当以下情况之一满足时,这一年是闰年:

1. 年份是4的倍数而不是100的倍数;

2. 年份是400的倍数。

其他的年份都不是闰年。

输入格式

输入包含一个整数y,表示当前的年份。

输出格式

输出一行,如果给定的年份是闰年,则输出yes,否则输出no。

import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int year = sc.nextInt();
		if(year%4==0||year%400==0)
			System.out.println("yes");
		else {
			System.out.println("no");
		}
	}
	
}


BASIC-2.

[b]蓝桥杯-基础练习
01字串 [/b]

问题描述

对于长度为5位的一个01串,每一位都可能是0或1,一共有32种可能。它们的前几个是:

00000

00001

00010

00011

00100

请按从小到大的顺序输出这32种01串。

输入格式

本试题没有输入。

输出格式

输出32行,按从小到大的顺序每行一个长度为5的01串。

样例输出

00000
00001
00010
00011
<以下部分省略>



public class Main {
	public static void main(String[] args) {
		for (int i = 0; i < 2; i++) {
			for (int j = 0; j < 2; j++) {
				for (int j2 = 0; j2 < 2; j2++) {
					for (int k = 0; k < 2; k++) {
						for (int k2 = 0; k2 < 2; k2++) {
							System.out.println(i+""+j+""+j2+""+k+""+k2);
						}
					}
				}
			}
		}
	}
}


BASIC-3.

[b]蓝桥杯-基础练习
字母图形 [/b]

问题描述

利用字母可以组成一些美丽的图形,下面给出了一个例子:

ABCDEFG

BABCDEF

CBABCDE

DCBABCD

EDCBABC

这是一个5行7列的图形,请找出这个图形的规律,并输出一个n行m列的图形。

输入格式

输入一行,包含两个整数n和m,分别表示你要输出的图形的行数的列数。

输出格式

输出n行,每个m个字符,为你的图形。

样例输入

5 7

样例输出

ABCDEFG

BABCDEF

CBABCDE

DCBABCD

EDCBABC


数据规模与约定

1 <= n, m <= 26。

import java.util.ArrayList;
import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int n = sc.nextInt();
		int m = sc.nextInt();
		ArrayList<Character> zimu = new ArrayList<>();
		for (int i = 0; i < n; i++) {
			zimu.clear();
			zimu.add(((char) ('A')));
			for (int j = 1; j < i+1; j++) {
				zimu.add(0, ((char) ('A' + j)));
			}
			for (int j = 1; j < m - i; j++) {
				zimu.add(((char) ('A' + j)));
			}
			for (int j = 0; j < m; j++) {
				System.out.print(zimu.get(j));
			}
			System.out.println();
		}
	}
}


BASIC-4.

[b]蓝桥杯-基础练习
数列特征 [/b]

问题描述

给出n个数,找出这n个数的最大值,最小值,和。

输入格式

第一行为整数n,表示数的个数。

第二行有n个数,为给定的n个数,每个数的绝对值都小于10000。

输出格式

输出三行,每行一个整数。第一行表示这些数中的最大值,第二行表示这些数中的最小值,第三行表示这些数的和。

样例输入

5

1 3 -2 4 5


样例输出

5

-2

11


数据规模与约定

1 <= n <= 10000。

import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int N = sc.nextInt();
		int[] n = new int
;
		int max,min,sum = 0;
		for (int i = 0; i < N; i++) {
			n[i] = sc.nextInt();
			sum += n[i];
		}
		max=n[0];
		min=n[0];
		if (N > 1) {
			for (int i = 1; i < N; i++) {
				if (n[i] > max) {
					max = n[i];
				} else if (n[i] < min) {
					min = n[i];
				}					
			}
		}
		System.out.println(max);
		System.out.println(min);
		System.out.println(sum);
	}
}


BASIC-5.

[b]蓝桥杯-基础练习
查找整数[/b]

问题描述

给出一个包含n个整数的数列,问整数a在数列中的第一次出现是第几个。

输入格式

第一行包含一个整数n。

第二行包含n个非负整数,为给定的数列,数列中的每个数都不大于10000。

第三行包含一个整数a,为待查找的数。

输出格式

如果a在数列中出现了,输出它第一次出现的位置(位置从1开始编号),否则输出-1。

样例输入

6

1 9 4 8 3 9

9


样例输出

2

数据规模与约定

1 <= n <= 1000。

import java.util.ArrayList;
import java.util.Scanner;

public class Main {
	public static void main(String[] args){
		Scanner sc = new Scanner(System.in);
		int N = sc.nextInt();
		ArrayList<Integer> Number = new ArrayList<>();
		for (int i = 0; i < N; i++) {
			Number.add(sc.nextInt());
		}
		int numtar = sc.nextInt();
		int temp = Number.indexOf(numtar)+1;
		if (temp==0) {
			temp=-1;
		}
		System.out.println(temp);
	}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: