3

我遇到了一个问题(可能是由于睡眠不足!),我正在尝试用 C# 解决数学问题。

假设我有一台饮料机,我有三排可以装可乐的空行。我手里有 17 罐可乐,我必须一次装满每一排。

例如...

通过1:

将可乐添加到第 1 行。饮品 = 1
将可乐添加到第 2 行。饮品 = 1
将可乐添加到第 3 行。饮品 = 1

通行证 2:

将可乐添加到第 1 行。饮品 = 2
将可乐添加到第 2 行。饮品 = 2
将可乐添加到第 3 行。饮品 = 2

...

通过 6

将可乐添加到第 1 行。饮品 = 6
将可乐添加到第 2 行。饮品 = 6
将可乐添加到第 3 行。饮品 = 5(此时已无饮品)

出于某种原因,我完全迷路了。谁能帮忙?!

4

3 回答 3

6

非常快速和轻松,只需要一个循环,而不是两个嵌套循环。您只需要一点数学即可获得数组的正确索引:

int[] Cola = {0,0,0};
int Rows = Cola.Length;
int Drinks = 17;

for (int i = Drinks; i > 0; i--)
{
   Cola[(Drinks - i) % Rows]++;
}

Console.WriteLine("Row 1 has " + Cola[0] + " cans.");
Console.WriteLine("Row 2 has " + Cola[1] + " cans.");
Console.WriteLine("Row 3 has " + Cola[2] + " cans.");

这会产生以下输出:

Row 1 has 6 cans.
Row 2 has 6 cans.
Row 3 has 5 cans.
于 2009-08-09T00:01:31.730 回答
2

您可以计算每行将获得多少个罐子,而不是循环添加一个罐子:

int cans = 17;
cans += machine.Rows.Count;
for(int i = 1; i <= machine.Rows.Count; i++) {
   Console.WriteLine("Row {0} has {1} cans.", i, --cans / machine.Rows.Count);
}
于 2009-08-09T00:14:46.470 回答
1

从臀部射击:

int numDrinks = /* Your constant here */
int[] drinksInRow = new int[NUM_ROWS];
for(int i = 0; i < drinksInRow.Length; i++)
{
  drinksInRow[i] = numDrinks / NUM_ROWS;
  if(i < numDrinks % NUM_ROWS) drinksInRow[i]++;
}

每行中的饮料数量在 中drinksInRow,按行号从 0 开始索引。

这比重复通过要快;基本上是它的 O(NUM_ROWS) [如果用 Big-O 玩得很松]。

于 2009-08-09T00:03:06.687 回答