为什么最后输入6是结果是9,那出问题了应该怎么改?

【问题描述】
下图是著名的杨辉三角 。

图片
如果按从上到下、从左到右的顺序把所有数排成一列,则可以得到如下数列:1,1,1,1,2,1,3,3,1,1,4,6,4,1,1,5,10,10,5,1…… 给定一个正整数N,请你输出数列中N第一次出现是在第几个数的位置?
[输入格式]
输入一个整数N。
[输出格式]
输出一个整数,代表答案。
[样例输 入]
6
[样例输出]
13
[样例输 入]
2
[样例输出]
5


0#include 
#include 
using namespace std;
int main()
{
    
    //定义一个9行9列的二维整型数组
    int data[9][9];

    int i = 0;
    int j = 0;

    for (i = 0; i < 9; i++)
    {
        for (j = 0; j < 9; j++)
        {
            //数组所有元素都赋值为1
            data[i][j] = 1;
        }
    }

    //dp
    for (i = 1; i < 9; i++)
    {
        for (j = 1; j < i; j++)
        {
            data[i][j] = data[i - 1][j] + data[i - 1][j - 1];
        }
    }

    //输出数组所有元素
    for (i = 0; i < 9; i++)
    {
        for (j = 0; j <= i; j++)
        {
            cout<" "<int n,sum1=0;
    cin>>n;
    if(n==data[i][j])
    {
        for(int k=1;k<=i-1;k++)
        {
         sum1+=k;
         
            }
            cout<return 0;
}

你好!

你的程序中有一些问题:

1.在输出杨辉三角的过程中,你使用的是2个循环变量i和j。但是在后面的查找过程中,你却使用了i和j来比较,但是这2个循环变量已经被更新了。你应该使用另外的循环变量来查找。

2.你的程序在查找过程中,是按照行的顺序来查找的。但是在杨辉三角中,是按照列的顺序来排列的。你应该改变查找的顺序。

下面是修改后的程序,希望能帮到你:

#include <stdio.h>
#include <iostream>
using namespace std;

int main()
{
    //定义一个9行9列的二维整型数组
    int data[9][9];

    int i = 0;
    int j = 0;

    for (i = 0; i < 9; i++)
    {
        for (j = 0; j < 9; j++)
        {
            //数组所有元素都赋值为1
            data[i][j] = 1;
        }
    }

    //dp
    for (i = 1; i < 9; i++)
    {
        for (j = 1; j < i; j++)
        {
            data[i][j] = data[i - 1][j] + data[i - 1][j - 1];
        }
    }

    //输出数组所有元素
    for (i = 0; i < 9; i++)
    {
        for (j = 0; j <= i; j++)
        {
            cout << data[i][j] << " ";
        }
        cout << endl;
    }

    int n, pos = 0;
    cin >> n;

    //查找n在数组中的位置
    for (i = 0; i < 9; i++)
    {
        for (j = 0; j <= i; j++)
        {
            pos++;
            if (n == data[i][j])