Manchester


私信TA

用户名:wenyajie

访问量:332120

签 名:

在历史前进的逻辑中前进,这个逻辑就是人心向背的逻辑

等  级
排  名 1
经  验 65567
参赛次数 1
文章发表 188
年  龄 0
在职情况 学生
学  校 Xiamen University
专  业 计算机科学

  自我简介:

在历史前进的逻辑中前进,这个逻辑就是人心向背的逻辑

解题思路:
(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 ;
}


 

0.0分

35 人评分

  评论区

有需要的可参考下:

#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;
}
2021-04-15 17:36:37
#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;
	}
}
2020-03-29 14:04:21
厉害,强强强,找规律我都找晕了
2019-11-19 20:46:14
递归用的怪怪的,还不如再写个循环
2019-11-19 12:11:07
呜呜呜看完了才恍然大悟,回到了小时候找规律的时代
2019-07-21 13:27:31
#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;
}
2019-04-13 11:12:50
#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;
	}
}
2019-03-18 23:36:42
#include <stdio.h>

int main()
{
	int i,j,n;
	printf("请输入行数N:");
	scanf("%d",&n);
	printf("\n");

	for(i=1;i<=n;i++)
	{

	  for(j=i;j<=n;j++)

	  {

	     printf("%d ",(1+j)*j/2-i+1);
	
	  }

	  printf("\n");
	}
 	
	return 0;


}
2018-12-21 13:22:16