练习:卖飞机票
简单思路:
import java.util.Scanner;
public class test {
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
System.out.println("请输入机票原价");
double price=sc.nextDouble();
System.out.println("请输入月份");
int month=sc.nextInt();
System.out.println("请输入经济(J)或头等(T)");
char sit=sc.next().charAt(0);
double money=0;
if(month>=5&&month<=10){
if(sit=='T'){
money=price*0.9;
}
else if(sit=='J'){
money=price*8.5;
}
}
else if((month>=1&&month<=4)||(month>=11&&month<=12)) {
if(sit=='T'){
money=price*0.7;
}
else if(sit=='J'){
money=price*6.5;
}
else{
System.out.println("舱位录入不合法");
}
}
else{
System.out.println("月份录入错误");
}
System.out.println("价格为:"+money);
}
}
抽取成方法进行优化
import java.util.Scanner;
public class test {
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
System.out.println("请输入机票原价");
double price1=sc.nextDouble();
System.out.println("请输入月份");
int month=sc.nextInt();
System.out.println("请输入经济(J)或头等(T)");
char sit1=sc.next().charAt(0);
double result=0;
if(month>=5&&month<=10){
result=getprice(price1,sit1,0.9,0.85);
}
else if((month>=1&&month<=4)||(month>=11&&month<=12)) {
result=getprice(price1,sit1,0.7,0.65);
}
else{
System.out.println("月份录入错误");
}
System.out.println(result);
}
public static double getprice(double price,char sit,double v0,double v1){
double money=0;
if(sit=='T'){
money=price*v0;
}
else if(sit=='J'){
money=price*v1;
}
else{
System.out.println("非法输入");
}
return money;
}
}
练习:找质数
public class test {
public static void main(String[] args) {
int count=0;
for(int i=101;i<=200;i++){//得到101-200之间的数
boolean flag=true;//定义在for循环里面!!!,每次外循环开始都变为true
for(int j=2;j<=Math.sqrt(i);j++){
if(i%j==0){
//System.out.println(i+"不是质数");
flag=false;
break;//跳出单层循环
}
}
if(flag){
System.out.println(i+"是素数");
count++;
}
}
System.out.println("素数共有"+count+"个");
}
}
练习:开发验证码
import java.util.Random;
public class test {
public static void main(String[] args) {
/*方法:
* 在以后如果我们要在一堆没有什么规律的数据中随机抽取
* 可以先把这些数据放到数组当中
* 再随机抽取一个索引*/
/*分析:
* 1.大写字母和小写字母都放到数组当中
* 2.随机抽取四次
* 3.随机抽取一个数字0-9*/
Random rd=new Random();
char a[]=new char[52];//26个英文字母
char b[]=new char[4];//随机抽取字母保存在b数组中
for(int i=0;i<a.length;i++) {
if(i<=25){
a[i]=(char)(97+i);//此处用ASCLL码表a对应的ascall码是97,之后进行强制转化为char类型
}
else{
a[i]=(char)(65+i-26);//A对应的Ascall码是65
}
}
int num0=rd.nextInt(a.length);
for (int i = 0; i < b.length; i++) {
b[i]=a[rd.nextInt(num0)];//利用随机数生成随机索引
}
int num=rd.nextInt(10);
for (int i = 0; i < b.length; i++) {
System.out.print(b[i]);
}
System.out.print(num);
}
}
练习:评委打分
import java.util.Random;
public class test {
public static void main(String[] args) {
Random rd=new Random();
int[] a=new int[6];
int max=a[0];//最高分
int sum=0;
for(int i=0;i<6;i++){
a[i]=rd.nextInt(101);
sum+=a[i];
System.out.print(a[i]+" ");
}
int min=a[0];//最低分
for(int j=1;j<a.length;j++){
if(a[j]>max){
max=a[j];
}
else if(a[j]<min){
min=a[j];
}
}
double result=(sum-max-min)/4.0;
System.out.println();
System.out.println("去掉最低分"+min);
System.out.println("去掉最高分"+max);
System.out.println("最终得分"+result);
}
}
练习:数字加密
import java.util.Scanner;
public class test {
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
System.out.println("请输入原始密码");
int mima=sc.nextInt();
int count=0;
int num2=mima;
while(mima!=0){//得到输入数字的长度
mima=mima/10;//每次循环去掉右边的一个数字
count++;//计数器+1
}
int[] c=secert(num2,count);
for (int i = 0; i < c.length; i++) {
System.out.print(c[i]+" ");
}
}
public static int[] secert(int M,int n){
int[] a=new int[n];
for (int i = 0; i < a.length; i++) {
a[i]=M%10;
M=M/10;
}
for (int i = 0; i < a.length; i++) {
a[i]=(a[i]+5)%10;
}
return a;
}
}
练习:数字解密
public class test {
public static void main(String[] args) {
int[] a={8,3,4,6};//加密后的数据,加密前的数据是1983
for(int i=0 ,j=a.length-1;i<j;j--,i++){//将数组进行反转
int temp=a[i];
a[i]=a[j];
a[j]=temp;
}
for (int i = 0; i < a.length; i++) {
if(a[i]<5&&a[i]>=0){//除十取余前的数据是6、14、13、8,所以只需要其中的0~4的数据加10即可
a[i]=a[i]+10;
}
}
for (int i = 0; i < a.length; i++) {
a[i]=a[i]-5;
}
for (int i = 0; i < a.length; i++) {
System.out.print(a[i]);
}
}
}
练习:抢红包
import java.util.Random;
public class test {
public static void main(String[] args) {
int[] a={2,588,888,1000,10000};
int[] b= new int[a.length];
for (int i = 0; i < a.length; ) {
boolean flag=true;
Random rd= new Random();
int index=rd.nextInt(5);
for(int j=0;j<b.length;j++){
if(b[j]==a[index]){
flag=false;//表示该索引对应的奖金已经被抽取过
break;
}
}
if(flag==true){//该奖金没有被抽取,注意=和==的区别啊!!!!
b[i]=a[index];
System.out.println(a[index]+"元的奖金被抽出");
i++;//当抽取的奖金没有重复时i才自增
}
}
}
}
此代码存在的问题:第5次抽中奖金的概率只有20%,效率比较低。
抢红包代码优化
import java.util.Random;
public class test {
public static void main(String[] args) {
//优化思路:每次都将奖池里面的所有奖项打乱顺序后输出实现不重复抽奖
int[] a={2,588,888,1000,10000};
Random rd=new Random();
for(int i=0;i<a.length;i++){
int index=rd.nextInt(a.length);
int temp=a[i];
a[i]=a[index];
a[index]=temp;
}
for (int i = 0; i < a.length; i++) {
System.out.println(a[i]);
}
}
}
练习:双色球系统
import java.util.Random;
import java.util.Scanner;
public class test {
public static void main(String[] args) {
int[] a=new int[7];
Scanner sc=new Scanner(System.in);
int[] arr1=getsurpise();//接收获得的球
System.out.println("===========中奖号码===========");
for (int i = 0; i < arr1.length; i++) {
System.out.print(arr1[i]+" ");
}
System.out.println();
System.out.println("======================");
for(int i=0;i<6;i++){//用户输入中奖号码
System.out.println("请输入红球号码");
a[i]=sc.nextInt();
}
System.out.println("请输入蓝球号码");
a[6]=sc.nextInt();
int countred=0;
int countblue=0;
for(int i=0;i<a.length-1;i++){
for(int j=0;j< arr1.length-1;j++){
if(a[i]==arr1[j]){
countred++;
break;//如果找到了,那么后面的数字就没有必要继续比较了
//跳出内循环,继续判断下一个红球号码
}
}
}
if(a[6]==arr1[6]){
countblue=1;
}
System.out.println("红球中奖个数是"+countred);
System.out.println("蓝球中奖个数是"+countblue);
}
public static int[] getsurpise(){
int[] b=new int[7];
Random rd=new Random();
/*随机生成号码并添加到数组中
* 红球:数字不能重复1~33
* 蓝球:可以跟红球号码重复1~16*/
for (int i = 0; i < 6; ) {//随机生成6个红色球号码,在1-33中选
int red=rd.nextInt(33)+1;
boolean flag=contains(b,red);
if(!flag){//红色号码添加到数组当中
b[i]=red;
i++;
}
}
b[6]=rd.nextInt(16)+1;//蓝色球号码在1-16中选择
return b;
}
public static boolean contains(int[] arr, int number){//定义方法用于判断红球中元素是否重复
for (int i = 0; i < arr.length; i++) {
if(arr[i]==number){
return true;
}
}
return false;//循环结束之后还没找到,说明不重复
}
}