打印指定月份的日历信息
(实现从键盘输入1900年之后的任意的某年、某月)
import java.util.*;
public class Demo02{
public static void main(String[] args){
//打印指定月份的日历信息(实现从键盘输入1900年之后的任意的某年、某月)
Scanner input =new Scanner(System.in);
int sj=input.nextInt();
int year=sj/100;int month=sj%100;
//当前年到1900之间年份
int rn=year-1900;
//当前年到1900之间闰年数
int t=rn/100*24+(rn/100-1)/4+rn%100/4;
//2000年为闰年,在两千年后计算闰年加上2000年
//if(rn>=100){t+=1;}
//计算该月的第一天为星期几
int num01 = 0;
switch (month-1) {
case 11:
num01 += 30;
case 10:
num01 += 31;
case 9:
num01 += 30;
case 8:
num01 += 31;
case 7:
num01 += 31;
case 6:
num01 += 30;
case 5:
num01 += 31;
case 4:
num01 += 30;
case 3:
num01 += 31;
case 2:
if(year % 4 == 0 && year % 100 != 0 || year % 400 == 0) {
num01 += 29;
}else {
num01 += 28;
}
case 1:
num01 += 31;
}
int week=(rn*365+t+num01+1)%7;
if(week==0){week=7;}
int x02=1;
int state01=0;
if((year%4==0&&year%100!=0)||year%400==0){state01=1;}
System.out.println("星期一\t"+"星期二\t"+"星期三\t"+"星期四\t"+"星期五\t"+"星期六\t"+"星期日\t");
for(int j=1;j<week;j++){
System.out.print(" \t");
}
for(int i=1;i<6;i++){
for(int j=1;j<8;j++){
System.out.print(x02+"\t");
if(i==1&&(x02+week-1)==7){
x02++;
break;
}
if(month==2&&((x02>27&&state01==0)||(x02>28&&state01==1))){
break;
}
if((month==1||month==3||month==5||month==7||month==8||month==10||month==12)&&x02>30){
break;
}
if((month==4||month==6||month==9||month==11)&&x02>29){break;}
x02++;
}
System.out.println();
}
}
}
有奖竞猜
随机出现一个电视的价格(2000-10000之间),用户去竞猜价格,如果在5次内猜对价格,便可获得此商品。
import java.util.*;
public class Demo03{
public static void main(String[] args){
Scanner input = new Scanner(System.in);
Random r =new Random();
double ran = r.nextDouble();
int money=(int)(ran*8000+2000);
System.out.println("正在随机生成电视机价格......"+"\n生成成功,请进行竞猜:"+money);
int i=1;
for( i=1;i<=5;i++){
System.out.println("请进行第"+i+"次竞猜:");
int a=input.nextInt();
if(a==money){
System.out.println("恭喜你获得4k大屏电视");break;
}else{
int t=5-i;
System.out.println("你没有猜对你还有"+t+"次机会");
}
}
if(i>5){
System.out.println("很可惜,你没有获得奖品,竞猜结束。");
}
}
}
求质数
输出1~1000以内质数(只能被1或本身整除的数)
import java.util.*;
public class Demo04{
public static void main(String[] args){
System.out.println("1~1000以内质数有:");
for(int m=1;m<1000;m++){
boolean flag=true;
for(int i=2;i<Math.sqrt(m);i++){
if(m%i==0){
flag=false;break;
}
}
if(flag){
System.out.print(m+",");
}
}
}
}
最大公约数和最小公倍数
输入两个数,求最大公约数和最小公倍数
import java.util.*;
public class Demo05{
public static void main(String[] args){
Scanner input =new Scanner(System.in);
System.out.print("请输入第一个数:");
int a=input.nextInt();
System.out.print("请输入第二个数:");
int b=input.nextInt();
int num01=a*b;
int t=1;
if(a<b){t=a;a=b;b=t;}
for(int i=0;t!=0;i++){
t=a%b;
a=b;
b=t;
}
t=num01/a;
System.out.print("最大公约数为:"+a+"最小公倍数为:"+t);
}
}
小结
在第一题日历打印的题目中制表的代码判断了很多时间,到最后写出来也觉得不够优化,感觉有点绕到自己,以后看到记得再思考思考。