cs-2124: checkin Assignment 2

This commit is contained in:
Price Hiller 2024-02-09 13:20:39 -06:00
parent c37007b077
commit 7523a5aa42
No known key found for this signature in database
22 changed files with 1000 additions and 0 deletions

View File

@ -0,0 +1,225 @@
---
Language: Cpp
# BasedOnStyle: LLVM
AccessModifierOffset: -2
AlignAfterOpenBracket: Align
AlignArrayOfStructures: None
AlignConsecutiveAssignments:
Enabled: false
AcrossEmptyLines: false
AcrossComments: false
AlignCompound: false
PadOperators: true
AlignConsecutiveBitFields:
Enabled: false
AcrossEmptyLines: false
AcrossComments: false
AlignCompound: false
PadOperators: false
AlignConsecutiveDeclarations:
Enabled: false
AcrossEmptyLines: false
AcrossComments: false
AlignCompound: false
PadOperators: false
AlignConsecutiveMacros:
Enabled: false
AcrossEmptyLines: false
AcrossComments: false
AlignCompound: false
PadOperators: false
AlignEscapedNewlines: Right
AlignOperands: Align
AlignTrailingComments:
Kind: Always
OverEmptyLines: 0
AllowAllArgumentsOnNextLine: true
AllowAllParametersOfDeclarationOnNextLine: true
AllowShortBlocksOnASingleLine: Never
AllowShortCaseLabelsOnASingleLine: false
AllowShortEnumsOnASingleLine: true
AllowShortFunctionsOnASingleLine: All
AllowShortIfStatementsOnASingleLine: Never
AllowShortLambdasOnASingleLine: All
AllowShortLoopsOnASingleLine: false
AlwaysBreakAfterDefinitionReturnType: None
AlwaysBreakAfterReturnType: None
AlwaysBreakBeforeMultilineStrings: false
AlwaysBreakTemplateDeclarations: MultiLine
AttributeMacros:
- __capability
BinPackArguments: true
BinPackParameters: true
BitFieldColonSpacing: Both
BraceWrapping:
AfterCaseLabel: false
AfterClass: false
AfterControlStatement: Never
AfterEnum: false
AfterExternBlock: false
AfterFunction: false
AfterNamespace: false
AfterObjCDeclaration: false
AfterStruct: false
AfterUnion: false
BeforeCatch: false
BeforeElse: false
BeforeLambdaBody: false
BeforeWhile: false
IndentBraces: false
SplitEmptyFunction: true
SplitEmptyRecord: true
SplitEmptyNamespace: true
BreakAfterAttributes: Never
BreakAfterJavaFieldAnnotations: false
BreakArrays: true
BreakBeforeBinaryOperators: None
BreakBeforeConceptDeclarations: Always
BreakBeforeBraces: Attach
BreakBeforeInlineASMColon: OnlyMultiline
BreakBeforeTernaryOperators: true
BreakConstructorInitializers: BeforeColon
BreakInheritanceList: BeforeColon
BreakStringLiterals: true
ColumnLimit: 80
CommentPragmas: '^ IWYU pragma:'
CompactNamespaces: false
ConstructorInitializerIndentWidth: 4
ContinuationIndentWidth: 4
Cpp11BracedListStyle: true
DerivePointerAlignment: false
DisableFormat: false
EmptyLineAfterAccessModifier: Never
EmptyLineBeforeAccessModifier: LogicalBlock
ExperimentalAutoDetectBinPacking: false
FixNamespaceComments: true
ForEachMacros:
- foreach
- Q_FOREACH
- BOOST_FOREACH
IfMacros:
- KJ_IF_MAYBE
IncludeBlocks: Preserve
IncludeCategories:
- Regex: '^"(llvm|llvm-c|clang|clang-c)/'
Priority: 2
SortPriority: 0
CaseSensitive: false
- Regex: '^(<|"(gtest|gmock|isl|json)/)'
Priority: 3
SortPriority: 0
CaseSensitive: false
- Regex: '.*'
Priority: 1
SortPriority: 0
CaseSensitive: false
IncludeIsMainRegex: '(Test)?$'
IncludeIsMainSourceRegex: ''
IndentAccessModifiers: false
IndentCaseBlocks: false
IndentCaseLabels: false
IndentExternBlock: AfterExternBlock
IndentGotoLabels: true
IndentPPDirectives: None
IndentRequiresClause: true
IndentWidth: 4
IndentWrappedFunctionNames: false
InsertBraces: false
InsertNewlineAtEOF: false
InsertTrailingCommas: None
IntegerLiteralSeparator:
Binary: 0
BinaryMinDigits: 0
Decimal: 0
DecimalMinDigits: 0
Hex: 0
HexMinDigits: 0
JavaScriptQuotes: Leave
JavaScriptWrapImports: true
KeepEmptyLinesAtTheStartOfBlocks: true
LambdaBodyIndentation: Signature
LineEnding: DeriveLF
MacroBlockBegin: ''
MacroBlockEnd: ''
MaxEmptyLinesToKeep: 1
NamespaceIndentation: None
ObjCBinPackProtocolList: Auto
ObjCBlockIndentWidth: 2
ObjCBreakBeforeNestedBlockParam: true
ObjCSpaceAfterProperty: false
ObjCSpaceBeforeProtocolList: true
PackConstructorInitializers: BinPack
PenaltyBreakAssignment: 2
PenaltyBreakBeforeFirstCallParameter: 19
PenaltyBreakComment: 300
PenaltyBreakFirstLessLess: 120
PenaltyBreakOpenParenthesis: 0
PenaltyBreakString: 1000
PenaltyBreakTemplateDeclaration: 10
PenaltyExcessCharacter: 1000000
PenaltyIndentedWhitespace: 0
PenaltyReturnTypeOnItsOwnLine: 60
PointerAlignment: Right
PPIndentWidth: -1
QualifierAlignment: Leave
ReferenceAlignment: Pointer
ReflowComments: true
RemoveBracesLLVM: false
RemoveSemicolon: false
RequiresClausePosition: OwnLine
RequiresExpressionIndentation: OuterScope
SeparateDefinitionBlocks: Leave
ShortNamespaceLines: 1
SortIncludes: CaseSensitive
SortJavaStaticImport: Before
SortUsingDeclarations: LexicographicNumeric
SpaceAfterCStyleCast: false
SpaceAfterLogicalNot: false
SpaceAfterTemplateKeyword: true
SpaceAroundPointerQualifiers: Default
SpaceBeforeAssignmentOperators: true
SpaceBeforeCaseColon: false
SpaceBeforeCpp11BracedList: false
SpaceBeforeCtorInitializerColon: true
SpaceBeforeInheritanceColon: true
SpaceBeforeParens: ControlStatements
SpaceBeforeParensOptions:
AfterControlStatements: true
AfterForeachMacros: true
AfterFunctionDefinitionName: false
AfterFunctionDeclarationName: false
AfterIfMacros: true
AfterOverloadedOperator: false
AfterRequiresInClause: false
AfterRequiresInExpression: false
BeforeNonEmptyParentheses: false
SpaceBeforeRangeBasedForLoopColon: true
SpaceBeforeSquareBrackets: false
SpaceInEmptyBlock: false
SpaceInEmptyParentheses: false
SpacesBeforeTrailingComments: 1
SpacesInAngles: Never
SpacesInConditionalStatement: false
SpacesInContainerLiterals: true
SpacesInCStyleCastParentheses: false
SpacesInLineCommentPrefix:
Minimum: 1
Maximum: -1
SpacesInParentheses: false
SpacesInSquareBrackets: false
Standard: Latest
StatementAttributeLikeMacros:
- Q_EMIT
StatementMacros:
- Q_UNUSED
- QT_REQUIRE_VERSION
TabWidth: 8
UseTab: Never
WhitespaceSensitiveMacros:
- BOOST_PP_STRINGIZE
- CF_SWIFT_NAME
- NS_SWIFT_NAME
- PP_STRINGIZE
- STRINGIZE
...

