1011 A+B 和 C (15 分)
给定区间 [−231,231] 内的 3 个整数 A、B 和 C,请判断 A+B 是否大于 C。
输入格式:
输入第 1 行给出正整数 T (≤10),是测试用例的个数。随后给出 T 组测试用例,每组占一行,顺序给出 A、B 和 C。整数间以空格分隔。
输出格式:
对每组测试用例,在一行中输出 Case #X: true
如果 A+B>C,否则输出 Case #X: false
,其中 X
是测试用例的编号(从 1 开始)。
输入样例:
4
1 2 3
2 3 4
2147483647 0 2147483646
0 -2147483648 -2147483647
输出样例:
Case #1: false
Case #2: true
Case #3: true
Case #4: false
package test1;
import java.math.*;
import java.util.*;
public class pat1011 {
public static void main(String[] args) {
Scanner in=new Scanner(System.in);
int n=in.nextInt();
String[] flag=new String[n];
for(int i=0;i<n;i++) {
BigInteger a=in.nextBigInteger();
BigInteger b=in.nextBigInteger();
BigInteger c=in.nextBigInteger();
BigInteger sum=a.add(b);
if(sum.compareTo(c)>0) {
flag[i]="ture";
}else {
flag[i]="false";
}
}
for(int i=0;i<n;i++) {
System.out.println("case #"+(i+1)+":"+flag[i]);
}
}
}
1012 数字分类 (20 分)
给定一系列正整数,请按要求对数字进行分类,并输出以下 5 个数字:
- A1 = 能被 5 整除的数字中所有偶数的和;
- A2 = 将被 5 除后余 1 的数字按给出顺序进行交错求和,即计算 n1−n2+n3−n4⋯;
- A3 = 被 5 除后余 2 的数字的个数;
- A4 = 被 5 除后余 3 的数字的平均数,精确到小数点后 1 位;
- A5 = 被 5 除后余 4 的数字中最大数字。
输入格式:
每个输入包含 1 个测试用例。每个测试用例先给出一个不超过 1000 的正整数 N,随后给出 N 个不超过 1000 的待分类的正整数。数字间以空格分隔。
输出格式:
对给定的 N 个正整数,按题目要求计算 A1~A5 并在一行中顺序输出。数字间以空格分隔,但行末不得有多余空格。
若其中某一类数字不存在,则在相应位置输出 N
。
输入样例 1:
13 1 2 3 4 5 6 7 8 9 10 20 16 18
输出样例 1:
30 11 2 9.7 9
输入样例 2:
8 1 2 4 5 6 7 9 16
输出样例 2:
N 11 2 N 9
import java.util.Scanner;
public class Main {
public static void fun1(int[] c){
int a1 = 0;
boolean b = false;
for(int i = 0;i<c.length;i++){
if(c[i]%10==0){
a1 = a1 + c[i];
b = true;
}
}
if(b){
System.out.print(a1+" ");
}
else{
System.out.print("N"+" ");
}
}
public static void fun2(int[] c){
int a2 = 0;
boolean b = false;
for(int i = 0,j = 0;i<c.length;i++){
if(c[i]%5==1){
b = true;
if(j%2==0){
a2=a2+c[i];
}
else{
a2=a2-c[i];
}
j++;
}
}
if(b){
System.out.print(a2+" ");
}
else{
System.out.print("N"+" ");
}
}
public static void fun3(int[] c){
int a3=0;
boolean b = false;
for(int i = 0;i<c.length;i++){
if(c[i]%5==2){
b = true;
a3++;
}
}
if(b){
System.out.print(a3+" ");
}
else{
System.out.print("N"+" ");
}
}
public static void fun4(int[] c){
float a4=0;
boolean b = false;
int j = 0;
for(int i=0;i<c.length;i++){
if(c[i]%5==3){
b = true;
j = j + 1;
a4= a4 + c[i];
}
}
if(a4!=0)
a4=a4/j;
if(b){
System.out.printf("%.1f ",a4);
}
else{
System.out.print("N"+" ");
}
}
public static void fun5(int[] c){
int a5=0;
boolean b = false;
for(int i = 0;i<c.length;i++){
if(c[i]%5==4){
b = true;
if(c[i]>a5){
a5 = c[i];
}
}
}
if(b){
System.out.print(a5);
}
else{
System.out.print("N");
}
}
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int n = in.nextInt();
int[] a = new int[n];
int a1=0,a2=0,a3=0,a5=0;
float a4=0;
for(int i = 0;i<n;i++){
a[i] = in.nextInt();
}
fun1(a);
fun2(a);
fun3(a);
fun4(a);
fun5(a);
}
}