lifuguan 2016-04-07 09:31 采纳率: 26.7%
浏览 1275
已采纳

C++指针问题 *(primes_i + count_i++) = trail_i;

 #include <iostream>
#include <iomanip>
using namespace std;

#define maxn 100
void main11()
{
    //const auto maxn = 100;
    long primes_i[maxn] = { 2, 3, 6 };
    long trail_i = 5;
    auto count_i = 3;
    auto found_i = false;

    do
    {
        trail_i += 2;
        found_i = false;

        for (int i{}; i < count_i; i++)
        {
            found_i = (trail_i % * (primes_i + i)) == 0;
            if (found_i)
                break;
        }
        if (!found_i)
        {
            *(primes_i + count_i++) = trail_i;
        }
    } while (count_i < maxn);

    for (int i{}; i < maxn; i++)
    {
        if (i % 5 == 0)
        {
            cout << endl;
        }

        cout << setw(10) << *(primes_i + i);
    }
    cout << endl;
    system("pause");
}

其中

 *(primes_i + count_i++) = trail_i;

是什么意思

  • 写回答

3条回答 默认 最新

  • 清泉流 2016-04-07 09:48
    关注

    primes-i是数组的首地址(指针),与count-i相加表示地址(指针)进行加法运算,也就是获取数组其他元素的地址(指针)。如果count是1,那么primes_i + count_i++的结果就是得到数组的第二个元素的地址(指针),在此句话执行结束之后count再加1,进而继续操作数组下一个元素
    那么整个语句的意思就是给long数组中的某个元素进行赋值,结合循环完成对数组所有元素逐个赋值

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 安装svn网络有问题怎么办
  • ¥15 Python爬取指定微博话题下的内容,保存为txt
  • ¥15 vue2登录调用后端接口如何实现
  • ¥65 永磁型步进电机PID算法
  • ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥15 latex怎么处理论文引理引用参考文献