View File

@ -0,0 +1,7 @@
bin
CMakeFiles
CMakeCache.txt
cmake_install.cmake
README.pdf
*.tex
.tex-out

Binary file not shown.

View File

@ -0,0 +1,11 @@
cmake_minimum_required(VERSION 3.25)
set(SOURCES src/lib/lib.h src/lib/lib.c src/lib/vec.h)
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY bin)
project(AssignmentTwo LANGUAGES C)
add_executable(PartOne src/part_one.c ${SOURCES})
add_executable(PartTwo src/part_two.c ${SOURCES})
add_executable(PartThree src/part_three.c ${SOURCES})

View File

@ -0,0 +1,296 @@
# CMAKE generated file: DO NOT EDIT!
# Generated by "Unix Makefiles" Generator, CMake Version 3.28
# Default target executed when no arguments are given to make.
default_target: all
.PHONY : default_target
# Allow only one "make -f Makefile2" at a time, but pass parallelism.
.NOTPARALLEL:
#=============================================================================
# Special targets provided by cmake.
# Disable implicit rules so canonical targets will work.
.SUFFIXES:
# Disable VCS-based implicit rules.
% : %,v
# Disable VCS-based implicit rules.
% : RCS/%
# Disable VCS-based implicit rules.
% : RCS/%,v
# Disable VCS-based implicit rules.
% : SCCS/s.%
# Disable VCS-based implicit rules.
% : s.%
.SUFFIXES: .hpux_make_needs_suffix_list
# Command-line flag to silence nested $(MAKE).
$(VERBOSE)MAKESILENT = -s
#Suppress display of executed commands.
$(VERBOSE).SILENT:
# A target that is always out of date.
cmake_force:
.PHONY : cmake_force
#=============================================================================
# Set environment variables for the build.
# The shell in which to execute make rules.
SHELL = /bin/sh
# The CMake executable.
CMAKE_COMMAND = /usr/bin/cmake
# The command to remove a file.
RM = /usr/bin/cmake -E rm -f
# Escaping for special characters.
EQUALS = =
# The top-level source directory on which CMake was run.
CMAKE_SOURCE_DIR = /home/sam/Git/College/Spring-2023/CS-2124/Assignment-2
# The top-level build directory on which CMake was run.
CMAKE_BINARY_DIR = /home/sam/Git/College/Spring-2023/CS-2124/Assignment-2
#=============================================================================
# Targets provided globally by CMake.
# Special rule for the target edit_cache
edit_cache:
@$(CMAKE_COMMAND) -E cmake_echo_color "--switch=$(COLOR)" --cyan "Running CMake cache editor..."
/usr/bin/ccmake -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR)
.PHONY : edit_cache
# Special rule for the target edit_cache
edit_cache/fast: edit_cache
.PHONY : edit_cache/fast
# Special rule for the target rebuild_cache
rebuild_cache:
@$(CMAKE_COMMAND) -E cmake_echo_color "--switch=$(COLOR)" --cyan "Running CMake to regenerate build system..."
/usr/bin/cmake --regenerate-during-build -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR)
.PHONY : rebuild_cache
# Special rule for the target rebuild_cache
rebuild_cache/fast: rebuild_cache
.PHONY : rebuild_cache/fast
# The main all target
all: cmake_check_build_system
$(CMAKE_COMMAND) -E cmake_progress_start /home/sam/Git/College/Spring-2023/CS-2124/Assignment-2/CMakeFiles /home/sam/Git/College/Spring-2023/CS-2124/Assignment-2//CMakeFiles/progress.marks
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 all
$(CMAKE_COMMAND) -E cmake_progress_start /home/sam/Git/College/Spring-2023/CS-2124/Assignment-2/CMakeFiles 0
.PHONY : all
# The main clean target
clean:
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 clean
.PHONY : clean
# The main clean target
clean/fast: clean
.PHONY : clean/fast
# Prepare targets for installation.
preinstall: all
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 preinstall
.PHONY : preinstall
# Prepare targets for installation.
preinstall/fast:
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 preinstall
.PHONY : preinstall/fast
# clear depends
depend:
$(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 1
.PHONY : depend
#=============================================================================
# Target rules for targets named PartOne
# Build rule for target.
PartOne: cmake_check_build_system
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 PartOne
.PHONY : PartOne
# fast build rule for target.
PartOne/fast:
$(MAKE) $(MAKESILENT) -f CMakeFiles/PartOne.dir/build.make CMakeFiles/PartOne.dir/build
.PHONY : PartOne/fast
#=============================================================================
# Target rules for targets named PartTwo
# Build rule for target.
PartTwo: cmake_check_build_system
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 PartTwo
.PHONY : PartTwo
# fast build rule for target.
PartTwo/fast:
$(MAKE) $(MAKESILENT) -f CMakeFiles/PartTwo.dir/build.make CMakeFiles/PartTwo.dir/build
.PHONY : PartTwo/fast
#=============================================================================
# Target rules for targets named PartThree
# Build rule for target.
PartThree: cmake_check_build_system
$(MAKE) $(MAKESILENT) -f CMakeFiles/Makefile2 PartThree
.PHONY : PartThree
# fast build rule for target.
PartThree/fast:
$(MAKE) $(MAKESILENT) -f CMakeFiles/PartThree.dir/build.make CMakeFiles/PartThree.dir/build
.PHONY : PartThree/fast
src/lib/lib.o: src/lib/lib.c.o
.PHONY : src/lib/lib.o
# target to build an object file
src/lib/lib.c.o:
$(MAKE) $(MAKESILENT) -f CMakeFiles/PartOne.dir/build.make CMakeFiles/PartOne.dir/src/lib/lib.c.o
$(MAKE) $(MAKESILENT) -f CMakeFiles/PartTwo.dir/build.make CMakeFiles/PartTwo.dir/src/lib/lib.c.o
$(MAKE) $(MAKESILENT) -f CMakeFiles/PartThree.dir/build.make CMakeFiles/PartThree.dir/src/lib/lib.c.o
.PHONY : src/lib/lib.c.o
src/lib/lib.i: src/lib/lib.c.i
.PHONY : src/lib/lib.i
# target to preprocess a source file
src/lib/lib.c.i:
$(MAKE) $(MAKESILENT) -f CMakeFiles/PartOne.dir/build.make CMakeFiles/PartOne.dir/src/lib/lib.c.i
$(MAKE) $(MAKESILENT) -f CMakeFiles/PartTwo.dir/build.make CMakeFiles/PartTwo.dir/src/lib/lib.c.i
$(MAKE) $(MAKESILENT) -f CMakeFiles/PartThree.dir/build.make CMakeFiles/PartThree.dir/src/lib/lib.c.i
.PHONY : src/lib/lib.c.i
src/lib/lib.s: src/lib/lib.c.s
.PHONY : src/lib/lib.s
# target to generate assembly for a file
src/lib/lib.c.s:
$(MAKE) $(MAKESILENT) -f CMakeFiles/PartOne.dir/build.make CMakeFiles/PartOne.dir/src/lib/lib.c.s
$(MAKE) $(MAKESILENT) -f CMakeFiles/PartTwo.dir/build.make CMakeFiles/PartTwo.dir/src/lib/lib.c.s
$(MAKE) $(MAKESILENT) -f CMakeFiles/PartThree.dir/build.make CMakeFiles/PartThree.dir/src/lib/lib.c.s
.PHONY : src/lib/lib.c.s
src/part_one.o: src/part_one.c.o
.PHONY : src/part_one.o
# target to build an object file
src/part_one.c.o:
$(MAKE) $(MAKESILENT) -f CMakeFiles/PartOne.dir/build.make CMakeFiles/PartOne.dir/src/part_one.c.o
.PHONY : src/part_one.c.o
src/part_one.i: src/part_one.c.i
.PHONY : src/part_one.i
# target to preprocess a source file
src/part_one.c.i:
$(MAKE) $(MAKESILENT) -f CMakeFiles/PartOne.dir/build.make CMakeFiles/PartOne.dir/src/part_one.c.i
.PHONY : src/part_one.c.i
src/part_one.s: src/part_one.c.s
.PHONY : src/part_one.s
# target to generate assembly for a file
src/part_one.c.s:
$(MAKE) $(MAKESILENT) -f CMakeFiles/PartOne.dir/build.make CMakeFiles/PartOne.dir/src/part_one.c.s
.PHONY : src/part_one.c.s
src/part_three.o: src/part_three.c.o
.PHONY : src/part_three.o
# target to build an object file
src/part_three.c.o:
$(MAKE) $(MAKESILENT) -f CMakeFiles/PartThree.dir/build.make CMakeFiles/PartThree.dir/src/part_three.c.o
.PHONY : src/part_three.c.o
src/part_three.i: src/part_three.c.i
.PHONY : src/part_three.i
# target to preprocess a source file
src/part_three.c.i:
$(MAKE) $(MAKESILENT) -f CMakeFiles/PartThree.dir/build.make CMakeFiles/PartThree.dir/src/part_three.c.i
.PHONY : src/part_three.c.i
src/part_three.s: src/part_three.c.s
.PHONY : src/part_three.s
# target to generate assembly for a file
src/part_three.c.s:
$(MAKE) $(MAKESILENT) -f CMakeFiles/PartThree.dir/build.make CMakeFiles/PartThree.dir/src/part_three.c.s
.PHONY : src/part_three.c.s
src/part_two.o: src/part_two.c.o
.PHONY : src/part_two.o
# target to build an object file
src/part_two.c.o:
$(MAKE) $(MAKESILENT) -f CMakeFiles/PartTwo.dir/build.make CMakeFiles/PartTwo.dir/src/part_two.c.o
.PHONY : src/part_two.c.o
src/part_two.i: src/part_two.c.i
.PHONY : src/part_two.i
# target to preprocess a source file
src/part_two.c.i:
$(MAKE) $(MAKESILENT) -f CMakeFiles/PartTwo.dir/build.make CMakeFiles/PartTwo.dir/src/part_two.c.i
.PHONY : src/part_two.c.i
src/part_two.s: src/part_two.c.s
.PHONY : src/part_two.s
# target to generate assembly for a file
src/part_two.c.s:
$(MAKE) $(MAKESILENT) -f CMakeFiles/PartTwo.dir/build.make CMakeFiles/PartTwo.dir/src/part_two.c.s
.PHONY : src/part_two.c.s
# Help Target
help:
@echo "The following are some of the valid targets for this Makefile:"
@echo "... all (the default if no target is provided)"
@echo "... clean"
@echo "... depend"
@echo "... edit_cache"
@echo "... rebuild_cache"
@echo "... PartOne"
@echo "... PartThree"
@echo "... PartTwo"
@echo "... src/lib/lib.o"
@echo "... src/lib/lib.i"
@echo "... src/lib/lib.s"
@echo "... src/part_one.o"
@echo "... src/part_one.i"
@echo "... src/part_one.s"
@echo "... src/part_three.o"
@echo "... src/part_three.i"
@echo "... src/part_three.s"
@echo "... src/part_two.o"
@echo "... src/part_two.i"
@echo "... src/part_two.s"
.PHONY : help
#=============================================================================
# Special targets to cleanup operation of make.
# Special rule to run CMake to check the build system integrity.
# No rule that depends on this can have commands that come from listfiles
# because they might be regenerated.
cmake_check_build_system:
$(CMAKE_COMMAND) -S$(CMAKE_SOURCE_DIR) -B$(CMAKE_BINARY_DIR) --check-build-system CMakeFiles/Makefile.cmake 0
.PHONY : cmake_check_build_system

View File

@ -0,0 +1,47 @@
* Assignment 2
- ABC123: =zfp106=
- Name: =Price Hiller=
- Course: =CS2124=
- Section: =0C3=
- Semester: =Spring 2024=
** Source Code
The full source code for this project can be found at [[https://git.orion-technologies.io/Price/college/src/branch/Development/Spring-2023/CS-2124/Assignment-2]]
** Running the Programs
1. Install [[https://cmake.org/download/][cmake]] version 3.25 or greater.
2. Ensure you have a recent version of ~make~ at the time of writing. This project successfully
compiles with ~GNU make~ version ~4.4.1~.
3. Go the directory with ~CMakeLists.txt~ and run ~cmake .~ to generate a Makefile.
4. Run ~make all~ to compile all the programs.
5. Go into the newly created ~bin~ directory where all the compiled programs will be output to
6. Programs will be named ~PartOne~, ~PartTwo~, and ~PartThree~
** Program Outputs
*** Part One
C program to Check for balanced Parentheses in an Expression using Stack. The program will
check if the expression has balanced Parentheses.
1. [[./assets/PartOne/img1.png]]
2. [[./assets/PartOne/img2.png]]
3. [[./assets/PartOne/img3.png]]
4. [[./assets/PartOne/img4.png]]
5. [[./assets/PartOne/img5.png]]
*** Part Two
Write a program which will take input (Infix expression) from user and converts the expression
to Postfix expression (using stacks).
1. [[./assets/PartTwo/img1.png]]
2. [[./assets/PartTwo/img2.png]]
3. [[./assets/PartTwo/img3.png]]
4. [[./assets/PartTwo/img4.png]]
*** Part Three
Implement code that will tell you the time binary search took when implemented through both a
recursive method and iterative method
1. [[./assets/PartThree/img1.png]]

Binary file not shown.

After

Width:  |  Height:  |  Size: 22 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 25 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 24 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 24 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 20 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 211 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 38 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 42 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 42 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 37 KiB

View File

@ -0,0 +1,57 @@
// Credit to
// https://stackoverflow.com/questions/40159892/using-asprintf-on-windows/49873938#49873938
// with modifications by me
#include <stdarg.h> /* needed for va_* */
#include <stdio.h> /* needed for vsnprintf */
#include <stdlib.h> /* needed for malloc, free */
#ifdef _MSC_VER
#include <direct.h>
#else
#include <linux/limits.h>
#endif
int vscprintf(const char *format, va_list ap) {
va_list ap_copy;
va_copy(ap_copy, ap);
int retval = vsnprintf(NULL, 0, format, ap_copy);
va_end(ap_copy);
return retval;
}
/*
* asprintf, vasprintf:
* MSVC does not implement these, thus we implement them here
* GNU-C-compatible compilers implement these with the same names, thus we
* don't have to do anything
*/
int vasprintf(char **strp, const char *format, va_list ap) {
int len = vscprintf(format, ap);
if (len == -1)
return -1;
char *str = (char *)malloc((size_t)len + 1);
if (!str)
return -1;
int retval = vsnprintf(str, len + 1, format, ap);
if (retval == -1) {
free(str);
return -1;
}
*strp = str;
return retval;
}
char* fmtstr(const char *format, ...) {
char *str = NULL;
va_list ap;
va_start(ap, format);
vasprintf(&str, format, ap);
va_end(ap);
return str;
}
void print_header() {
printf("Price Hiller | zfp106 | <Spring 2024>\n");
}

View File

@ -0,0 +1,35 @@
// Credit to
// https://stackoverflow.com/questions/40159892/using-asprintf-on-windows/49873938#49873938
// with modifications by me
#ifndef FMTSTR_H
#define FMTSTR_H
#if defined(__GNUC__) && !defined(_GNU_SOURCE)
#define _GNU_SOURCE /* needed for (v)asprintf, affects '#include <stdio.h>' */
#endif
#include <stdarg.h> /* needed for va_* */
/*
* vscprintf:
* MSVC implements this as _vscprintf, thus we just 'symlink' it here
* GNU-C-compatible compilers do not implement this, thus we implement it here
*/
#ifdef _MSC_VER
#define vscprintf _vscprintf
#endif
#ifdef _MSC_VER
int vasprintf(char **strp, const char *format, va_list ap);
#endif
#ifdef __GNUC__
int vscprintf(const char *format, va_list ap);
#endif
char* fmtstr(const char *format, ...);
void print_header();
#endif

View File

@ -0,0 +1,79 @@
#pragma once
#define VECTOR_LIB
#include <stdbool.h>
#include <stdlib.h>
// This code is pretty bad in all honesty, but I *really* didn't want to play
// the void pointer game.
#define DECL_VEC(type_name, type) \
typedef struct { \
size_t elem_count; \
size_t capacity; \
type *data; \
} type_name; \
\
type_name type_name##_new(size_t initial_capacity) { \
initial_capacity = (initial_capacity < 1) ? 1 : initial_capacity; \
type_name v = {.capacity = initial_capacity, \
.elem_count = 0, \
.data = malloc(sizeof(type *) * initial_capacity)}; \
return v; \
} \
\
bool type_name##_alloc(type_name *v, size_t extra_capacity) { \
if (extra_capacity == 0) { \
return false; \
} \
\
int desired_size = v->capacity + extra_capacity; \
type *newData = realloc(v->data, sizeof(type *) * desired_size); \
if (newData == NULL) \
return false; \
v->data = newData; \
v->capacity = desired_size; \
return true; \
} \
\
bool type_name##_ensure_capacity(type_name *v, size_t capacity) { \
if (v->capacity < capacity) \
return type_name##_alloc(v, capacity - v->capacity); \
return true; \
} \
\
void type_name##_push(type_name *v, type item) { \
type_name##_ensure_capacity(v, v->elem_count + 1); \
v->data[v->elem_count++] = item; \
} \
\
type *type_name##_get(type_name *v, size_t index) { \
if (index >= 0 && index < v->elem_count) \
return &v->data[index]; \
return NULL; \
} \
\
void type_name##_del(type_name *v, size_t index) { \
if (index >= 0 && index < v->elem_count) { \
for (int i = index; (i < v->elem_count - 1); ++i) { \
v->data[i] = v->data[i + 1]; \
} \
v->elem_count--; \
} \
} \
\
type type_name##_pop(type_name *v) { \
type popped_value = *type_name##_get(v, v->elem_count - 1); \
type_name##_del(v, v->elem_count - 1); \
return popped_value; \
} \
\
type type_name##_first(type_name *v) { \
type found_value = *type_name##_get(v, 0); \
type_name##_del(v, 0); \
return found_value; \
} \
\
type *type_name##_peek(type_name *v) { \
return type_name##_get(v, v->elem_count - 1); \
} \
\
void type_name##_free(type_name *v) { free(v->data); }

