*7.21 (游戏:豆机)豆机,也称为梅花瓶或高尔顿瓶,它是一个用来做统计实验的设备···(用一维数组)

在这里插入图片描述
在这里插入图片描述


import java.util.Arrays;
import java.util.Scanner;
public class Exercise7_21{
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        System.out.print("Enter the numbers of balls to drop:");
        int balls= input.nextInt();
        System.out.print("Enter the numbers of slots in the bean machine:");
        int slots = input.nextInt();
        System.out.println();
        int[] holes = new int[slots];
        for(int i=0;i<balls;i++){
            int sum=0;
            for (int j=0;j<slots-1;j++) {
                double direction = Math.random() * 2 - 1; //随机生成-1到1之间的数字,当x<0时左移,x>0时右移
                if (direction < 0)
                    System.out.print("L");
                else {
                    System.out.print("R");
                    sum++;
                }
            }
            System.out.println();
            holes[sum]+=1; //有多少个R就进哪个洞,从0开始编号
        }
        int maxhole=0;
        for(int i=0;i<holes.length;i++){   //找出所有洞中进球数的最大值
            if(holes[i]>maxhole)
                maxhole=holes[i];
        }
        System.out.println();
        for (int i = 0; i < maxhole; i++) { //以进球数最大值为行数
            for (int j = 0; j < slots-1; j++) {   //以洞数为列数
                if (holes[j] == maxhole - i) {
                    System.out.print('0');
                    holes[j]--;
                }
                else
                    System.out.print(' ');
            }
            System.out.println();
        }
    }
}


输出结果如下:

Enter the numbers of balls to drop:5
Enter the numbers of slots in the bean machine:8

RRRLRLR
RLRLLRL
LLRRRLR
RRLLLLR
RLRLRLR

   00  
   000 
  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: c语言中,你可以使用for循环来遍历seita的所有可能取值,并在每次迭代时计算q0_1和q0_2的值。然后,你可以找到q0_1和q0_2最接近0的值,并记录下对应的seita值。 例如: ``` #include <stdio.h> #include <math.h> int main() { double hk = 0.0; double seita = 0.0; double q0_1 = 0.0; double q0_2 = 0.0; double min_diff = 1000000000.0; // 设置一个极大的初始值 double min_seita = 0.0; // 用于记录最接近时的seita值 for (seita = 0.0; seita <= 7.21; seita += 0.01) { // 遍历所有可能的seita值 q0_1 = hk * (1 / pow(seita, 0.25)) * seita; q0_2 = 2340.2650 * (7.21 - seita); double diff = fabs(q0_1 - q0_2); // 求出q0_1和q0_2的差值的绝对值 if (diff < min_diff) { // 如果当前的差值比之前的小 min_diff = diff; // 更新最小差值 min_seita = seita; // 记录最接近时的seita值 } } printf("seita = %f, q0_1 = %f, q0_2 = %f\n", min_seita, q0_1, q0_2); return 0; } ``` 在这段代码中,我们使用了for循环来遍历seita的所有可能取值,并在每次迭代时计算q0_1和q0_2的值。然后,我们比较q0_1和q0_2的差值的绝对值,并找到最小值,最后输出最接 ### 回答2: 根据给定的公式,我们需要编写程序来求出变量seita取值范围为[0, 7.21]时,使得q0_1和q0_2的值最接近的seita的值。 首先,我们可以设定一个初始值best_seita,用来保存当前使得q0_1和q0_2最接近的seita的值。初始时,我们可以将best_seita设定为0,并计算相应的q0_1和q0_2的值。 接下来,我们采用遍历的方式,从0到7.21的范围内,以较小的步长进行迭代计算。在每一次迭代中,我们用当前的seita值计算q0_1和q0_2。如果当前的q0_1和q0_2的差值比之前的最小差值还要小,则将当前的seita值更新为best_seita,并更新最小差值。 最后,程序运行完成后,best_seita的值即为使得q0_1和q0_2最接近时的seita值。 下面是一个示例程序的代码: ```c #include <stdio.h> #include <math.h> int main() { double best_seita = 0; double min_diff = __DBL_MAX__; // 设置初始最小差值为最大浮点数 for (double seita = 0; seita <= 7.21; seita += 0.001) { double q0_1 = hk * (1 / pow(seita, 0.25)) * seita; double q0_2 = 2340.2650 * (7.21 - seita); double diff = fabs(q0_1 - q0_2); // 计算当前q0_1和q0_2的差值的绝对值 if (diff < min_diff) { best_seita = seita; min_diff = diff; } } printf("使得q0_1和q0_2值最接近时的seita的值为:%f\n", best_seita); return 0; } ``` 以上就是一个求解最接近的seita值的C语言程序。注意,为了提高精度,我们在每次迭代中使用了较小的步长0.001。实际使用时,可以根据需要进行调整。 ### 回答3: 要求编写程序求出q0_1和q0_2最接近时seita的值。 首先,我们需要确定seita的取值范围为[0,7.21]。由于seita是一个变量,我们需要以一定的精度遍历这个范围。 首先,定义一个变量step,表示遍历的步长。为了保证精度,我们可以将seita的范围划分为多个小区间,然后在每个小区间内进行遍历。 假设步长为0.001,则需要遍历的次数为(7.21-0)/0.001 = 7210次。 我们可以使用一个循环来遍历这个范围。在每次遍历中,计算q0_1和q0_2的值,然后判断与之前的最接近值的差距,如果更接近,则更新最接近的值和seita的取值。 下面是一个伪代码示例: ```c double q0_1_min = MAX_DOUBLE; double q0_2_min = MAX_DOUBLE; double seita_min = 0; double hk = 1.0; // hk值需要根据实际情况确定 for (double seita = 0; seita <= 7.21; seita += 0.001) { double q0_1 = hk * (1 / pow(seita, 0.25)) * seita; double q0_2 = 2340.2650 * (7.21 - seita); double diff_q0_1 = fabs(q0_1 - q0_1_min); double diff_q0_2 = fabs(q0_2 - q0_2_min); if (diff_q0_1 < fabs(q0_1_min - q0_2_min) || diff_q0_2 < fabs(q0_1_min - q0_2_min)) { q0_1_min = q0_1; q0_2_min = q0_2; seita_min = seita; } } printf("q0_1最接近时的seita值:%f\n", seita_min); printf("q0_2最接近时的seita值:%f\n", seita_min); ``` 通过遍历并比较差值,最后输出q0_1和q0_2最接近时的seita值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Z-xina

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值