c语言中关于n个元素的栈和c1赋不上值的问题

问题:一个大小为n的栈,现已有n个元素,第n+1个能否直接弹出?

回答:在数据结构中,这个不可以,当栈满时,元素不可能被压栈,也不存在弹出,除非这个是你自己设计的功能,push时,有返回值,当栈满时,直接返回要压栈的值,正常的push是void(无返回值的)。

追问:如果在pascal里面又是怎么样呢?没有pascal的标签。只能打了个C/C++的。
补充:在pascal是一样的,数据结构适合所有语言,也可以说是语言无关的,在pascal中,一般push是个过程(procedure),它是没有返回值的。你当然可以做一个这样的function,当栈满时,直接返回push参数的值,(但这个在实际编程中没意义)。

问题:这个程序为什么c1赋不上值?
#include <stdio.h>
#include <stdlib.h>
int main()
{
    char c1,c2;
    scanf("%d,%d",&c1,&c2);
    printf("%d,%d\n",c1,c2);
    printf("%c,%c\n",c1,c2);
system("pause");
return 0;
}

回答:
这个c1,c2为char类型,而你用%d来接收它,结果当然不对
要改为
scanf("%c,%c",&c1,&c2);
然后若输入
a,b
结果为
97,98
a,b
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是用C语言实现建立一个顺序的代码: ```c #include <stdio.h> #include <stdlib.h> // 定义结构体 typedef struct { int *data; // 的数据 int top; // 顶指针 int size; // 的大小 } SeqStack; // 初始化 void InitStack(SeqStack *pStack, int n) { pStack->data = (int *)malloc(sizeof(int) * n); // 分配n个int大小的空间 pStack->top = -1; // 顶指针初始化为-1 pStack->size = n; // 的大小为n } // 判断是否为空 int IsEmpty(SeqStack *pStack) { return pStack->top == -1; } // 判断是否已满 int IsFull(SeqStack *pStack) { return pStack->top == pStack->size - 1; } // 入栈 void Push(SeqStack *pStack, int x) { if (IsFull(pStack)) { printf("Stack is full.\n"); return; } pStack->top++; pStack->data[pStack->top] = x; } // 出 int Pop(SeqStack *pStack) { if (IsEmpty(pStack)) { printf("Stack is empty.\n"); return -1; } int x = pStack->data[pStack->top]; pStack->top--; return x; } // 获取顶元素 int Top(SeqStack *pStack) { if (IsEmpty(pStack)) { printf("Stack is empty.\n"); return -1; } return pStack->data[pStack->top]; } // 输出元素 void PrintStack(SeqStack *pStack) { if (IsEmpty(pStack)) { printf("Stack is empty.\n"); return; } printf("Stack: "); for (int i = pStack->top; i >= 0; i--) { printf("%d ", pStack->data[i]); } printf("\n"); } int main() { int n = 5; SeqStack stack; InitStack(&stack, n); for (int i = 0; i < n; i++) { Push(&stack, i + 1); } PrintStack(&stack); Pop(&stack); PrintStack(&stack); printf("Top element: %d\n", Top(&stack)); return 0; } ``` 在这个例子,我们定义了一个结构体 `SeqStack`,其包含了的数据、顶指针和的大小。我们通过 `InitStack` 函数初始化,并通过 `Push`、`Pop`、`Top` 和 `PrintStack` 函数实现了入栈、出、获取顶元素和输出元素的功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值