C和指针#2.8编程练习
来源:互联网 发布:java swing开发工具 编辑:程序博客网 时间:2024/05/17 00:54
1.题目1:
increment.c-->int increment(int) negate.c-->int negate(int)main.c-->void main()
编辑好后,在linux用命令gcc main.c increment.c negate.c -o main即可,主要考察编译和链接C程序的命令。
//increment.c#include<stdio.h>int increment(int a){ return a+1;}
//negant.c#include<stdio.h>int negate(int b){ return -b;}
//main.c#include<stdio.h>int main(){ printf("%d\n",increment(10)); printf("%d\n",increment(0)); printf("%d\n",increment(-10)); printf("%d\n",negate(10)); printf("%d\n",negate(0)); printf("%d\n",negate(-10));}
2.题目二:
括号匹配问题,本人用栈将其实现,此时已经是回头看这本书了,决定用C++里的模板实现
顺序栈的实现参见本人github源码
匹配思想:从左至右扫描一个字符串(或表达式),则每个右括号将与最近遇到的那个左括号相匹配。则可以在从左至右扫描过程中把所遇到的左括号存放到堆栈中。每当遇到一个右括号时,就将它与栈顶的左括号(如果存在)相匹配,同时从栈顶删除该左括号。 算法思想:设置一个栈,当读到左括号时,左括号进栈。当读到右括号时,则从栈中弹出一个元素,与读到的左括号进行匹配,若匹配成功,继续读入;否则匹配失败,返回FLASE。另外,在算法的开始和结束时,栈都应该是空的.所以匹配到最后还要判断栈是否为空,若非空,则说明匹配失败.
#ifndef _BRACEMATCH_#define _BRACEMATCH_#include"SeqStack.h"BOOL BraceMatch(char *str){ SeqStack<char> st(0, 20); while(*str != '\0') { switch(*str) { case '[': case '(': case '{': st.Push(*str); break; case ']': if((st.GetTop()) != '[') return FALSE; else st.Pop(); break; case ')': if((st.GetTop()) != '(') return FALSE; else st.Pop(); break; case '}': if((st.GetTop()) != '{') return FALSE; else st.Pop(); break; default: break; } str++; } if((st.IsEmpty()) && (*str=='\0')) return TRUE;}#endif
1 0
- C和指针#2.8编程练习
- C和指针-编程练习
- C和指针第四章编程练习
- C和指针第二章编程练习
- C和指针第一章编程练习
- C和指针编程练习---6.18.1
- C和指针第三章--编程练习
- c和指针练习
- C和指针 第六章 编程练习 第一题
- C语言编程(练习1:数组和指针)
- C语言编程(练习2:数组和指针)
- C和指针第九章课后习题编程练习
- C和指针之数组之编程练习2
- C和指针之数组编程练习5 (矩阵相乘)
- C和指针之字符串编程练习1
- C和指针之字符串编程练习6
- C和指针之字符串编程练习3
- c函数和指针练习
- 线段树详解
- 微信订阅号开发者模式,在线调试显示“请求失败” ()
- 杭电 2022 ( 海选女主角 ) java
- mysql删除表中所有数据
- IO流
- C和指针#2.8编程练习
- Java 读写Properties配置文件
- 杭电 2023 ( 求平均成绩 ) java
- macOS Sierra安装Apache2.4+PHP7.0+MySQL5.7.16
- Groovy Closure简介
- 线段树从零开始
- Leetcode 78. Subsets题解
- Java 泛型类 以及 泛型类获取子类的具体参数类型 以及 获取子类型具体参数的实例
- 零基础入门深度学习(4) - 卷积神经网络