當前位置:才華齋>IT認證>SUN認證>

2017年java模擬試題

SUN認證 閱讀(2.08W)

Java引進虛擬機器 原理,並運行於虛擬機器,實現不同平臺的Java介面之間。使用Java編寫的程式能在世界範圍內共享。下面是小編收集的關於java模擬試題,希望大家認真閱讀!

2017年java模擬試題

1. 程式碼填空(滿分3分)

以下程式打印出0~9的數字,請補充缺少的程式碼。

public class MyTest

{

public static void f(int begin, int end)

{ if(begin>end) return;

tln(begin);

f(begin+1, end);

}

public static void main(String[] args)

{

f(0,9);

}

}

2. 程式碼填空(滿分4分)

如果要把兩個整型變數a、b的值交換,一般要採用一箇中間變數做過渡,但也可以在不借助任何其它變數的情況下完成。試填寫缺失的程式碼。

a = a ^ b;

b = ___a ^ b______;

a = ___a ^ b______;

3. 程式碼填空(滿分3分)

許多人都曾經玩過“拍七”遊戲。規則是:大家依次從1開始順序數數,數到含有7或7的倍數的要拍手或其它規定的方式表示越過(比如:7,14,17等都不能數出),下一人繼續數下面的數字。違反規則者受罰。下面的程式模擬這個過程,拍7的情況輸出“*”,請完善之。

for(int i=1; i<100; i++)

{

if(i % 7 == 0)

printf("*/n");

else if(____i/10==7||i%10==7_______________)

printf("*/n");

else

printf("%d/n", i);

}

4. 程式碼填空(滿分5分)

下面的靜態方法的目的是求出某個日期是該年度的第幾天。試完善之。

如果傳入:year=1980,month=1, day=1

則返回 1

如果傳入:year=1980,month=2, day=1

則返回 32

public static int getDayOfYear(int year, int month, int day)

{

int [][]days=____new int[][]{{0,31,29,31,30,31,30,31,31,30,31,30,31},{0,31,28,31,30,31,30,31,31,30,31,30,31}}_________________;

int flag =(year%4==0 && year%100!=0) || year%400 == 0 ? 1 : 0;

int sum = day ;

for(int i=0;i

sum += days[flag][i];

}

return sum;

}

5. 程式碼填空(滿分2分)

下列方法的目的是,找出1~n之間所有的平方數。試補全缺失的程式碼。

當n=10時,輸出結果是:

1 4 9

當n=100時,輸出結果是:

1 4 9 16 25 36 49 64 81

public static void showSqure(int n)

{

for(int i=0; i

{

for(int j=1; j<=i; j++)

{

if(i==___j*j__________) t(i + " ");

}

}.

tln();

}

6. 程式碼填空(滿分9分)

(a+b)的n次冪的展開式中各項的係數很有規律,對於n=2,3,4時分別是:1 2 1, 1 3 3 1,1 4 6 4 1。這些係數構成了著名的楊輝三角形:

1

1 1

1 2 1

1 3 3 1

1 4 6 4 1

1 5 10 10 5 1

下列的'程式給出了計算第m層的第n個係數的計算方法,試完善之(m,n都從0算起)。

public static int f(int m, int n)

{

if(m==0) return 1;

if(n==0 || n==m) return 1;

return f(m-1, n-1)+f(m-1, n);

}

7. 程式碼填空(滿分4分)

下面的程式碼將陣列中的元素的位置顛倒過來:

比如:原來的元素是 [1,2,3]

則顛倒後變為:[3,2,1]

public static void reverse(int[] arrs)

{

for (int i = 0, j = th - 1; i <____j_____ ; i++, j--)

{

int temp = arrs[i];

arrs[i] = arrs[j];

arrs[j] = temp;

}

}

8. 程式設計(滿分15分)

從鍵盤輸入一個整數(1~20)

則以該數字為矩陣的大小,把1,2,3…n*n 的數字按照順時針螺旋的形式填入其中。例如:

輸入數字2,則程式輸出:

1 2

4 3

輸入數字3,則程式輸出:

1 2 3

8 9 4

7 6 5

輸入數字4, 則程式輸出:

1 2 3 4

12 13 14 5

11 16 15 6

10 9 8 7

import ner;

public class Test8 {

public static void main(String[] args) {

int num = 1;

int cirCle[][] = new int[20][20];

int inputNum;

int i, j, line, t;

tln("請輸入一個正整數");

Scanner in = new Scanner();

inputNum = Int();

line = inputNum;

for (t = 0; t < line; t++) {

for (i = t, j = t; j < inputNum - t; j++) {

cirCle[i][j] = num;

num++;

}

for (j = j - 1, i = i + 1; i < inputNum - t; i++) {

cirCle[i][j] = num;

num++;

}

for (j = j - 1, i = i - 1; j >= t; j--) {

cirCle[i][j] = num;

num++;

}

for (j = j + 1, i = i - 1; i > t; i--) {

cirCle[i][j] = num;

num++;

}

}

for (int m = 0; m < line; m++) {

for (int n = 0; n < line; n++) {

t(cirCle[m][n] + " ");

}

tln();

}

}

}

9. 程式設計(滿分9分)

從鍵盤輸入一個日期,格式為yyyy-M-d

要求計算該日期與1949年10月1日距離多少天

例如:

使用者輸入了:1949-10-2

程式輸出:1

使用者輸入了:1949-11-1

程式輸出:31

import eException;

import leDateFormat;

import ;

import ner;

public class Test {

public static void main(String[] args) {

SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd");

Date d = new Date();

String d1 = "1949-10-1";

Date a = new Date();

tln("請輸入一個日期以(YYYY-MM-DD)格式輸入:");

Scanner sc = new Scanner();

String s = Line();

try {

d = e(d1);

a = e(s);

} catch (ParseException e1) {

tStackTrace();

}

long x = ime() - ime();

tln(x / 1000 / (24 * 60 * 60));

}

}

10. 程式設計(滿分20分)

任意一個5位數,比如:34256,把它的各位數字打亂,重新排列,可以得到一個最大的數:65432,一個最小的數23456。求這兩個數字的差,得:41976,把這個數字再次重複上述過程(如果不足5位,則前邊補0)。如此往復,數字會落入某個迴圈圈(稱為數字黑洞)。

比如,剛才的數字會落入:[82962, 75933, 63954, 61974] 這個迴圈圈。

請編寫程式,找到5位數所有可能的迴圈圈,並輸出,每個迴圈圈佔1行。其中5位數全都相同則迴圈圈為 [0],這個可以不考慮。迴圈圈的輸出格式仿照:

[82962, 75933, 63954, 61974]

其中數字的先後順序可以不考慮。

import ys;

public class MyTest {

public static void main(String args[]) {

int f = Sort(array(34256));

int x = Sort(array(34256));

for (int i = 0; i < 4; i++) {

x = Sort(array(x));

t(x + " ");

}

}

static int[] array(int n) {

int a[] = new int[5];

int i = 0;

int m = n;

while (i < 5) {

a[i] = m % 10;

if (m % 10 == 0)

a[i] = 0;

m /= 10;

i++;

}

return a;

}

static int Sort(int a[]) {

(a);

String min = "";

for (int i = 0; i < 5; i++) {

min = min + eOf(a[i]);

}

int Min = eInt(min);

StringBuffer sb = new StringBuffer(min)rse();

String max = new StringBuffer(sb)ring();

int Max = eInt(max);

int c = Max - Min;

return c;

}

}