C语言实现 杨辉三角

#include<stdio.h>
void printf_(int* p, int* p1, int x)
{

	while (x >= 2)
	{
		for (int i = 1; i <= x - 1; i++)
		{
			*(p + i) = *(p1 + i) + *(p1 + i - 1);

		}
		for (int i = 1; i <= x - 1; i++)
		{
			*(p1 + i) = *(p + i);
		}
		break;
	}

}
int main()
{
	int arr[100] = { 0 };
	int arr1[100] = { 0 };
	for (int i = 0; i <= 10; i++)
	{
		arr[0] = 1;
		arr[i] = 1;
		arr1[0] = 1;
		arr1[i] = 1;
		printf_(arr, arr1, i);
		for (int t = 0; t <= i; t++)
		{
			printf("%d ", arr[t]);
		}
		printf("\n");
	}
}

}

这里只打印了11行 可以调整主函数里面的for循环中的i控制打印行数

(这题写的比当时三子棋的费劲)

做题时的感悟记录 

1.两个for循环嵌套时 i和t写反了

2.函数传址调用后 如果使用p++(区分于*p++) 会导致 p值在整个函数中改变 非常不方便(不如用*(p+i)的形式)

3.传参有关数组元素的时候一定要再三思考 什么+1 -1 真的恶心

猜你喜欢

转载自blog.csdn.net/chara9885/article/details/125798855