Java 学习(07)--面向对象常见问题
1.有5家衣服专卖店,每家最多购买3件。用户可以选择离开,可以买衣服。最后打印总共买了几件衣服。
代码:
//有5家衣服专卖店,每家最多购买3件。用户可以选择离开,可以买衣服。最后打印总共买了几件衣服。 import java.util.Scanner; public class BuyClothes{ private static int number = 0;//存储总购买量 public void setNumber(int a){ number = number+a; } public int GetNumber(){ return number; } public static void main(String[] args){ int name;//输出商店序号 shop s=new shop(); for(name = 1 ; name<6 ; name++){ System.out.println("欢迎光临第" + name + "家专卖店"); s.ask(); } System.out.println("总共买了" + number + "件衣服");//输出总购买量 } }//建立专卖店类 class shop{ BuyClothes b = new BuyClothes(); private int n;//存储当前商店购买量 public void ask(){ n = 0; for(String a = "n" ; a.equals("n") ;){ System.out.print("要离开吗(y/n)? "); Scanner sc = new Scanner(System.in); a = sc.nextLine();//判断是否离开 if(a.equals("n") && n<3){ System.out.println("买了一件衣服"); n = n+1; b.setNumber(1); }else if(a.equals("y")){ System.out.println("离店结账"); System.out.println(); }else{ String t;//判断输入是否有误 for(t=a ; (n<3 && !a.equals("n") && !a.equals("y")) || (!a.equals("y") && n>=3) ;){ System.out.print("输入有误或已达到本店购买上限,请重新输入(y/n):"); a = sc.nextLine(); } } } } }
运行:
2.完成购买商品结算功能:
1、循环输入商品编号和购物数量,计算消费金额并累加到总金额
2、输入“n”开始结账(假设享8折)
3、输入实付金额,计算找零
//完成购买商品结算功能: import java.util.Scanner; public class Shop{ public static void main(String[] args){ Scanner sc=new Scanner(System.in); String[] a=new String[]{"T恤","网球鞋","网球拍"}; float[] b=new float[]{245,570,100}; System.out.println("购物管理系统 > 购物结算"); System.out.println(); System.out.println(); //输出45个星 for(int i=0;i<45;i++){ System.out.print("*"); } System.out.println(); System.out.println("请选择购买的商品编号:"); System.out.println(); //遍历数组列出商品 for(int i=0;i<3;i++){ System.out.print((i+1) + "." + a[i] + " "); } System.out.println(); //输出45个星 for(int i=0;i<45;i++){ System.out.print("*"); } System.out.println(); System.out.println(); //开始购物 float cost=(float)0; float realCost=(float)0; for (String d="y" ; d.equals("y") ; ){ Scanner sc2=new Scanner(System.in); System.out.print("请输入商品编号: "); int x=sc2.nextInt()-1; System.out.println(); System.out.print("请输入购买数量: "); int y=sc2.nextInt(); System.out.println(); System.out.println(a[x] + " " + "¥" + b[x] + " " + "¥" + (b[x]*(float)y)); System.out.println(); cost=cost + (b[x]*(float)y); System.out.print("是否继续(y/n):"); d=sc.nextLine(); System.out.println(); } System.out.println("折扣:0.8"); System.out.println("金额总计 ¥" + cost*(float)0.8); System.out.print("实际交费 ¥"); //判断交钱数目是否正确 for (realCost=(float)sc.nextInt() ; realCost < cost*(float)0.8;){ System.out.println("钱数不对"); realCost=(float)sc.nextInt(); } System.out.println(""); System.out.println("找钱 ¥" + (realCost-(cost*(float)0.8))); } }
运行:
3.万年历(实现从键盘输入1900年之后的任意的某年、某月,输出该月的日历)
代码:
//万年历(实现从键盘输入1900年之后的任意的某年、某月,输出该月的日历) import java.util.Scanner; public class Week{ public static void main(String [] args){ int year;//保存输入的年 int month;//保存输入的月 int days=0;//保存月份的天数 int totalDays=0;//存放总的天数差 boolean isRn;//判断输入的年是否是闰年,是的话true,不是false Scanner input=new Scanner(System.in); System.out.println("***************万年历**************"); System.out.println("请输入年:"); year=input.nextInt(); System.out.println("请输入月:"); month=input.nextInt(); if(year%400==0||(year%4==0&&year%100!=0)){ isRn=true;//代表闰年 }else{ isRn=false;//代表平年 } if(isRn){ System.out.println(year+"是闰年"); }else{ System.out.println(year+"是平年"); } //计算年的总天数 for(int i=1900;i<year;i++){ if(i%400==0||(i%4==0&&i%100!=0)){ totalDays+=366; }else{ totalDays+=365; } } //计算你输入月份的天数 for(int i=1;i<=month;i++){ switch(i){ case 1: case 3: case 5: case 7: case 8: case 10: case 12: days=31; break; case 2: if(isRn){ days=29; }else{ days=28; } break; case 4: case 6: case 9: case 11: days=30; break; default: System.out.println("输入的月份有误"); break; } //累加求和,输入月份的天数保存到days变量中,但不累加进来 if(i!=month){ totalDays+=days; } } //求这个月的第一天是星期几.也就是输出的\t的个数 int beforeDays=0; beforeDays=1+totalDays%7; if(beforeDays==7){ beforeDays=0; } //打印输出 System.out.println("日\t一\t二\t三\t四\t五\t六"); //先打印输出\t的个数 for(int i=0;i<beforeDays;i++){ System.out.print("\t"); } for(int i=1;i<=days;i++){ System.out.print(i+"\t"); if((beforeDays+i)%7==0){ System.out.println(); } } } }
运行:
4.编写一个类Student,代表学员,要求:
1) 具有属性:姓名、年龄、性别、专业
2) 具有方法:自我介绍,负责输出该学员的姓名、年龄、性别以及专业
代码:
//编写一个类Student,代表学员,要求: public class School{ public static void main(String[] args){ Student wjh=new Student(); wjh.introduce(); } } class Student{ private String name="小明"; private int age=18; private String sex="男"; private String collegeMajor="电子信息工程"; public void introduce(){ System.out.println("我叫" + name + "\t"); System.out.println(sex + " " + "今年" + age + "岁\t"); System.out.println("我的专业是" + collegeMajor + "\t"); } }
运行:

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
动态规划法(九)想要更多例子?
本文将会介绍三个用动态规划法解决的例子,分别是: 楼梯台阶问题 二项式系数求解 最大乘积子数组问题 楼梯台阶问题 一个n阶的楼梯,一个婴儿每次爬一阶或两阶,试问一共有多少种办法爬完楼梯。 设f(n)为该问题的解,考虑最后一次的爬法,若最后一次爬一阶,则前面n-1阶楼梯有f(n-1)种办法,若最后一次爬两阶,则前面n-2阶楼梯有f(n-2)种办法,因此: f(n)=f(n−1)+f(n−2).f(n)=f(n−1)+f(n−2). f(1)=1,f(2)=2,f(3)=3,….该数列为斐波那契数列,可以参考博客 动态规划法(一)从斐波那契数列谈起用动态规划法进行求解。 一个n阶的楼梯,一个婴儿每次爬一阶或两阶或三阶台阶,试问一共有多少种办法爬完楼梯。 同上面的解法一样,有: f(n)=f(n−1)+f(n−2)+f(n−3).f(n)=f(n−1)+f(n−2)+f(n−3). 其中,f(1)=1,f(2)=2,f(3)=4. 可以参考博客 动态规划法(二)找零钱问题用动态规划法进行求解。 二项式系数求解 对于二项式系数,有如下等式: Ckn=Ckn−1+Ck−1n−1.Cnk=...
- 下一篇
2018-06-06 第三十一天
一、File***Stream和 Buffered***Stream Buffered带缓存区,提高了内存和内存之间的交互,减少了内存和磁盘之间的交互,效率更高。 二、MyBuffered importjava.io.InputStream; importjava.io.OutputStream; importjava.io.FileInputStream; importjava.io.FileOutputStream; publicclassTestMyBufferedStream { publicstaticvoidmain(String[] args) { longtime= System.currentTimeMillis(); BufferedInputOutputStreamTest.copyFile(); longcost= System.currentTimeMillis()-time; System.out.println("buffered cost = "+cost); time= System.currentTimeMillis(); try{ copyFile...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS8编译安装MySQL8.0.19
- Hadoop3单机部署,实现最简伪集群
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- SpringBoot2初体验,简单认识spring boot2并且搭建基础工程
- Windows10,CentOS7,CentOS8安装Nodejs环境
- 设置Eclipse缩进为4个空格,增强代码规范
- CentOS关闭SELinux安全模块
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- Linux系统CentOS6、CentOS7手动修改IP地址
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7