1.(显示闰年)编写程序,显示从101到2100期间所有的闰年,每行显示10个。数字之间用一个空格字符隔开,同时显示这期间闰年的数目。
- 解题思路:我们先要知道什么是闰年,闰年就是可以被四整除但不可以被100整除,且可以被400整除的年份,所以我们可以在for循环里用if判断是否闰年
class Demo01{
public static void main(String[] args){
int count=0;
for(int i=101;i<=2100;i++){
if(i%4==0&&i%100!=0 || i%400==0){
count++;
System.out.print(i+" ");
if(count%10==0){
System.out.println();
}
}
}
System.out.println("\n闰年一共"+count+"个");
}
}
2.(完全数)如果一个正整数等于除它本身之外其他所有除数之和,就称之为完全数。例如: 6是第一个完全数,因为6=1+2+3。下一个完全数是28=14+7+4+2+1。10 000以下的完全数有四个。编写程序,找出这四个完全数。
- 解题思路:用for循环找出这个数字的所有除数然后再相加,并判断两者是否相等
class Demo02{
public static void main(String[] args){
int sum=0;
for(int n=2;n<=10000;n++){ //循环2到10000之间的数字
for(int i=1;i<=n/2;i++){ //循环这个数字的所有可能的除数
if(n%i==0){
sum+=i; //将这个数的除数相加
}
}
if(n==sum){ //判断除数之和是否和他相等
System.out.println("完全数"+n);
}
sum=0;
}
}
}
3.(十进制到二进制)编写程序,提示用户输入一个十进制整数,然后显示对应的二进制值。在这个程序中不要使用Java的Interger . toBinaryString(int)方法。
- 解题思路:先要清楚十进制如何转为二进制,无非就是一个2整除再求余再整除再求余直至整除为0为止,举例63:
import java.util.Scanner;
class Demo03{
public static void main(String[] args){
Scanner scanner=new Scanner(System.in);
System.out.print("请输入一个数字:");
int num=scanner.nextInt();
String binStr="";
while(true){
binStr=num%2+binStr;
num/=2;
if(num==0){
break;
}
}
System.out.println(binStr);
}
}
4.(最大数的出现次数)编写程序读取整数,找出它们的最大数,然后计算该数的出现次数。假设输人是以0结束的。假定输人是3 5 2 5 5 5 0,程序找出最大数5,而5出现的次数是4。提示:维护max和count两个变量。max 存储当前最大数,而count存储它的出现次数。初始状态时,将第一个数赋值给max而将count赋值为1。然后将接下来的每个数字逐个地和max进行比较。如果这个数大于max,就将它赋值给max,同时将count重置为1。如果这个数等于max,就给count加1。
import java.util.Scanner;
class Demo04{
public static void main(String[] args){
Scanner scanner=new Scanner(System.in);
int num=0;
int max=0;
int count=0;
System.out.print("请输入数字:");
while(true){
num=scanner.nextInt(); //将输入的值挨个赋给num
if(num==0){
break; //如果输入的值为0则停止循环
}else if(num>max){
max=num;
count=1;
}else if(num==max){
count++;
}
}
System.out.println("max="+max+",count="+count);
}
}