View File

@ -0,0 +1,73 @@
#include "lib/lib.h"
#include "lib/vec.h"
#include <stdbool.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
DECL_VEC(CharVec, char);
CharVec readStdinToNewline() {
CharVec cvec = CharVec_new(2);
int ch;
while (EOF != (ch = fgetc(stdin)) && ch != '\n') {
CharVec_push(&cvec, ch);
}
return cvec;
}
bool pairedBraces(char open_brace, char close_brace) {
if (open_brace == '\0')
return true;
int asciiDiff = 2;
if (open_brace == '(' || open_brace == ')') {
asciiDiff = 1;
}
return ((int)open_brace - ((int)close_brace - asciiDiff)) == 0;
}
bool checkCharVecBalance(CharVec *cvec) {
int balance = 0;
CharVec braceStack = CharVec_new(cvec->elem_count);
char lastOpenBrace = '\0';
while (cvec->elem_count != 0) {
char val = CharVec_first(cvec);
switch (val) {
case '(':
case '[':
case '{':
CharVec_push(&braceStack, val);
balance++;
break;
case ')':
case ']':
case '}':
if (!pairedBraces(CharVec_pop(&braceStack), val))
return 0;
balance--;
break;
}
}
if (balance == 0) {
return -1;
} else {
return cvec->elem_count;
}
}
int main() {
print_header();
printf("Enter Expression: ");
CharVec cvec = readStdinToNewline();
char *input = malloc(cvec.elem_count + 1);
strcpy(input, cvec.data);
if (checkCharVecBalance(&cvec)) {
printf("It's balanced (^_^)\n");
return EXIT_SUCCESS;
} else {
printf("It's Not Balanced (0_0)\n");
return EXIT_FAILURE;
}
}

