158146 2022-12-28 18:53 采纳率: 87%
浏览 17
已结题

为什么最后输入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 <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,sum1=0;
    cin>>n;
    if(n==data[i][j])
    {
        for(int k=1;k<=i-1;k++)
        {
         sum1+=k;
         
            }
            cout<<sum1;
   }
         cout<<sum1+j<<endl;

    return 0;
}
  • 写回答

2条回答 默认 最新

  • 嗷呜大嘴狼 2022-12-28 19:18
    关注

    你好!

    你的程序中有一些问题:

    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])
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 1月5日
  • 已采纳回答 12月28日
  • 创建了问题 12月28日

悬赏问题

  • ¥15 全部备份安卓app数据包括密码,可以复制到另一手机上运行
  • ¥15 Python3.5 相关代码写作
  • ¥20 测距传感器数据手册i2c
  • ¥15 RPA正常跑,cmd输入cookies跑不出来
  • ¥15 求帮我调试一下freefem代码
  • ¥15 matlab代码解决,怎么运行
  • ¥15 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
  • ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
  • ¥15 用windows做服务的同志有吗