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日

悬赏问题

  • ¥50 求解vmware的网络模式问题 别拿AI回答
  • ¥24 EFS加密后,在同一台电脑解密出错,证书界面找不到对应指纹的证书,未备份证书,求在原电脑解密的方法,可行即采纳
  • ¥15 springboot 3.0 实现Security 6.x版本集成
  • ¥15 PHP-8.1 镜像无法用dockerfile里的CMD命令启动 只能进入容器启动,如何解决?(操作系统-ubuntu)
  • ¥30 请帮我解决一下下面六个代码
  • ¥15 关于资源监视工具的e-care有知道的嘛
  • ¥35 MIMO天线稀疏阵列排布问题
  • ¥60 用visual studio编写程序,利用间接平差求解水准网
  • ¥15 Llama如何调用shell或者Python
  • ¥20 谁能帮我挨个解读这个php语言编的代码什么意思?