HDU

来源:互联网 发布:java怎么上传图片 编辑:程序博客网 时间:2024/05/29 16:56

OP:怎么说呢......printf("\b") 有毒 !!

因为看到整数之间用空格隔开,所以想用"\b"解决,WA了三四次,然后就想起了曾经被printf("\b")支配的恐惧......

改回 :

if( j != i+1 ) printf(" ") ;

就A了orz...

题目地址:HDU - 2032

题目描述:

还记得中学时候学过的杨辉三角吗?具体的定义这里不再描述,你可以参考以下的图形:
1
1 1
1 2 1
1 3 3 1
1 4 6 4 1
1 5 10 10 5 1

Input
输入数据包含多个测试实例,每个测试实例的输入只包含一个正整数n(1<=n<=30),表示将要输出的杨辉三角的层数。
Output
对应于每一个输入,请输出相应层数的杨辉三角,每一层的整数之间用一个空格隔开,每一个杨辉三角后面加一个空行。
Sample Input
2 3
Sample Output
11 111 11 2 1

#include<stdio.h>#include<string.h>using namespace std;int dp[60][60] ;int main() {   //杨辉三角首先考虑DP memset( dp , 0 , sizeof(dp) ) ;//初始化高维数组(三角中每个数为其"肩上"两数之和) dp[0][1] = 1 ;  //行数从0开始,列数从1开始 int n ;while( scanf("%d" , &n  ) != EOF ) {for(int i=0 ; i<n ; i++ ) {for(int j=1 ; j<=i+1 ; j++ ) {dp[i+1][j+1] = dp[i][j+1] + dp[i][j] ;//递推式 printf("%d" , dp[i+1][j+1] ) ;if( j != i+1 ) printf(" ") ;//输出之间以空格隔开 }printf("\n") ;}printf("\n") ;}return 0 ;}






原创粉丝点击