-1

我正在尝试制作一个简单的程序来根据客户购买的商品数量显示折扣。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace ConsoleApplication11
{
    class Program
    {
        const int SIZE = 4;
        static void Main(string[] args)
        {
            int itemsbought = 0;
            double discountItem = 0;
            int[] items = new int[SIZE] { 0, 10, 26, 61 };
            double[] discount = new double[SIZE] { 0.0, 0.05, 0.10, 0.15 };

            InputItems(ref itemsbought);
            getDiscount(items, discount, ref itemsbought, ref discountItem);

            Console.WriteLine("Your discount is {0}", discountItem);

        }

        private static void getDiscount(int[] items, double[] discount, ref int itemsbought, ref double discountItem)
        {
            int idx = 0;
            for (idx = 1; idx >= items.Length; idx++)
            {
                while (itemsbought >= items[idx])
                {
                    discountItem = discount[idx];
                    idx++;
                }
            }
        }
        private static void InputItems(ref int itemsbought)
        {
            Console.WriteLine("Enter the amount of items you bought");
            while (!int.TryParse(Console.ReadLine(), out itemsbought))
                Console.WriteLine("Error, whole numbers only");
        }
    }
}

不知何故,我知道这个逻辑真的很糟糕,但我不确定。主题之一当然是显示与输入对齐的折扣。无论输入什么值,它都只是显示“折扣为 0”。

4

2 回答 2

1

你的for循环全错了。首先,它没有执行,因为您的条件是idx >= items.Length;. 应该是相反的:idx < items.Length;. 其次,我不确定您为什么idx1在初始化程序中设置为...

内部 while 循环也可能不会做你想做的事,但我什至不确定你一开始想让它做什么。

于 2013-04-05T02:09:19.463 回答
0

您需要修复循环条件检查部分,它使用的故障逻辑idx >= items.Length;应该是idx < items.Length;.

c# 中的数组具有从零开始的索引,因此它必须以idx = 0.

for (idx = 0; idx < items.Length; idx++)
{
    while (itemsbought >= items[idx])
    {
        discountItem = discount[idx];
        idx++;
    }
}
于 2013-04-05T02:11:09.190 回答