View File

@ -0,0 +1,104 @@
#include "lib/lib.h"
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
void swap(int *a, int *b) {
int t = *a;
*a = *b;
*b = t;
}
int partition(int arr[], int low, int high) {
int pivot = arr[high];
int i = (low - 1);
for (int j = low; j <= high - 1; j++) {
if (arr[j] < pivot) {
i++;
swap(&arr[i], &arr[j]);
}
}
swap(&arr[i + 1], &arr[high]);
return (i + 1);
}
void q_sort(int arr[], int low, int high) {
if (low < high) {
int p = partition(arr, low, high);
q_sort(arr, low, p - 1);
q_sort(arr, p + 1, high);
}
}
int bsearch_iterative(int arr[], int key, int len) {
int low = 0;
int high = len;
while (low < high) {
int mid = (low + high) / 2;
if (key == arr[mid]) {
return mid;
} else if (key > arr[mid]) {
low = mid + 1;
} else {
high = mid - 1;
}
}
return -1;
}
int bsearch_recursive(int arr[], int key, int low, int high) {
if (low > high) {
return -1;
}
int mid = (low + high) / 2;
if (key == arr[mid]) {
return mid;
} else if (key > arr[mid]) {
return bsearch_recursive(arr, key, mid + 1, high);
} else {
return bsearch_recursive(arr, key, low, mid - 1);
}
}
int main() {
print_header();
printf("Enter 5 elements:\n");
int arr_len = 5;
int arr[arr_len];
for (int i = 0; i < arr_len; i++) {
scanf("%d", &arr[i]);
}
printf("\nEnter element to search for:\n");
int search_element;
scanf("%d", &search_element);
q_sort(arr, 0, arr_len);
clock_t tic, toc;
printf("\n\n--------\n=> Binary Search (Iterative Approach)");
tic = clock();
int b_iter_index = bsearch_iterative(arr, search_element, arr_len);
toc = clock();
if (b_iter_index == -1) {
printf("Unable to find the element '%d'!\n", search_element);
} else {
printf("Element found at index %d\n", b_iter_index);
}
printf("Total time taken by CPU (End Time - Start Time)/clock per sec: %f\n--------\n",
(double)(toc - tic) / CLOCKS_PER_SEC);
printf("\n--------\n=> Binary Search (Recursive Approach)");
tic = clock();
int b_rec_index = bsearch_recursive(arr, search_element, 0, arr_len);
toc = clock();
if (b_iter_index == -1) {
printf("Unable to find the element '%d'!\n", search_element);
} else {
printf("Element found at index %d\n", b_rec_index);
}
printf("Total time taken by CPU (End Time - Start Time)/clock per sec: %f\n--------\n",
(double)(toc - tic) / CLOCKS_PER_SEC);
return EXIT_SUCCESS;
}

