8

它是由我的同事给出的,1 2 3 4 .... 15 15 ..... 4 3 2 1只打印一个 for 循环没有函数没有 goto 语句并且不使用任何条件语句或三元运算符的值。

所以我使用类型转换来解决它,但这不是一个精确的解决方案,因为 15 没有打印两次。

int main()
{
    int i, j;
    for(i = 1, j = 0;j < 29;j++, i += int(j/15)*-2 + 1)
        cout<<i<<endl;
}

输出1 2 3 4 ... 15 14 13 .... 2 1

任何替代解决方案?

4

11 回答 11

32

您可以从 1 循环到 30,然后使用 (i/16) 将是“0”作为您的上升部分和“1”作为您的下降部分的事实。

for (int i = 1; i < 31; i++)
{
    int number = (1-i/16) * i + (i/16) * (31 - i);
    printf("%d ", number);
}
于 2012-04-11T12:00:17.017 回答
25
for (int i=0; i<1; i++)
{
    std::cout << "1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1"
}
于 2012-04-11T11:49:26.253 回答
8

这个怎么样:

std::string first;
std::string second;

for ( int i = 1 ; i <= 15 ; i++ )
{
   std::ostringstream s;
   s << i;
   first += s.str();
   second = s.str() + second;
}

std::cout << first << second;
于 2012-04-11T11:55:39.033 回答
5

选择:

static int bla[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1};

for (int i = 0; i < 30; i++) 
{        
    printf("%d\n", bla[i]);
}

好的,与所有相比,它的执行速度更快......

于 2012-04-11T11:48:32.677 回答
3

XOR 位#4(即j & 0x10)与位 3:0。您将需要找到一种方法将该位“重复”到 4 个位置。

于 2012-04-11T11:49:34.907 回答
3
for (int i=1;i<31;++i)
{
  cout<<(((i<<27>>31|i)&(~i<<27>>31|~i))&15)<<" ";
}
于 2012-04-11T13:08:38.120 回答
2
#include <iostream>

int main()
{
    for(int i = 1; i < 31; i++) std::cout << ((i/16)-1)*-i+(i/16)*(i^0x1F) << " ";
    std::cout << std::endl;
}
于 2012-04-11T12:10:12.500 回答
2

我见过许多复杂的答案,但没有人按原样利用对称性。

std::string head = "1";
std::string tail = "1";

for (unsigned i = 2; i != 16; ++i) {
  std::string const elem = boost::lexical_cast<std::string>(i);

  head = head + " " + elem;
  tail = elem + " " + tail;
}

std::cout << head << " " << tail << "\n";

ideone采取行动(减号lexical_cast):

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1

它的工作原理很简单,并且适用于任何大小的上限(只要您的计算机有足够的内存)。

于 2012-04-11T12:45:30.210 回答
2
const int N = 15;
for(int i = 1; i <= 2 * N; ++i)
    printf("%d ", i + (i > N) * (1 + 2 * (N - i)));
于 2012-04-11T14:05:14.090 回答
1
for (int i = 1; i < 30; i++)
    printf("%d\n", (-((i & 16) >> 4) + 1) * i + ((i & 16) >> 4) * (14 - (i & 15)));
于 2012-04-11T12:03:04.950 回答
1
int main()
{

    for(int i = 15, j = 30, k = 15; i <= 30; i++, j--, k -= 2)
    {
        cout << (j - i) * (k % 2) << endl << (j - i - 1) * (k % 2) << endl;
    }

    return 0;
}

这是我想出的。反之亦然,即:15 -> 0 -> 15。更值得深思。使用 mod 和 k 来计算是否为负数。I - J 在中间相遇。它绝不是完美的,还有其他一些更好的答案。

于 2012-04-11T14:17:59.077 回答