(1)编写一个程序,用for循环输入俄文的“字母表”。
public class Example10_29_1 {
public static void main(String[] args) {
int startPosition = 0,endPosition = 0;
char cStart = 'a',cEnd = 'я';
startPosition = (int)cStart;
endPosition = (int)cEnd;
System.out.println("俄文字母表: Total=" + (endPosition-startPosition + 1)+"个");
for (int i = startPosition;i <= endPosition;i++){
char c = '\0';
c= (char) i;
System.out.print(c + " ");
if((i - startPosition + 1) %1 == 0){
System.out.println();
}
}
}
}
(2)编写一个程序,求1!+2!+......+20!。
public class Example10_29_2 {
public static void main(String[] args) {
long a = 1;
long sum = 0;
for (int i=1; i<=20; i++) {
sum = sum + a;
a = a * i;
System.out.println(i + "!=" + a);
}
System.out.println("sum = " + sum);
int k=1;
a = 1;
while (k<=20) {
sum = sum + a;
a = a * k;
System.out.println(k + "!=" + a);
k++;
}
}
}
(3)编写一个程序,求一百以内的全部素数。
//编写一个程序求100以内的全部素数
public class Example10_29_4 {
public static void main(String[] srgs) {
int i = 2;
int k;
int j = 2;
for(i = 2;i <= 100;i++) {
k = (int)Math.sqrt(i);
for(j = 2;j <= k;j++)
if(i %j == 0)
break;
if(j > k) {
System.out.print(i+" ");
}
}
}
}
(4) 分别用while和for循环计算1+1/2!+1/3!+1/4!=...的前20项和。
//用while求...前二十项和
public class Example10_29_5 {
public static void main(String[] args) {
double sum=0,number=1;
for(int i=1;i<=20;i++) {
number= number*(1.0/i);
sum += number;
}
System.out.println("使用for循环计算的sum="+sum);
}
}
//用for...前二十项和
public class Example10_29_6 {
public static void main(String[] args) {
double sum = 0, number = 1, i = 1;
while (i <= 20) {
number = number * (1.0 / i);
sum = +number;
i++;
}
System.out.println("使用for循环计算的sum=" + sum);
}
}
(5)正整数number如果恰好等于他的因子(因子包括1,但不包括number本身—)之和,这个数就称为“完数“,编写一个应用程序,求1000以内的所有完数。
public class Example10_29_7 {
public static void main(String[] args) {
int n = 10000;
compNumber(n);
}
//求完数
private static void compNumber(int n) {
System.out.println(n + "以内的完数: ");
for (int i = 1;i < n + 1;i++) {
int sum = 0;
for (int j = 1;j < i/2 + 1;j++) {
if((i%j) == 0) {
sum +=j;
}
}
if(sum == i){
System.out.print(i + " ");
}
}
}
}
(6)编写完整程序,计算两个非零正整数的而最大公约数和最小公倍数,要求两个非零正整数从键盘输入。
import java.util.Scanner;
public class Example10_29_8 {
public static void main(String[] args) {
Scanner reader=new Scanner(System.in);
int a,b,i,j,k;
k=j=1;
a=reader.nextInt();
b=reader.nextInt();
for(i=2;i<=a&&i<=b;i++){
if(a%i==0&&b%i==0){
j=i;
}
}k=j*(a/j)*(b/j);
System.out.println(a+"与"+b+"的最大公约数是"+j);
System.out.println(a+"与"+b+"的最小公倍数是"+k);
}
}
(7)求满足1+2!+3!+...+n!≤9999的最大整数n。
public class Example10_29_9 {
public static void main(String[] aegs) {
int n,i;
int sum = 0;
int j=1;
for(n=1;sum<=9999;n++)
{
j=1;
for(i=1;1<=n;i++)
{
j=j*i;
}
if((sum = sum + j) < 9999)
{
continue;
}
else
{
n--;
System.out.println("求得满足1+2!+3!...n!<=9999的最大整数n为:"+n);
}
}
}
}