OpenJudge-1.6.03:计算书费

一、题目链接

http://noi.openjudge.cn/ch0106/03/

二、解题思路(Java)

◎ 方法public double cost(double[] price, int[] number)处理所有业务逻辑:
	→ 参数price为double类型的数组,存储每种书的单价;
	→ 参数number为int类型的数组,存储每种书的采购量;
	→ cost方法返回非负浮点数,代表购书应付的总费用;
◎ 定义double类型的浮点数ans,代表购书应付的总费用,初始时ans为0;
◎ 定义int类型的整数n,代表购书的种类,令n = price.length;
◎ 从第一种书开始,到最后一种书为止,利用循环i处理如下:
	→ 令ans = ans + price[i] * number[i],也即将当前第i种书的购书费用累加到ans上;
	循环i结束后,ans中存储了购书应付的总费用,返回ans;
◎ 在main方法中调用cost方法,注入相应的参数后即可获得计算结果,保留1位小数将其输出。

三、解题思路(C++)

◎ 定义并初始化double类型的数组price[10],用于存储每种书的单价,其中的10个元素按题目要求设定;
◎ 定义int类型的数组number[10],用于存储每种书的采购量;
◎ 定义double类型的浮点数ans,代表购书应付的总费用,初始时ans为0;
◎ 从第一种书开始,到最后一种书为止,利用循环i处理如下:
	→ 首先,输入当前第i种书的采购量number[i];
	→ 其次,令ans = ans + price[i] * number[i],也即将当前第i种书的购书费用累加到ans上;
	循环i结束后,ans中存储了购书应付的总费用;
◎ 保留1位小数输出ans。

四、Java程序

import java.util.Scanner;

public class Main {
    /**
     * 返回购书应付的总费用
     *
     * @param price  double类型的数组,存储每种书的单价
     * @param number int类型的数组,存储每种书的采购量
     * @return 非负浮点数,代表购书应付的总费用
     */
    public double cost(double[] price, int[] number) {
        double ans = 0; // 购书应付的总费用
        int n = price.length; // 购书的种类
        /* 取每种书的单价和采购量计算费用 */
        for (int i = 0; i < n; i++) {
            ans = ans + price[i] * number[i];
        }
        return ans;
    }

    public static void main(String[] args) {
        Main test = new Main();
        Scanner input = new Scanner(System.in);
        int N = 10;
        double[] price = {28.9, 32.7, 45.6, 78, 35, 86.2, 27.8, 43, 56, 65};
        int[] number = new int[N];
        for (int i = 0; i < N; i++) {
            number[i] = input.nextInt();
        }
        System.out.printf("%.1f", test.cost(price, number));
    }
}

五、C++程序

#include <iostream>
using namespace std;

int main()
{
    // 存储每种书的单价
    double price[10] = {28.9, 32.7, 45.6, 78, 35, 86.2, 27.8, 43, 56, 65};
    int number[10]; // 存储每种书的采购量
    double ans = 0; // 购书应付的总费用
    /* 输入每种书的采购量,同时累加购书应付的总费用 */
    for (int i = 0; i < 10; i++)
    {
        cin >> number[i];
        ans = ans + price[i] * number[i];
    }
    printf("%.1f", ans);
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

江苏科技大学_计算机学院_潘磊

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

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

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

打赏作者

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

抵扣说明:

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

余额充值