打印一系列数字优化第1部分
print a series of numbers optimization part 1
假设你想编写一个程序,它将一遍又一遍地打印数字1-9
123456789123456789123456789
我想最明显的方法是使用循环
int number = 1;
while(true)
{
print(number);
number = number + 1;
if(number > 9)
number = 1;
}
在我进一步讨论之前,这是最好的方法还是有更常见的方法?
这样行吗?
while(true)
{
print("123456789");
}
到目前为止,每个使用%
运算符的人似乎都认为涉及到十个值。他们也忽略了他们的逻辑有时会产生0
的事实。您可以这样做:
int i = 1;
while (true) {
print(i);
i = (i % 9) + 1;
}
最明显的方法是:
for (;;)
{
for (int i = 1; i < 10; ++i)
{
print(i);
}
}
我不明白你为什么要把它放大。输出将压倒计算,任何类型的优化都是无关紧要的。
首先,你为什么要"优化"这个?你是否在优化速度?空间?可读性还是可维护性?
更短的方式是这样的:
for (int i = 1; true; i++)
{
print(i);
i = (i + 1) % 10;
}
我所做的只是:
- 将while循环转换为for循环
- 转换增量+条件为increment + mod操作。
这确实是一个微优化的例子
我的答案是基于Mike的答案,但经过进一步优化:
for (int i = 1; true; i++)
{
std::cout << ('0' + i);
i = (i + 1) % 10;
}
打印数字比打印字符和加法要广泛得多。
相关文章:
- 空基优化子对象的地址
- 关闭||运算符优化
- 如何解决gcc编译器优化导致的centos双编译器设置中的分段错误
- 返回值优化:显式移动还是隐式
- 人脸跟踪arduino代码的优化
- 使用仅使用一次的变量调用的复制构造函数.这可能是通过调用move构造函数进行编译器优化的情况吗
- 纯函数,为什么没有优化
- 如何将部分流作为参数传递
- 为什么大多数 pair 实现默认不使用压缩(空基优化)?
- 如何以优化的方式同时迭代两个间距不相等的数组
- 小字符串优化(调试与发布模式)
- 浮点定向舍入和优化
- Visual Studio 调试优化如何工作?
- 为什么开关的优化方式与 c/c++ 中的链接不同?
- 线性优化目标函数中的绝对值
- GCC 会优化内联访问器吗?
- gcc 如何优化此循环?
- 如何防止 CUDA-GDB 中的<优化输出>值
- 为什么我的程序在 O0 和 O2 的优化级别返回不同的结果
- 这个C++编译器优化(在自身的实例上调用对象自己的构造函数)的名称是什么,它是如何工作的?