- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
你好,我正在用 c 编写一个小的二叉树程序,在执行操作后,主菜单会打印两次,然后才能扫描下一个输入。有什么想法可以防止这种情况发生吗?
#include<stdio.h>
#include<stdlib.h>
struct btree{
int id, val;
struct btree *left, *right;
};
typedef struct btree node;
void myparent(node *tree, int myid, node **parent){
if(tree->id==(myid/2))
*parent = tree;
if(tree->left)
myparent(tree->left, myid, parent);
if(tree->right)
myparent(tree->right, myid, parent);
}
void insert(node **tree, node *item){
node *parent;
if(item->id==1)
*tree=item;
else{
myparent(*tree, item->id,&parent);
if((item->id)%2)
parent->right=item;
else
parent->left=item;
}
}
void preorder_print(node *tree){
if (tree!=NULL){
printf(" %d\n",tree->val);
printf("\t");
preorder_print(tree->left);
printf("\n");
preorder_print(tree->right);
}
}
void inorder_print(node *tree){
if (tree!= NULL){
inorder_print(tree->left);
printf("%d ", tree->val);
inorder_print(tree->right);
}
}
void printout(node *tree){
if(tree->left)
printout(tree->left);
printf("%d\n", tree->val);
if(tree->right)
printout(tree->right);
}
main(){
char opn;
node *root, *curr;
int idcount=1, inp=0;
root=NULL;
//input 9999 is the exit point
do{
printf("\n ### Binary Tree Operations ### \n\n");
printf("\n Enter one of the following Operations:\n a- Add\n e- Empty\n i- List IN ORDER\n r- List PRE-ORDER\n p- List POST ORDER\n q- Quit\n");
scanf("%c", &opn);
switch (opn) {
case 1:
case 'a':
case 'A':
printf("\nEnter a Node>");
scanf("%d",&inp);
curr=(node*)malloc(sizeof(node));
curr->val=inp;
curr->id=idcount++;
curr->left = curr->right = NULL;
insert(&root, curr);
printf("The number was inserted\n");
break;
case 2:
case 'e':
case 'E':
printf("The value was deleted\n");
break;
case 3:
case 'i':
case 'I':
printf("IN ORDER Tree: \n");
inorder_print(root);
break;
case 4:
case 'r':
case 'R':
printf("PRE ORDER Tree: \n");
preorder_print (root);
break;
case 5:
case 'p':
case 'P':
printf("POST ORDER Tree: \n");
printout(root);
break;
case 6:
case 'q':
case 'Q':
printf("\n\n Terminating \n\n");
exit(1);
default:
printf("Invalid Opition \n \n");
break;
}
printf("\n Press any key to continue . . .");
} while (opn != 'q');
/* printf("\n Entered Binary Tree is \n");
printout(root);
return 0; */
}
即使未输入任何内容,也会打印出包含无效选项的菜单所以输出看起来像:
### Binary Tree Operations ###
Enter one of the following Operations:
a- Add
e- Empty
i- List IN ORDER
r- List PRE-ORDER
p- List POST ORDER
q- Quit
a
Enter a Node>1
The number was inserted
Press any key to continue . . .
### Binary Tree Operations ###
Enter one of the following Operations:
a- Add
e- Empty
i- List IN ORDER
r- List PRE-ORDER
p- List POST ORDER
q- Quit
Invalid Opition
Press any key to continue . . .
### Binary Tree Operations ###
Enter one of the following Operations:
a- Add
e- Empty
i- List IN ORDER
r- List PRE-ORDER
p- List POST ORDER
q- Quit
i
IN ORDER Tree:
2 4 1 3 5
Press any key to continue . . .
### Binary Tree Operations ###
Enter one of the following Operations:
a- Add
e- Empty
i- List IN ORDER
r- List PRE-ORDER
p- List POST ORDER
q- Quit
Invalid Opition
Press any key to continue . . .
### Binary Tree Operations ###
Enter one of the following Operations:
a- Add
e- Empty
i- List IN ORDER
r- List PRE-ORDER
p- List POST ORDER
q- Quit
q
Terminating
最佳答案
如果“未输入任何内容”,
scanf
将使用带有上述代码的换行符 (\n
) 填充 opn
。因为你没有一个 case
,它会被默认处理。
即使输入了一个字符,换行符也会保留在缓冲区中以供下一次 scanf
调用。
关于c - Switch Case Default case C题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13615202/
我经常在 ATS 中看到使用 case、case+ 或 case- 形成的 case 表达式。有什么区别? 最佳答案 如果表达式不详尽,使用 case 会发出警告,case+ 会产生错误,而 case
我有一个导入时全部大写的表,我想将其转换为正确的大小写。你们用什么脚本来完成这个? 最佳答案 这个函数: “正确大小写”由空格分隔的所有“大写”单词 保留“小写单词” 即使对于非英语字母也能正常工作
#include int main() { switch(2) { case 1: if(1)
我已经四处寻找了一段时间,如果我使用的术语不当,请原谅我... 代码的目标是在输入为 0 时更新 Aout1 和 Aout0,输出对应于 7 段显示,但出现以下错误: “错误 (10170):Four
我正在尝试按照 PostgreSQL 手册中的说明进行操作。 PostgreSQL: Documentation: 9.1: Control Structures 我的 PostgreSQL 服务器是
我有一个状态机,其中有几个非常相似的状态。我可以为每个状态编写它,如下例所示: module CHECK_FSM ( GO, DONE, CLK, RESETN ); input GO;
如何使用或创建案例? 就像是: string str; case (str) "abc" || "dfg": begin //some code end "yfg":
这个问题已经有答案了: Are double and single quotes interchangeable in JavaScript? (23 个回答) 已关闭 9 年前。 我正在学习Java
汽车 Make | Model | Year | Color Honda | Accord | 12 | Red Lexus | IS | 14 |
如何使用当前 case 语句的值跳转到 switch-case 条件下的另一个 case 语句? 是否可以使用 switch case 来实现这种事情,或者是否有其他实现方式? 有可能实现吗?如果没有
我理解下面的代码。 var day = 2; switch (day) { case 1: document.write("Monday"); break;
这是有效的。 object FilesToDFDS { case class Student(id: Int, name: String, dept:String) def main(
我对 VHDL 还是个新手。我需要在 CASE 语句中为多个信号赋值,如下所示: CASE input24 IS WHEN "00" THEN output0
我有这个 case 语句,它给出了一个错误“变量 constant1 未使用”。它似乎忽略了变量并返回了第一行,因此变量显然没有范围。如果我用数字 1 替换常量,那么它就可以工作。在 Elixir 中
在 MySQL 中,是否可以在 SELECT 子句中有两个 CASE 语句,其中第二个 CASE 语句依赖于第一个 CASE 语句? 例如,考虑以下查询: SELECT CASE WHEN `user
我正在尝试一个挑战,我需要获得一个随机数,并在没有重复的情况下打印数字内的数字总和:例如,123 将打印 6 ( 1 + 2 + 3 ),而 32111 将做同样的事情(因为我们没有在我们的总和中添加
当有人试图更新当前未存储在我的散列中的值时,我想立即返回 when 'add' 而无需重新启动整个 case声明,因为我已经知道他们想要添加并且不想再次提示他们。 有没有一种方法可以在不重新启动整个案
老 C 程序员可以在 Swift 方面得到一些帮助。 我不太了解 if-case 语法。例如: if case 20...30 = age { print ("in range.") } cas
老 C 程序员可以在 Swift 方面得到一些帮助。 我不太了解 if-case 语法。例如: if case 20...30 = age { print ("in range.") } cas
我有一个 ArrayList,其中包含以下字符串:[name, age, gender, salary] . 有没有办法可以将 ArrayList 中的值用作 case 表达式? 显而易见的答案是否定
我是一名优秀的程序员,十分优秀!