用c语言编写根据输入的正整数,输出行数为n的杨辉三角形。
时间: 2024-03-08 17:49:56 浏览: 126
以下是用C语言编写输出行数为n的杨辉三角形的代码:
```c
#include <stdio.h>
// 定义组合数函数
int combination(int n, int k) {
int res = 1;
for (int i = 1; i <= k; i++) {
res *= (n - i + 1);
res /= i;
}
return res;
}
int main() {
int n;
printf("请输入杨辉三角形的行数:");
scanf("%d", &n);
// 打印杨辉三角形
for (int i = 0; i < n; i++) {
// 打印空格
for (int j = 0; j < n - i; j++) {
printf(" ");
}
// 打印数字
for (int j = 0; j <= i; j++) {
printf("%-3d ", combination(i, j));
}
printf("\n");
}
return 0;
}
```
运行程序后,输入想要打印的杨辉三角形的行数,即可输出相应的杨辉三角形。
相关问题
C语言编写一个程序,输出杨辉三角形输入格式: 杨辉三角形行数n(正整数,不超过10) 输出格式: 每个整数域宽6位
好的,以下是C语言的代码实现:
```c
#include <stdio.h>
int main() {
int n;
printf("请输入杨辉三角形的行数n(正整数,不超过10):");
scanf("%d", &n);
int triangle[10][10] = {0};
for (int i = 0; i < n; i++) {
triangle[i][0] = 1;
triangle[i][i] = 1;
}
for (int i = 2; i < n; i++) {
for (int j = 1; j < i; j++) {
triangle[i][j] = triangle[i-1][j-1] + triangle[i-1][j];
}
}
for (int i = 0; i < n; i++) {
for (int j = 0; j <= i; j++) {
printf("%6d", triangle[i][j]);
}
printf("\n");
}
return 0;
}
```
示例输出:
```
请输入杨辉三角形的行数n(正整数,不超过10):7
1
1 1
1 2 1
1 3 3 1
1 4 6 4 1
1 5 10 10 5 1
```
问题描述 利用队列相关操作实现打印输出指定行数的杨辉三角形。 输入描述 输入要打印的行数,15>n>0。 输出描述 输出杨辉三角形。注:每个数字设置4个域宽,上一行的第一个数字比下一行第一个数字右缩进2个空格。 用c语言编写代码
杨辉三角是一个经典的动态规划问题,可以使用队列数据结构来辅助存储每一层的元素。下面是使用 C 语言实现的代码示例:
```c
#include <stdio.h>
#include <stdlib.h>
// 定义队列结构体,用于存储杨辉三角的每行
typedef struct {
int data[100]; // 队列中存放整数
int front; // 队首元素索引
int rear; // 队尾元素索引
} Queue;
// 初始化队列
void initQueue(Queue* queue) {
queue->front = -1;
queue->rear = -1;
}
// 入队操作
void enqueue(Queue* queue, int num) {
if (queue->rear == queue->front + 100 - 1) {
printf("队列已满,无法入队\n");
return;
}
queue->data[++queue->rear] = num;
}
// 出队操作
int dequeue(Queue* queue) {
if (queue->front == queue->rear) {
printf("队列为空,无法出队\n");
return -1;
}
return queue->data[queue->front++];
}
// 打印队列内容,模拟杨辉三角的输出格式
void printTriangle(Queue* queue, int level) {
for (int i = 0; i <= level; ++i) {
for (int j = 0; j <= level - i);
printf("%4d", dequeue(&queue)); // 输出当前节点
for (int k = 0; k < space; ++k)
printf(" ");
if (j != level - i)
printf("%4d", dequeue(&queue)); // 输出下一个节点
printf("\n");
}
enqueue(&queue, 0); // 每一层结束后添加0
}
}
int main() {
int n;
printf("请输入要打印的行数(n > 0): ");
scanf("%d", &n);
if (n <= 0) {
printf("输入错误,请输入正整数。\n");
return 1;
}
Queue triangle;
initQueue(&triangle);
// 构建杨辉三角
for (int row = 1; row <= n; ++row) {
for (int col = 0; col <= row; ++col) {
if (col == 0 || col == row) {
enqueue(&triangle, 1);
} else {
enqueue(&triangle, dequeue(&triangle) + dequeue(&triangle));
}
}
printTriangle(&triangle, row);
}
return 0;
}
```
这个程序首先定义了一个队列结构体,并实现了基本的队列操作。然后通过构建杨辉三角的核心算法(递归公式),将每层的元素依次加入队列,最后按照规定的格式打印出来。
阅读全文