Java实现统计福彩双色球出现次数(毫无技术可言)

博主利用Java编写了一个程序,用于统计网上获取的双色球彩票数据中每期号码的出现次数。通过代码实现了对彩票号码的统计分析。
摘要由CSDN通过智能技术生成

今天早上闲来无事,恰好在看微博的时候看到的双色球的开奖视频,没出现一个号,主持人就会报出现了多少次,于是自己就无聊的写了一下统计每期的号码出现的次数程序。

彩票号码数据来自网上:



代码如下Money.java:

package com.heynine.money;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileOutputStream;
import java.io.FileReader;
import java.io.PrintStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class Money {
	
	private List<Map<String, String>> mOldDatas;
	
	/**
	 * 初始化数据
	 * @throws Exception 
	 */
	private void initData() throws Exception {
		mOldDatas = new ArrayList<Map<String, String>>();
		File dataFile = new File("datas.txt");
		BufferedReader reader = new BufferedReader(new FileReader(dataFile));
		String line = null;
		while
以下是福利彩票双色球Java实现: ```java import java.util.Arrays; import java.util.Random; import java.util.Scanner; public class DoubleColorBall { public static void main(String[] args) { Scanner input = new Scanner(System.in); System.out.print("请输入您要购买的彩票注数:"); int n = input.nextInt(); int[][] tickets = new int[n][7]; for (int i = 0; i < n; i++) { System.out.println("请输入第" + (i + 1) + "注彩票的号码:"); for (int j = 0; j < 6; j++) { System.out.print("请输入第" + (j + 1) + "个红球号码(1-33):"); int redBall = input.nextInt(); while (redBall < 1 || redBall > 33) { System.out.print("输入有误,请重新输入第" + (j + 1) + "个红球号码(1-33):"); redBall = input.nextInt(); } tickets[i][j] = redBall; } System.out.print("请输入蓝球号码(1-16):"); int blueBall = input.nextInt(); while (blueBall < 1 || blueBall > 16) { System.out.print("输入有误,请重新输入蓝球号码(1-16):"); blueBall = input.nextInt(); } tickets[i][6] = blueBall; } System.out.println("您购买的彩票号码为:"); for (int i = 0; i < n; i++) { System.out.print("第" + (i + 1) + "注:"); for (int j = 0; j < 6; j++) { System.out.print(tickets[i][j] + " "); } System.out.println("蓝球:" + tickets[i][6]); } int[] result = getResult(); System.out.println("本期开奖号码为:" + Arrays.toString(Arrays.copyOf(result, 6)) + " 蓝球:" + result[6]); int totalMoney = n * 2; int totalPrize = 0; for (int i = 0; i < n; i++) { int prize = getPrize(tickets[i], result); totalPrize += prize; if (prize > 0) { System.out.println("第" + (i + 1) + "注彩票中奖了,中奖金额为:" + prize + "元"); } } System.out.println("您一共下注" + totalMoney + "元,累计中奖" + totalPrize + "元"); } public static int[] getResult() { int[] result = new int[7]; Random random = new Random(); for (int i = 0; i < 6; i++) { int redBall = random.nextInt(33) + 1; while (contains(result, redBall, i)) { redBall = random.nextInt(33) + 1; } result[i] = redBall; } Arrays.sort(result, 0, 6); int blueBall = random.nextInt(16) + 1; result[6] = blueBall; return result; } public static boolean contains(int[] array, int value, int length) { for (int i = 0; i < length; i++) { if (array[i] == value) { return true; } } return false; } public static int getPrize(int[] ticket, int[] result) { int redCount = 0; int blueCount = 0; for (int i = 0; i < 6; i++) { if (contains(result, ticket[i], 6)) { redCount++; } } if (ticket[6] == result[6]) { blueCount = 1; } if (redCount == 6 && blueCount == 1) { return 10000000; } else if (redCount == 6) { return 500000; } else if (redCount == 5 && blueCount == 1) { return 3000; } else if (redCount == 5 || (redCount == 4 && blueCount == 1)) { return 200; } else if (redCount == 4 || (redCount == 3 && blueCount == 1)) { return 10; } else if (blueCount == 1) { return 5; } else { return 0; } } } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值