解题思路:
(1)1  3  6  10  15       1+(2)-->3+(3)-->6+(4)-->10+(5)-->15     (dtax)        

(2)2  5  9  14              2+(3)-->5+(4)-->9+(5)-->14                                         

(3)4  8  13                  4+(4)-->8+(5)-->13                                                        

(4)7  12                       7+(5)-->12                                                                       

(5)11                            11                                                                               
                                                            1+(1)-->2+(2)-->4+(3)-->7+(4)-->11     (dtay)

输入行数N,num =1,dtax=2,dtay=1,作为初始值;num表示每行第一个数;

按照上面规律递归处理每一行,求num输出;N==0为结束条件;


注意事项:
最后一个num不带空格,可以把它分离出来输出,并且带上换行符;

进入下一行的时候,要更新N,num,dtay,dtax;


参考代码:

#include<stdio.h>
void output(int n,int mun,int dtax,int dtay);
/*----------------------------------------------*/

int main()
{
 int n;
 while(scanf("%d",&n)!=EOF)
  {
  output(n,1,2,0);
  }
  return 0;
}
/*----------------------------------------------*/
void output(int n,int num,int dtax,int dtay)
{
  if(n==0)
  return ;

  int num1=num,dtax1=dtax;   /*save num and dtax,it will be used in next circulation*/

  for(int i=1;i<n;i++)
   {
    printf("%d ",num);
    num+=dtax;
    dtax++;
   }
   printf("%d\n",num);

   n--;
   dtay++;
   num1+=dtay;
   dtax1++;

   output(n,num1,dtax1,dtay);
   return ;
}


点赞(75)
 

0.0分

25 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 14 条评论

攰圭 2年前 回复TA
@bluedam 牛波一
追寻 3年前 回复TA
有需要的可参考下:

#include<stdio.h>
int main()
{
	int n,i,j;
	int b[100];
	for(i=1;i<101;i++)
	{
		b[i]=i;
	}
	scanf("%d",&n);
	int a[n][n];
	a[0][0]=1;
	for(i=1;i<n;i++)
	{
		a[i][0]=a[i-1][0]+b[i];
	}
	for(i=0;i<n;i++)
	{
		for(j=1;j<n-i;j++)
		{
			a[i][j]=a[i][j-1]+b[i+2];
			b[i+2]++;
		}
	}
	for(i=0;i<n;i++)
	{
		for(j=0;j<n-i;j++)
		{
			printf("%d ",a[i][j]);
		}
		printf("\n");
	}
	return 0;
}
越更知鸟 4年前 回复TA
#include<Stdio.h>
int main()
{
	int a=1,b=1,c=2,i,j,k=1,h=3,n;
	scanf("%d",&n); 
	for(i=0;i<n;i++){
		for(j=0;j<n-i;j++){
			printf("%d ",b);
			b+=c;
			c++;
		}
		k=k+a;
		a++;
		c=h;
		h++;
		printf("\n");
		b=k;
	}
}
GDXL 5年前 回复TA
厉害,强强强,找规律我都找晕了
usi 5年前 回复TA
递归用的怪怪的,还不如再写个循环
扬沙 5年前 回复TA
呜呜呜看完了才恍然大悟,回到了小时候找规律的时代
bluedam 5年前 回复TA
#include<stdio.h>

int main()
{
    int N,i,j,temp=1,temp1=1;
    scanf("%d",&N);

   for(i=0;i < N;i++)
   {

       for(j=1;j<= N-i;j++)
       {
            printf("%d ",temp1);
            temp1 = temp1+i+j+1;

       }
       putchar('\n');
       temp = temp+i+1;
       temp1 = temp;
   }

    return 0;
}
侯金昌 5年前 回复TA
@marker #include<iostream> #include<stdio.h>  using namespace std; main()  { 	int N; 	cin>>N; 	for(int i=1,ad1=1, index1=1;index1<=N;i+=ad1,ad1++,index1++){ 		for(int index2=index1, j=i,add2=index2+1;index2<=N;index2++,j+=add2,add2++){ 			cout<<j<<" "; 		} 		cout<<endl; 	} }
侯金昌 5年前 回复TA
#include<iostream>
#include<stdio.h> 
using namespace std;
main() 
{
	int N;
	cin>>N;
	for(int i=1,ad1=1, index1=1;index1<=N;i+=ad1,ad1++,index1++){
		for(int index2=index1, j=i,add2=index2+1;index2<=N;index2++,j+=add2,add2++){
			cout<<j<<" ";
		}
		cout<<endl;
	}
}
marker 6年前 回复TA
@marker 我这个更简单