View File

@ -0,0 +1,66 @@
#include "lib/lib.h"
#include "lib/vec.h"
#include <ctype.h>
#include <stdbool.h>
#include <stdio.h>
#include <stdlib.h>
DECL_VEC(CharVec, char);
int priority(char x) {
switch (x) {
case '(':
return 0;
break;
case '+':
case '-':
return 1;
case '*':
case '/':
return 2;
}
return 0;
}
CharVec readStdinToNewline() {
CharVec cvec = CharVec_new(2);
int ch;
while (EOF != (ch = fgetc(stdin)) && ch != '\n') {
CharVec_push(&cvec, ch);
}
return cvec;
}
int main() {
print_header();
printf("Enter the Infix Expression:\n");
CharVec stack = CharVec_new(2);
CharVec input = readStdinToNewline();
printf("The Postfix expression:\n ");
while (input.elem_count != 0) {
char ch = CharVec_first(&input);
if (ch == ' ') {
continue;
} else if (isalnum(ch)) {
printf("%c ", ch);
} else if (ch == '(') {
CharVec_push(&stack, ch);
} else if (ch == ')') {
char x;
while ((x = CharVec_pop(&stack)) != '(') {
printf("%c ", x);
}
} else {
while (stack.elem_count != 0 && priority(*CharVec_peek(&stack)) >= priority(ch))
printf("%c ", CharVec_pop(&stack));
CharVec_push(&stack, ch);
}
}
while (stack.elem_count != 0) {
printf("%c ", CharVec_pop(&stack));
}
printf("\nEnd of Program\n");
return EXIT_SUCCESS;
}