我需要创建一个程序来计算你可以添加三个数字的方式,使它们等于1000.
我认为这段代码应该可行,但它不会写出任何东西.我究竟做错了什么?任何提示或解决方案?
using System;
namespace ConsoleApp02
{
class Program
{
public static void Main(string[] args)
{
for(int a = 0; a < 1000; a++)
{
for(int b = 0; b < 1000; b++)
{
for(int c = 0; c < 1000; c++)
{
for(int puls = a + b + c; puls < 1000; puls++)
{
if(puls == 1000)
{
Console.WriteLine("{0} + {1} + {2} = 1000", a, b, c);
}
}
}
}
}
Console.ReadKey(true);
}
}
}
Run Code Online (Sandbox Code Playgroud)
mqp*_*mqp 16
你最内层的循环(迭代puls变量)并没有任何意义,因为它上面的条件(puls < 1000)Console.WriteLine永远不会运行.
也许您应该测试A + B + C是否为1000.
此外,由于循环的界限(取决于问题陈述),您会发现可能缺少一些特定的数字组合.
另外,这个特定的实现,虽然它可以工作(通过其他答案建议的修改),但由于算法的复杂性为O(n ^ 3),因此性能受到很大影响.换句话说,你正在经历最里面的检查.
这里有一个暗示如何将它优化到至少O(n ^ 2)或仅一个百万次迭代:对于由两个外部for循环生成的每对a和b,c只有一个值将导致1000.
| 归档时间: |
|
| 查看次数: |
2051 次 |
| 最近记录: |