Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/cplusplus/128.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C++ 整数的并置_C++ - Fatal编程技术网

C++ 整数的并置

C++ 整数的并置,c++,C++,我想将int数组中的int串联起来,并将它们等于int e、 g 给我一个 int num = 1240; int num2 = 1023; 我尝试的方法是将每个指数乘以10,再加上一定的幂。(十进制转换法)。但是,它不会在数组中显示“0”。请提供帮助。您必须将结果乘以10,然后添加索引: #include <iostream> int main(void) { int arr[4]; arr[0] = 1; arr[1] = 0; arr[2] = 2;

我想将int数组中的int串联起来,并将它们等于int

e、 g

给我一个

int num = 1240; 
int num2 = 1023;

我尝试的方法是将每个指数乘以10,再加上一定的幂。(十进制转换法)。但是,它不会在数组中显示“0”。请提供帮助。

您必须将结果乘以10,然后添加索引:

#include <iostream>

int main(void) {
  int   arr[4];

  arr[0] = 1;
  arr[1] = 0;
  arr[2] = 2;
  arr[3] = 3;

  int i = 0;
  int res = 0;

  while (i < 4) {
      res = res * 10 + arr[i];
      ++i;
  }
  std::cout << res << std::endl; // print 1023
}
#包括
内部主(空){
int-arr[4];
arr[0]=1;
arr[1]=0;
arr[2]=2;
arr[3]=3;
int i=0;
int res=0;
而(i<4){
res=res*10+arr[i];
++一,;
}

std::cout这似乎是方便的花花公子的时候了,它可以左折序列。您需要提供的只是迭代器、初始值(零)和一个二进制函数来进行计算:

int arr[] = {1, 2, 4, 0};
int res = std::accumulate(std::begin(arr), std::end(arr), 0,
  [](int lhs, int rhs) { return lhs * 10 + rhs; });
如果您喜欢使用循环,最简单的方法是:

int res{};
for (auto i : arr) {
    res = res * 10 + i;
}
或者如果你不能使用C++11,你可以索引

int res = 0;
for (int i = 0; i < (sizeof arr / sizeof arr[0]); ++i) {
    res = res * 10 + arr[i];
}

为什么要取消数组初始化,需要显式的大小?为什么要创建函数范围变量
i
?为什么要进行while循环?为什么要在两个位置硬编码数组大小?他显然已经开始开发了,所以我想让他尽可能清楚地了解问题中数组的初始化,为什么要将其更改为ma更糟吗?
int res = 0;
for (int i = 0; i < (sizeof arr / sizeof arr[0]); ++i) {
    res = res * 10 + arr[i];
}
int res = 0;
for (int* p = arr; p != arr + (sizeof arr / sizeof arr[0]); ++p) {
    res = res * 10 + *p;
}