Unix is popular operating system, developed by AT&T in 1969 and it has been very important to the development of the Internet. It is a multi-processing, multi-user, family of operating systems that run on a variety of architechtures. UNIX allows more than one user to access a computer system at the same time.
A widely used Open Source Unix-like operating system. Linux was first released by its inventor Linus Torvalds in 1991. There are versions of Linux for almost every available type of computer hardware from desktop machines to IBM mainframes. The inner workings of Linux are open and available for anyone to examine and change as long as they make their changes available to the public. Because of its robustness and availability, Linux has won popularity in the Open Source community as well as among commercial application developers.
Here is more input:
•Unix requires a more powerful hardware configuration. It will work in large mainframe computers but will not work in an x86 based personal computer. Linux however, (which is built on the concept of Unix) has small hardware requirements and it will work on both a large mainframe computer and an x86 based personal computer.
•Unix is an Operating System developed in olden days in which the kernel, the heart of the OS, interacts directly with the hardware. Because UNIX treats everything as a file, it provides greater security for users. An example of a UNIX distribution is posix. Linux uses a the UNIX architecture as its basis and provides more facilities and applications. Linux could be considered to be a GUI to the UNIX core. Examples of Linux distributions are Redhat, Fedora, Susee, Mandriva, and Ubuntu. Solaris OS also uses the UNIX kernal almost all UNIX commands will work on solaris in addition to 500 Solaris specific commands. Both UNIX and LINUX are Open source.
•Unix is the foundation for a number of operating systems, with Linux being the most popular one. Novell and Free BSD are 2 other commonly used Unix varients.
•UNIX is an operating system created in the early days of computers. More recently, Linux was created as an open-source, freeware operating system. It is "UNIX-LIKE", meaning that it uses many UNIX constructs but also departs from traditional UNIX in many ways. Like UNIX, Linux is faster than many of the other commercially available operating systems. It appears to also be far more robust than any of the Microsoft products. Linux is being used in many time critical applications because of it's speed. It is also used in many applications that need to maintain uptime because Linux, like UNIX, can run for months at a time without rebooting. While the typical method of solving Microsoft problems is to "reboot", that particular requirement does not seem to be appropriate in a Linux/Unix environment. While UNIX has created a windows-like work environment, Linux has improved greatly on that concept. Linux has become a real player in the consumer operating system market... and it's free. While you may want to pay for a Linux distribution, the actual code is free and you are allowed to load it on as many machines as you want. You can get Linux for free if you wish to load it across the internet.
Thursday, May 28, 2009
Difference between Procedural and Object Oriented Programming
Procedural:
The problem is decomposed into individual procedures or subroutines. This decomposition is
usually done in a top down manner. In a top down approach, once a section of the problem has been identified as being implementable by a procedure,it too is broken down into individual procedures.The data however, is not usually part of this decomposition.
Eg: C & Pascal
Object-oriented:
The problem is decomposed into individual procedures or subroutines. This decomposition is
usually done in a top down manner. In a top down approach, once a section of the problem has been identified as being implementable by a procedure,it too is broken down into individual procedures.The data however, is not usually part of this decomposition.
Eg: C & Pascal
Object-oriented:
The problem is decomposed into interacting objects. Each object encapsulates and hides
methods that manipulate the hidden state of the object. A message sent to an object evokes the encapsulated method that then performs the requested task.
methods that manipulate the hidden state of the object. A message sent to an object evokes the encapsulated method that then performs the requested task.
Eg: ADA95,java
Wednesday, May 27, 2009
How does a language compiler work?
=>A compiler for a language generally has several different stages as it
processes the input.
=>They are:
1. Preprocessing
2. Lexical analysis
3. Syntactical analysis
4. Semantical analysis
5. Intermediate code generation
6. Code optimization
7. Code generation
1.Preprocessing:
During the preprocessing stage, comments, macros, and directives are
processed.
Comments are removed from the source file. This greatly simplifies the
later stages.
If the language supports macros, the macros are replaced with the equivalent
text.
The preprocessor may also replace special strings with other characters. In
C and C++, the preprocessor recognizes the \ character as an escape code,
and will replace the escape sequence with a special character. For example
\t is the escape code for a tab, so \t would be replaced at this stage with
a tab character.
2.Lexical analysis:
Lexical analysis is the process of breaking down the source files into
key words, constants, identifiers, operators and other simple tokens. A
token is the smallest piece of text that the language defines.
3.Syntactical analysis:
Syntactical analysis is the process of combining the tokens into
well-formed expressions, statements, and programs. Each language has
specific rules about the structure of a program--called the grammar or
syntax. Just like English grammar, it specifies how things may be put
together. In English, a simple sentence is: subject, verb, predicate
4.Semantic analysis:
Semantic analysis is the process of examining the types and values of the
statements used to make sure they make sense. During the semantic
analysis, the types, values, and other required information about statements
are recorded, checked, and transformed as appropriate to make sure the
program makes sense.
5.Intermediate code generation:
Depending on the compiler, this step may be skipped, and instead the program
may be translated directly into the target language (usually machine object
code). If this step is implemented, the compiler designers also design a
machine independent language of there own that is close to machine language
and easily translated into machine language for any number of different
computers.
The purpose of this step is to allow the compiler writers to support
different target computers and different languages with a minimum of effort.
The part of the compiler which deals with processing the source files,
analyzing the language and generating the intermediate code is called the
front end, while the process of optimizing and converting the intermediate
code into the target language is called the back end.
6. Code optimization
During this process the code generated is analyzed and improved for
efficiency. The compiler analyzes the code to see if improvements can be
made to the intermediate code that couldn't be made earlier. For example,
some languages like Pascal do not allow pointers, while all machine
languages do. When accessing arrays, it is more efficient to use pointers,
so the code optimizer may detect this case and internally use pointers.
7. Code generation
Finally, after the intermediate code has been generated and optimized, the
compiler will generated code for the specific target language. Almost
always this is machine code for a particular target machine.
Also, it us usually not the final machine code, but is instead object code,
which contains all the instructions, but not all of the final memory
addresses have been determined.
A subsequent program, called a linker is used to combine several different object code files into the final executable program.
processes the input.
=>They are:
1. Preprocessing
2. Lexical analysis
3. Syntactical analysis
4. Semantical analysis
5. Intermediate code generation
6. Code optimization
7. Code generation
1.Preprocessing:
During the preprocessing stage, comments, macros, and directives are
processed.
Comments are removed from the source file. This greatly simplifies the
later stages.
If the language supports macros, the macros are replaced with the equivalent
text.
The preprocessor may also replace special strings with other characters. In
C and C++, the preprocessor recognizes the \ character as an escape code,
and will replace the escape sequence with a special character. For example
\t is the escape code for a tab, so \t would be replaced at this stage with
a tab character.
2.Lexical analysis:
Lexical analysis is the process of breaking down the source files into
key words, constants, identifiers, operators and other simple tokens. A
token is the smallest piece of text that the language defines.
3.Syntactical analysis:
Syntactical analysis is the process of combining the tokens into
well-formed expressions, statements, and programs. Each language has
specific rules about the structure of a program--called the grammar or
syntax. Just like English grammar, it specifies how things may be put
together. In English, a simple sentence is: subject, verb, predicate
4.Semantic analysis:
Semantic analysis is the process of examining the types and values of the
statements used to make sure they make sense. During the semantic
analysis, the types, values, and other required information about statements
are recorded, checked, and transformed as appropriate to make sure the
program makes sense.
5.Intermediate code generation:
Depending on the compiler, this step may be skipped, and instead the program
may be translated directly into the target language (usually machine object
code). If this step is implemented, the compiler designers also design a
machine independent language of there own that is close to machine language
and easily translated into machine language for any number of different
computers.
The purpose of this step is to allow the compiler writers to support
different target computers and different languages with a minimum of effort.
The part of the compiler which deals with processing the source files,
analyzing the language and generating the intermediate code is called the
front end, while the process of optimizing and converting the intermediate
code into the target language is called the back end.
6. Code optimization
During this process the code generated is analyzed and improved for
efficiency. The compiler analyzes the code to see if improvements can be
made to the intermediate code that couldn't be made earlier. For example,
some languages like Pascal do not allow pointers, while all machine
languages do. When accessing arrays, it is more efficient to use pointers,
so the code optimizer may detect this case and internally use pointers.
7. Code generation
Finally, after the intermediate code has been generated and optimized, the
compiler will generated code for the specific target language. Almost
always this is machine code for a particular target machine.
Also, it us usually not the final machine code, but is instead object code,
which contains all the instructions, but not all of the final memory
addresses have been determined.
A subsequent program, called a linker is used to combine several different object code files into the final executable program.
Wednesday, May 20, 2009
AFDX(Avionics Full DupleX Switched Ethernet)
AFDX - Overview
1.Advanced protocol system to interconnect Avionics subsystem
2.The standard is based on widely approved and adopted standards like Ethernet (IEEE 802.3) and IP/UDP (Internet Protocols)which are applied for sharing information anywhere on the aircraft
3.100 MBit switched Ethernet (wire).
4.Uses a special protocol to provide deterministic timing and redundancy management.
5.The main elements of an AFDX network are:
- AFDX End Systems
- AFDX Switches
- AFDX Links
Topology Description:
1.AFDX is a network than bus.
2.All connections are full duplex (100 MBits/sec).
3.Redundancy is achieved by duplication of the connections (wires) and the Switches.
Specifications of AFDX:
1.UDP/IP protocol including IP fragmentation/reassembly.
2.Virtual Links and Sub-Links.
3.Traffic shaping through bandwidth allocation gap (BAG.
4.Redundancy control.
5.AFDX addressing with multicast and unicast addresses.
6.Sampling and queuing ports for transmit and receive.
7.Autonomously scheduled transmissions.
8.Statistic counters.
Avionics Full-Duplex Switched Ethernet:
Avionics Full-Duplex Switched Ethernet (AFDX) is Part 7 of the ARINC 664 Specification which defines how Commercial Off-the-Shelf (COTS) networking technology will be used for future generation Aircraft Data Networks (ADN).
AFDX is an Airbus trademark, the equivalent Boeing product is known as CDN or Common Data Network.
AFDX defines a low-level network and protocol to communicate between avionics (referred to as End-System) devices in aircraft.
It is based on Ethernet, and like all full-duplex networks uses dedicated outgoing and incoming channels to allow full-speed transmission in both directions at the same time.
AFDX extends standard Ethernet to provide high data integrity and deterministic timing.
It specifies interoperable functional elements at the following OSI Reference Model layers:
Data Link (MAC and Virtual Link addressing concept);
Network (IP and ICMP);
Transport (UDP and optionally TCP)
Application (Network) (Sampling, Queuing, SAP, TFTP and SNMP).
The Physical layer is not defined as part of ARINC 664 Part 7 (AFDX) but can be any of the solutions defined in ARINC 664 Part 2, including:
10BASE-T to support traffic at 10Mbit/s;
100BASE-TX and 100BASE-FX to support traffic at 100 Mbit/s; and
provisions for growth to 1000 Mbit/s operations.
1.Advanced protocol system to interconnect Avionics subsystem
2.The standard is based on widely approved and adopted standards like Ethernet (IEEE 802.3) and IP/UDP (Internet Protocols)which are applied for sharing information anywhere on the aircraft
3.100 MBit switched Ethernet (wire).
4.Uses a special protocol to provide deterministic timing and redundancy management.
5.The main elements of an AFDX network are:
- AFDX End Systems
- AFDX Switches
- AFDX Links
Topology Description:
1.AFDX is a network than bus.
2.All connections are full duplex (100 MBits/sec).
3.Redundancy is achieved by duplication of the connections (wires) and the Switches.
Specifications of AFDX:
1.UDP/IP protocol including IP fragmentation/reassembly.
2.Virtual Links and Sub-Links.
3.Traffic shaping through bandwidth allocation gap (BAG.
4.Redundancy control.
5.AFDX addressing with multicast and unicast addresses.
6.Sampling and queuing ports for transmit and receive.
7.Autonomously scheduled transmissions.
8.Statistic counters.
Avionics Full-Duplex Switched Ethernet:
Avionics Full-Duplex Switched Ethernet (AFDX) is Part 7 of the ARINC 664 Specification which defines how Commercial Off-the-Shelf (COTS) networking technology will be used for future generation Aircraft Data Networks (ADN).
AFDX is an Airbus trademark, the equivalent Boeing product is known as CDN or Common Data Network.
AFDX defines a low-level network and protocol to communicate between avionics (referred to as End-System) devices in aircraft.
It is based on Ethernet, and like all full-duplex networks uses dedicated outgoing and incoming channels to allow full-speed transmission in both directions at the same time.
AFDX extends standard Ethernet to provide high data integrity and deterministic timing.
It specifies interoperable functional elements at the following OSI Reference Model layers:
Data Link (MAC and Virtual Link addressing concept);
Network (IP and ICMP);
Transport (UDP and optionally TCP)
Application (Network) (Sampling, Queuing, SAP, TFTP and SNMP).
The Physical layer is not defined as part of ARINC 664 Part 7 (AFDX) but can be any of the solutions defined in ARINC 664 Part 2, including:
10BASE-T to support traffic at 10Mbit/s;
100BASE-TX and 100BASE-FX to support traffic at 100 Mbit/s; and
provisions for growth to 1000 Mbit/s operations.
Tuesday, May 19, 2009
Testing Definitions
Black box testing:
not based on any knowledge of internal design or code. Tests are based on requirements and functionality.
White box testing:
based on knowledge of the internal logic of an application’s code. Tests are based on coverage of code statements, branches, paths, conditions.
Unit testing
the most ‘micro’ scale of testing; to test particular functions or code modules. Typically done by the programmer and not by testers, as it requires detailed knowledge of the internal program design and code. Not always easily done unless the application has a well-designed architecture with tight code; may require developing test driver modules or test harnesses.
Incremental integration testing
continuous testing of an application as new functionality is added; requires that various aspects of an application’s functionality be independent enough to work separately before all parts of the program are completed, or that test drivers be developed as needed; done by programmers or by testers.
Integration testing
testing of combined parts of an application to determine if they function together correctly. The ‘parts’ can be code modules, individual applications, client and server applications on a network, etc. This type of testing is especially relevant to client/server and distributed systems.
Functional testing
black-box type testing geared to functional requirements of an application; this type of testing should be done by testers. This doesn’t mean that the programmers shouldn’t check that their code works before releasing it (which of course applies to any stage of testing.
System testing
black box type testing that is based on overall requirement specifications; covers all combined parts of a system.
End-to-end testing
similar to system testing; the ‘macro’ end of the test scale; involves testing of a complete application environment in a situation that mimics real-world use, such as interacting with a database, using network communications, or interacting with other hardware, applications, or systems if appropriate.
Sanity testing
typically an initial testing effort to determine if a new software version is performing well enough to accept it for a major testing effort. For example, if the new software is crashing systems every 5 minutes, bogging down systems to a crawl, or destroying databases, the software may not be in a ’sane’ enough condition to warrant further testing in its current state.
Regression testing
re-testing after fixes or modifications of the software or its environment. It can be difficult to determine how much re-testing is needed, especially near the end of the development cycle. Automated testing tools can be especially useful for this type of testing.
Acceptance testing
final testing based on specifications of the end-user or customer, or based on use by end-users/customers over some limited period of time.
Load testing
testing an application under heavy loads, such as testing of a web site under a range of loads to determine at what point the systems response time degrades or fails.
Stress testing
term often used interchangeably with ‘load’ and ‘performance’ testing. Also used to describe such tests as system functional testing while under unusually heavy loads, heavy repetition of certain actions or inputs, input of large numerical values, large complex queries to a database system, etc.
Performance testing
term often used interchangeably with ’stress’ and ‘load’ testing. Ideally ‘performance’ testing (and any other ‘type’ of testing) is defined in requirements documentation or QA or Test Plans.
Usability testing
testing for ‘user-friendliness’. Clearly this is subjective, and will depend on the targeted end-user or customer. User interviews, surveys, video recording of user sessions, and other techniques can be used. Programmers and testers are usually not appropriate as usability testers.
Install/uninstall testing
testing of full, partial, or upgrade install/uninstall processes.
Recovery testing
testing how well a system recovers from crashes, hardware failures, or other catastrophic problems.
Security testing
testing how well the system protects against unauthorized internal or external access, willful damage, etc; may require sophisticated testing techniques.
Compatibility testing
testing how well software performs in a particular hardware/software/operating system/network/etc. environment.
Exploratory testing
often taken to mean a creative, informal software test that is not based on formal test plans or test cases; testers may be learning the software as they test it.
Ad-hoc testing
similar to exploratory testing, but often taken to mean that the testers have significant understanding of the software before testing it.
User acceptance testing
determining if software is satisfactory to an end-user or customer.
Comparison testing
comparing software weaknesses and strengths to competing products.
Alpha testing
testing of an application when development is nearing completion; minor design changes may still be made as a result of such testing. Typically done by end-users or others, not by programmers or testers.
Beta testing
testing when development and testing are essentially completed and final bugs and problems need to be found before final release. Typically done by end-users or others, not by programmers or testers.
Mutation testing
a method for determining if a set of test data or test cases is useful, by deliberately introducing various code changes (’bugs’) and retesting with the original test data/cases to determine if the ‘bugs’ are detected. Proper implementation requires large computational resources.
1. What is Defect?
In computer technology, a Defect is a coding error in a computer program. It is defined by saying that “A software error is present when the program does not do what its end user reasonably expects it to do”.
Bug the application works incorrectly or provides incorrect information.
not based on any knowledge of internal design or code. Tests are based on requirements and functionality.
White box testing:
based on knowledge of the internal logic of an application’s code. Tests are based on coverage of code statements, branches, paths, conditions.
Unit testing
the most ‘micro’ scale of testing; to test particular functions or code modules. Typically done by the programmer and not by testers, as it requires detailed knowledge of the internal program design and code. Not always easily done unless the application has a well-designed architecture with tight code; may require developing test driver modules or test harnesses.
Incremental integration testing
continuous testing of an application as new functionality is added; requires that various aspects of an application’s functionality be independent enough to work separately before all parts of the program are completed, or that test drivers be developed as needed; done by programmers or by testers.
Integration testing
testing of combined parts of an application to determine if they function together correctly. The ‘parts’ can be code modules, individual applications, client and server applications on a network, etc. This type of testing is especially relevant to client/server and distributed systems.
Functional testing
black-box type testing geared to functional requirements of an application; this type of testing should be done by testers. This doesn’t mean that the programmers shouldn’t check that their code works before releasing it (which of course applies to any stage of testing.
System testing
black box type testing that is based on overall requirement specifications; covers all combined parts of a system.
End-to-end testing
similar to system testing; the ‘macro’ end of the test scale; involves testing of a complete application environment in a situation that mimics real-world use, such as interacting with a database, using network communications, or interacting with other hardware, applications, or systems if appropriate.
Sanity testing
typically an initial testing effort to determine if a new software version is performing well enough to accept it for a major testing effort. For example, if the new software is crashing systems every 5 minutes, bogging down systems to a crawl, or destroying databases, the software may not be in a ’sane’ enough condition to warrant further testing in its current state.
Regression testing
re-testing after fixes or modifications of the software or its environment. It can be difficult to determine how much re-testing is needed, especially near the end of the development cycle. Automated testing tools can be especially useful for this type of testing.
Acceptance testing
final testing based on specifications of the end-user or customer, or based on use by end-users/customers over some limited period of time.
Load testing
testing an application under heavy loads, such as testing of a web site under a range of loads to determine at what point the systems response time degrades or fails.
Stress testing
term often used interchangeably with ‘load’ and ‘performance’ testing. Also used to describe such tests as system functional testing while under unusually heavy loads, heavy repetition of certain actions or inputs, input of large numerical values, large complex queries to a database system, etc.
Performance testing
term often used interchangeably with ’stress’ and ‘load’ testing. Ideally ‘performance’ testing (and any other ‘type’ of testing) is defined in requirements documentation or QA or Test Plans.
Usability testing
testing for ‘user-friendliness’. Clearly this is subjective, and will depend on the targeted end-user or customer. User interviews, surveys, video recording of user sessions, and other techniques can be used. Programmers and testers are usually not appropriate as usability testers.
Install/uninstall testing
testing of full, partial, or upgrade install/uninstall processes.
Recovery testing
testing how well a system recovers from crashes, hardware failures, or other catastrophic problems.
Security testing
testing how well the system protects against unauthorized internal or external access, willful damage, etc; may require sophisticated testing techniques.
Compatibility testing
testing how well software performs in a particular hardware/software/operating system/network/etc. environment.
Exploratory testing
often taken to mean a creative, informal software test that is not based on formal test plans or test cases; testers may be learning the software as they test it.
Ad-hoc testing
similar to exploratory testing, but often taken to mean that the testers have significant understanding of the software before testing it.
User acceptance testing
determining if software is satisfactory to an end-user or customer.
Comparison testing
comparing software weaknesses and strengths to competing products.
Alpha testing
testing of an application when development is nearing completion; minor design changes may still be made as a result of such testing. Typically done by end-users or others, not by programmers or testers.
Beta testing
testing when development and testing are essentially completed and final bugs and problems need to be found before final release. Typically done by end-users or others, not by programmers or testers.
Mutation testing
a method for determining if a set of test data or test cases is useful, by deliberately introducing various code changes (’bugs’) and retesting with the original test data/cases to determine if the ‘bugs’ are detected. Proper implementation requires large computational resources.
1. What is Defect?
In computer technology, a Defect is a coding error in a computer program. It is defined by saying that “A software error is present when the program does not do what its end user reasonably expects it to do”.
Bug the application works incorrectly or provides incorrect information.
Monday, May 18, 2009
Types of Software Testing
Hardware/software integration testing: To verify correct operation of the software in the target computer environment.
Software integration testing: To verify the interrelationships between software requirements and components and to verify the implementation of the software requirements and software components within the software architecture.
Low-level testing: To verify the implementation of software low-level requirements.
Objective of HSIT:
The objective of requirements-based hardware/software integration testing is to ensure that the software in the target computer will satisfy the high-level requirements.
Errors revealed by HSIT:
Incorrect interrupt handling.
Failure to satisfy execution time requirements.
Incorrect software response to hardware transients or hardware failures, for example, start-up sequencing, transient input loads and input power transients.
Data bus and other resource contention problems, for example, memory mapping.
Inability of built-in test to detect failures.
Errors in hardware/software interfaces.
Incorrect behavior of feedback loops.
Incorrect control of memory management hardware or other hardware devices under software control.
Stack overflow.
Incorrect operation of mechanism(s) used to confirm the correctness and compatibility of field-loadable software.
Violations of software partitioning
Objective of SIT:
The objective of requirements-based software integration testing is to ensure that the software components interact correctly with each other and satisfy the software requirements and software architecture.
Errors revealed by SIT
Incorrect initialization of variables and constants.
Parameter passing errors.
Data corruption, especially global data.
Inadequate end-to-end numerical resolution.
Incorrect sequencing of events and operations.
Objective of Low-Level testing:
The objective of requirements-based low-level testing is to ensure that the software components satisfy their low-level requirements.
Errors revealed by Low Level Testing
Failure of an algorithm to satisfy a software requirement.
Incorrect loop operations.
Incorrect logic decisions.
Failure to process correctly legitimate combinations of input conditions.
Incorrect responses to missing or corrupted input data.
Incorrect handling of exceptions, such as arithmetic faults or violations of array limits.
Incorrect computation sequence.
Inadequate algorithm precision, accuracy or performance.
Software integration testing: To verify the interrelationships between software requirements and components and to verify the implementation of the software requirements and software components within the software architecture.
Low-level testing: To verify the implementation of software low-level requirements.
Objective of HSIT:
The objective of requirements-based hardware/software integration testing is to ensure that the software in the target computer will satisfy the high-level requirements.
Errors revealed by HSIT:
Incorrect interrupt handling.
Failure to satisfy execution time requirements.
Incorrect software response to hardware transients or hardware failures, for example, start-up sequencing, transient input loads and input power transients.
Data bus and other resource contention problems, for example, memory mapping.
Inability of built-in test to detect failures.
Errors in hardware/software interfaces.
Incorrect behavior of feedback loops.
Incorrect control of memory management hardware or other hardware devices under software control.
Stack overflow.
Incorrect operation of mechanism(s) used to confirm the correctness and compatibility of field-loadable software.
Violations of software partitioning
Objective of SIT:
The objective of requirements-based software integration testing is to ensure that the software components interact correctly with each other and satisfy the software requirements and software architecture.
Errors revealed by SIT
Incorrect initialization of variables and constants.
Parameter passing errors.
Data corruption, especially global data.
Inadequate end-to-end numerical resolution.
Incorrect sequencing of events and operations.
Objective of Low-Level testing:
The objective of requirements-based low-level testing is to ensure that the software components satisfy their low-level requirements.
Errors revealed by Low Level Testing
Failure of an algorithm to satisfy a software requirement.
Incorrect loop operations.
Incorrect logic decisions.
Failure to process correctly legitimate combinations of input conditions.
Incorrect responses to missing or corrupted input data.
Incorrect handling of exceptions, such as arithmetic faults or violations of array limits.
Incorrect computation sequence.
Inadequate algorithm precision, accuracy or performance.
Monday, May 11, 2009
Difference between Unformated I/O functions
getchar() :
The getchar() accepts a single charater from the keyboard.you have to specify the end of the input by pressing Enter key because the getchar() accepts bufferred input. This means that the input value is stored in a variable only aftr enter is pressed.
If more than one character is typed before pressing Enter,only the first character is accepted by the getchar() . The rest of the input character remain in th buffer while the first input character is returned by the getchar().
getch():
The getch() accepts a single character from the keyboard. The getch() accepts unbufferred input . This indicates that input is directly stored in a variable. Therefore, there is no need to press Enter key to specify the end of input.
The getch() returns the character you type, and this character is assigned to the char variable.
getche():
The character based input function getche() also accepts unbufferred input as a single character similar to the getch(). How ever , input to the getche() is echoed on the screen. The getche()returns the character accepted from the keyboard.
getc():
The getc() is used to accept a value for a character variable from a file. The file can be a disk file or the standard input device, which is the keyboard.
gets():
Finally, the gets function accepts a sequence of characters with embedded spaces. A sequence of characters with embedded spaces is called string. The end of the string is specified by pressing Enter.
The getchar() accepts a single charater from the keyboard.you have to specify the end of the input by pressing Enter key because the getchar() accepts bufferred input. This means that the input value is stored in a variable only aftr enter is pressed.
If more than one character is typed before pressing Enter,only the first character is accepted by the getchar() . The rest of the input character remain in th buffer while the first input character is returned by the getchar().
getch():
The getch() accepts a single character from the keyboard. The getch() accepts unbufferred input . This indicates that input is directly stored in a variable. Therefore, there is no need to press Enter key to specify the end of input.
The getch() returns the character you type, and this character is assigned to the char variable.
getche():
The character based input function getche() also accepts unbufferred input as a single character similar to the getch(). How ever , input to the getche() is echoed on the screen. The getche()returns the character accepted from the keyboard.
getc():
The getc() is used to accept a value for a character variable from a file. The file can be a disk file or the standard input device, which is the keyboard.
gets():
Finally, the gets function accepts a sequence of characters with embedded spaces. A sequence of characters with embedded spaces is called string. The end of the string is specified by pressing Enter.
HONEY WELL Interview questions
HONEY WELL
Written test followd by three technical interviews.
ABT all projects in my resume.(brief)
1.Difference between union and structures.why we are using structures in our project rather than
Unions?
2.program for string is palndrome or not?
3.write a program for maximum number in a array.
4.out puts for function call by value ,call by reference, calll by address.
5.macros and inline functions difference.(in depth)
6.in C++ inhertence.
7. how to find a size of variable with out using size of variable?
8.abt data link layer.
9. abt tcp aand udp.
10.wt is the use of keyword EXTERN .wt is difference between declaring as extern and declared in .h file?
11.abt stack opration?
12.abt queue operation?
13.abt malloc and calloc.
14.program exeqution process abt each stage.
15.some questions in graphs and trees.
16.searching and sorting of tree.
17.time complexcity of different searching algorithms.
18.in C++ wt is pure virtuval class.
19.Abt DO-178B standrads.,(brief)
20.wt is diff between GPOS and RTOS
21. based on priority of task some tricky questions.
22.wt is deadlock
23.wt is starvation.
24.paging AND SEGMENTATION.
25.general SHEDULINGS policies.
26.abt fork and kill in linux.
27.if we kill the parent process wt happen to child process.
28.wt is ment by context switching.
29.abt process control block.?
30.abt fork systemcall.
31.difference between semophore and mutex.
32.abt VOLATILE CONST,wt is the use of volatile for constant .
33.abt recursive functions.and example in real time.
34.disadvantages and advantages of recursive functions with an example.
35.abt bit manpulation programs in c.
36.revrse a linked list elements without using any other variable.
37.abt #define…
38.abt function pointers and and their use in real time….(we have to explain).
39.function with different arugument list.(it is ddifferent from variable length argument list)
40.static int a[5]={1};
Int b[5]={1}; values of a[3],b[3]?
41. how the function call will work internally.
Written test followd by three technical interviews.
ABT all projects in my resume.(brief)
1.Difference between union and structures.why we are using structures in our project rather than
Unions?
2.program for string is palndrome or not?
3.write a program for maximum number in a array.
4.out puts for function call by value ,call by reference, calll by address.
5.macros and inline functions difference.(in depth)
6.in C++ inhertence.
7. how to find a size of variable with out using size of variable?
8.abt data link layer.
9. abt tcp aand udp.
10.wt is the use of keyword EXTERN .wt is difference between declaring as extern and declared in .h file?
11.abt stack opration?
12.abt queue operation?
13.abt malloc and calloc.
14.program exeqution process abt each stage.
15.some questions in graphs and trees.
16.searching and sorting of tree.
17.time complexcity of different searching algorithms.
18.in C++ wt is pure virtuval class.
19.Abt DO-178B standrads.,(brief)
20.wt is diff between GPOS and RTOS
21. based on priority of task some tricky questions.
22.wt is deadlock
23.wt is starvation.
24.paging AND SEGMENTATION.
25.general SHEDULINGS policies.
26.abt fork and kill in linux.
27.if we kill the parent process wt happen to child process.
28.wt is ment by context switching.
29.abt process control block.?
30.abt fork systemcall.
31.difference between semophore and mutex.
32.abt VOLATILE CONST,wt is the use of volatile for constant .
33.abt recursive functions.and example in real time.
34.disadvantages and advantages of recursive functions with an example.
35.abt bit manpulation programs in c.
36.revrse a linked list elements without using any other variable.
37.abt #define…
38.abt function pointers and and their use in real time….(we have to explain).
39.function with different arugument list.(it is ddifferent from variable length argument list)
40.static int a[5]={1};
Int b[5]={1}; values of a[3],b[3]?
41. how the function call will work internally.
Important Programs in C
BIT OPERATIONS
atoi( ) using bit operaion
main()
{
char *s= "12349";
int i=0;
while (*s)
{
i = (i<<3)+(i<<1)+(*s>Coverting decimal to binary
main()
{
int x=10;
int i;
for(i=0;i<32;i++)>To change/Swap value
main()
{
int x=3;
int y=2;
printf("before %d %d\n",x,y);
x = x^y;
y = x^y;
x = y^x;
printf("after %d %d",x,y);
}
To check no is power of two or not
main()
{
int n;
printf("enter the number\n");
scanf ("%d",&n);
if( n & n-1)
printf("not power of two");
else
printf("power of two");
}
To count 1s in number
-main()
{
int b;
int x=15;
for(b=0;x!=0; x&=(x-1))
++b;
printf("%d",b);
}
-main()
{
int i,x;
printf("enter the no\n");
scanf("%d",&x);
for(i=0;x!=0;i++)
x=x>>1;
printf("count = %d",i);
}
-main()
{
int b=0;
int x=15;
for ( b=0; x!=0; x >>=1)
{
if ( x & 01 )
b++;
}
printf(" No on ones :%d",b);
}
Bit invert from postion P, N bits inverted
int temp[32];
void bitshow(int);
main()
{
int x=11;
int p=3;
int n=2;
int z;
printf("no is %d\n",x);
bitshow(x);
z = ( x ^ (~(~0 << lsb="0,p,i;" i="0;i<32;i++)" lsb =" x" x =" x">> 1;
}
for(p=31;p>=0;p--)
{
printf("%d",temp[p]);
}
}
Bit rotate right
/* Program To Right Rotate Bits */
#include
#include
void rotate ( unsigned long int,int ); // Rotate Right function
void bitshow ( unsigned long int ); // To display 32 bits
int temp[32]; // To hold Bit values
main()
{
int n=5;
unsigned long int x=15;
system ( "clear" );
rotate ( x, n );
}
void rotate ( unsigned long int x, int n )
{
int s=1; // counter to know no of rotates
long int mask;
int lsb;
mask = 1 << lsb =" x" x =" x">> 1;
if ( lsb )
{
x = mask;
}
printf ( "\n%d Rotate:",s );
bitshow ( x );
s++;
} // while ends
printf("\n");
} //function ends
void bitshow ( unsigned long int x )
{
int p,i;
for( i=0; i<32; x =" x">> 1;
}
for ( p=31; p>=0; p--)
printf ( "%d",temp[p] );
} //function ends
Program to set bits
int temp[32];
void bitshow(int);
main()
{
int x=10;
int p=3;
int n=2;
int y=1;
int z;
z = (x & ~(~(~0 <<>Bit SWAP
void swap(int p3,int p4)
{
int lsb=0,p,i;
for(i=0;i<32;i++) lsb =" x" x =" x">> 1;
}
p=temp[p3];
temp[p3]=temp[p4];
temp[p4]=p;
for(p=31;p>=0;p--)
printf("%d",temp[p]);
}
Program to get bits
main()
{
int x=10; //number
int p=3; // from which position
int n=2; // n numbers right
printf("%d",(x>>(p+1-n) & ~(~0 <<>To set particular bit
#include
void bitshow(int);
main()
{
int n,pos;
int mask=1;
printf("entre the number\n");
scanf("%d",&n);
printf("enter the position u want to set\n");
scanf("%d",&pos);
bitshow(n);
mask = mask <<(pos-1); n= nmask; // to set use OR printf("\nafter setting bit\n"); bitshow(n); } To reset BIT
#include
void bitshow(int);
main()
{
int n,pos;
int mask=1;
printf("entre the number\n");
scanf("%d",&n);
printf("enter the position u want to reset\n");
scanf("%d",&pos);
bitshow(n);
mask = mask <<(pos-1); n= n ^ mask; //to reset use XOR printf("\nafter resetting bit\n"); bitshow(n); } To check bit is on or not main()
{
int n,pos;
int mask=1;
printf("entre the number\n");
scanf("%d",&n);
printf("enter the position u want to check\n");
scanf("%d",&pos);
bitshow(n);
n= n>>(pos-1);
n = n&1;
if (n ==1 )
printf("\n%d bit is on\n",pos);
else
printf("\n%d bit is off\n",pos);
}
Bit complement
main()
{
int x=3;
x=~x;
printf("%d",x);
} // -4
BIT REVERSE
main()
{
int x,i;
printf("enter the number\n");
scanf("%d",&x);
printf("no is %d:",x);
for(i=0;i<32;i++) prefix =" i&1<<31)?1">>i&1)?1:0);
}
Bit operation to find min max number
main()
{
int x=10; // we want to find the minimum of x and y
int y=20;
int min,max; // the result goes here
min = y + ((x - y) & -(x < max =" x" min =" %d" max =" %d">Multiplication of two number using bit operation
#include
main()
{
int i,n,m,temp=0;
printf ( "enter two num\n" );
scanf ( "%d %d ",&n,&m );
for(i=0;i<31;i++) temp =" temp+(m<
main()
{
long int n;
int sum=0,base =1,rem;
printf("enter binary form\n");
scanf("%ld",&n);
while(n!=0)
{
rem = n %2;
sum = sum+rem * base;
base = base *2;
n= n/10;
}
printf("%d",sum);
}
Decimal to binary
#include
main()
{
int n,i=0;
printf("enter number\n");
scanf("%d",&n);
for(i=0;i<32;i++)>Decimal to hexa
#include
main()
{
int n,i=0,rem=0,j;
char hexa[10];
printf("enter number\n");
scanf("%d",&n);
while(n)
{
rem = n %16;
if ( rem < n="n/16;" j="i-1;j">=0;j--)
printf("%c",hexa[j]);
}
Decimal to octal
#include
main()
{
int n,i=0,rem,j;
char s[10];
printf("enter number\n");
scanf("%d",&n);
while(n)
{
rem = n%8;
s[i++]=rem;
n=n/8;
}
s[i]='\0';
for(j=i-1;j>=0;j--)
printf("%d",s[j]);
}
Hexa to decimal
#include
main()
{
char s[]="OX1a";
int i=0,hex;
int base = 1,sum=0;
if (s[i] == '0' s[i]=='O')
i++;
if (s[i]== 'x' s[i]=='X')
i++;
while (s[i] !='\0')
{
i++;
};
--i;
for(;i>=2;i--)
{
if (s[i]>='0'&& s[i]<='9') hex=(s[i]-'0'); if (s[i]>='a' &&s[i]<='f') hex =(s[i]-'a')+10; if (s[i]>='A' &&s[i]<='F') hex =(s[i]-'A')+10; sum += hex*base; base = base *16; } printf("%d",sum); } Octal to decimal
#include
main()
{
long int n;
int sum=0,base =1,rem;
printf("enter octal form\n");
scanf("%ld",&n);
while(n!=0)
{
rem=n%10;
sum = sum+ rem * base;
base = base *8;
n= n/10;
}
printf("%d",sum);
}
FILE RELATED PROGRAMS
To print content of file:
#include
#include
main()
{
FILE *fp;
int c;
fp = fopen("p1.c","r");
while ((c = getc(fp)) != EOF )
{
putchar(c);
}
}
Cut a file upto some position
#include
#include
main()
{
int pos,i=0,count=0,len,c;
FILE *fp;
printf ("enter the position value\n");
scanf ("%d",&pos);
fp = fopen("p1.c","r");
fseek(fp,-2,2);
len = ftell(fp);
fseek(fp,0,0);
if( pos > len )
printf("file size is less.....content of file is\n");
while ( (c = getc(fp)) !=EOF && (count != pos))
{
putchar(c);
count++;
}
printf("\n");
if(posTo create two file depending on even and odd size of words
#include
#include
#include
char * word;
//int size;
//char* malloc (int);
//char* realloc (char *,int);
main()
{
int fd,fd1,fd2;
int count=0;
char c;
word =(char*) malloc(50);
fd = open ("p1.c",O_RDONLY);
fd1 = open ( "f1.c",O_WRONLY);
fd2 = open ( "f2.c",O_WRONLY);
while ( read (fd,&c,1) == 1 )
{
word[count++]=c;
// if ( count >= size )
// word = realloc(word,(size+20));
if ( c == ' ' c== '\t' c == '\n')
{
if ( count % 2)
write (fd1,word,count);
else
write ( fd2,word,count );
count = 0;
}
}
}
To convert first and last char of each word in file uppercase
#include
#include
main(int argc,char *argv[])
{
FILE *fp;
int c,lastc;
char a[20];
int i=0,x;
lastc = '\t';
fp = fopen("p1.c","r");
while ((c = getc(fp)) != EOF )
{
if( c ==' ' c == '\t')
printf("%c",c);
else
if (( c != ' ' c!= '\t' c!='\n') && (lastc ==' ' lastc == '\t' lastc=='\n'))
{
c= c +'A'-'a';
a[i++]=c;
}
else if (( c == ' ' c== '\t' c=='\n') && (lastc !=' ' lastc != '\t' lastc!='\n'))
{// i--;
lastc=lastc+'A'-'a';
a[i++]=lastc;
}
else
{
a[i++]=c;
}
lastc=c;
}
for(x=0;xLs command implementation…to list all files in directory
#include
#include
#include
#include
int main( int argc,char *argv[])
{
DIR *dp;
struct dirent *drp;
char *name;
name = malloc(30);
if( argc != 2)
printf("error");
getpwd(name);
if ( ( dp = opendir(name) )== NULL )
printf("error in opening dir");
while((drp = readdir(dp)) != NULL)
printf("%s\n",drp->d_name);
closedir(dp);
exit(0);
}
To convert vowel upper
#include
#include
main()
{
FILE *fp;
int c;
fp = fopen("p1.c","r");
while ((c = getc(fp)) != EOF )
{
if(c == 'a' c== 'e' c=='i'c=='o'c=='u')
{
c = c +'A'-'a';
printf("%c",c);
}
else
printf("%c",c);
}
}
Reversing of file contents
#include
#include
main()
{
FILE *fp;
int c;
int x,y;
fp = fopen("p1.c","r");
x= ftell(fp);
printf( "Intial value of fp is %d\n",x);
fseek(fp,-1,2);
y = ftell (fp);
printf ( "length of file is %d",y);
while ( ftell (fp) > x)
{
c = getc(fp);
printf("%c",c);
fseek ( fp,-2,1);
}
c = getc(fp);
printf("%c",c);
}
Reversing of lines in file
#include
main()
{
FILE *fp,*fp1;
int c,i=0,x,j,k,s;
char a[50];
fp = fopen ( "p1.c","r");
fp1 = fopen ("p2.c","w");
while ( (c = getc(fp))!= EOF )
{
a[i++]=c;
}
i--;
for( x = i ; x >= -1 ; x--)
{ int k;
if ( a[x] == '\n' x == -1)
{ int s;
for ( s = (x+1);sReversing of each word in file
#include
#include
main()
{
int c;
FILE *fp;
char a[50];
int i=0,x,j,k;
fp = fopen("p1.c","r");
while ( (c = getc(fp)) !=EOF )
{
a[i++]=c;
}
i--;
for(x=i;x>=-1;x--)
{
int k;
if(a[x]==' ' a[x] == '\t' a[x]== '\n' x == -1)
{ int s;
j=x;
printf(" ");
for(s=(j+1);sIMP PROGRAMS:
TO Remove more that line blank line in input:
#include
#define BLANK 'a'
main()
{
int c,lastc;
lastc = BLANK;
while ( (c=getchar()) != EOF)
{
if ( c!= ' ')
putchar(c);
if ( c == ' ')
if (lastc != ' ')
putchar(c);
lastc = c;
}
}
TO count blanks char tabs etc
#include
main()
{
int c,nl=0,nt=0,nc=0,nb=0;
while((c=getchar())!= EOF)
{
if( c == ' ')
nb++;
else if( c == '\t')
nt++;
else if(c == '\n')
nl++;
else
nc++;
}
printf(" no of char =%d\n",nc);
printf(" no of newlines =%d\n",nl);
printf(" no of tabs =%d\n",nt);
printf(" no of blanks =%d\n",nb);
CHAR count in input
#include
main()
{
int count=0;
while(getchar() != EOF)
++count;
printf("\nchar count is %d",count);
}
String copy fun
void copy ( char to[],char from[])
{
int i;
i=0;
while ((to[i]=from[i]) != '\0')
++i;
}
TO print longest line in input
#include
#define MAXLINE 1000
int getline ( char line[],int max);
void copy( char to[],char from[]);
main()
{
int len,max;
char line[MAXLINE];
char longest[MAXLINE];
max =0;
while ((len = getline(line,MAXLINE)) > 0)
if ( len > max)
{
max = len;
copy ( longest,line );
}
if ( max > 0)
printf("\n %s",longest);
}
int getline( char s[],int lim)
{
int c,i;
for( i=0;iTo print histogram
#include
char word[100];
main()
{
int count=0,c,i;
while((c=getchar())!=EOF)
{
word[count++]=c;
if( c == ' ' c == '\t' c == '\n' )
{
word[--count]='\0';
printf("%s:\t",word);
for(i=0;i
char word[100];
main()
{
int count=0,c,i;
while((c=getchar())!=EOF)
{
word[count++]=c;
if( c == ' ' c == '\t' c == '\n' )
{
word[--count]='\0';
printf("%s:\t",word);
for(i=0;i To count occurance of digits(how many times each digits occure)
#include
main()
{
int c,i,digit[10];
for(i=0;i<10;i++) c="getchar())!="">= '0' && c <= '9') ++digit[c -'0']; } for(i=0;i<10;i++)>ONE word per line
#include
char word[100];
main()
{
int count=0,c,i;
while((c=getchar())!=EOF)
{
word[count++]=c;
if( c == ' ' c == '\t' c == '\n' )
{
word[--count]='\0';
printf("%s\t",word);
printf("length %d\n",count);
count =0;
}
}
}
Reverse string
void reverse(char s[]);
main()
{
char str[]="hello";
reverse(str);
printf("%s",str);
}
void reverse( char s[])
{
int i,j;
char temp;
i=0;
while ( s[i] !='\0')
++i;
--i;
printf(" i value is %d",i);
j=0;
while ( j < temp =" s[j];">Atoi( ) function string to integer
#include
main()
{
int n;
char str[10]="12345";
n = atoi(str);
printf ( "%d",n);
}
int atoi ( char str[])
{
int n = 0 ,i;
for(i = 0; str[i] >= '0' && str [i] <= '9';i++) n = 10 * n +(str[i]-'0'); return n; } TO check leap year
main()
{
int year;
printf("enter the year you want to test\n");
scanf("%d",&year);
if(( year%4 == 0 && year %100 != 0 ) year %400 == 0)
printf("entered year is leap year\n");
else
printf("not leap year\n");
}
To convert lower to upper in file#include
main()
{
FILE *fp;
int c;
fp = fopen ( "abc.c","r+");
while ( (c = fgetc(fp)) != EOF)
{
if ( c >= 'a' && c <= 'z') { c = c+'A'-'a'; printf("%c",c); } else printf("%c",c); } } Shothand notation
main()
{
int x=2,y=3,z;
x *= y+1;
printf("%d",x);
}
// answer is 8
x *= y+1
x = (x)*(y+1)
x = 2 *(3+1)
x = 8
its not equal to x= x*y+1;
SQueez character
main()
{
char s[]="hello";
char c = 'l';
void sq( char s[],char c);
sq(s,c);
}
void sq(char s[],char c)
{
int i,j;
for(i=j=0;s[i]!='\0';i++)
{
if ( s[i] != c)
s[j++]=s[i];
}
s[j]='\0';
printf("%s",s);
}
Squeeze string
main()
{
char s1[]="hello";
char s2[]="ol";
int i,j,k;
for(i=k=0;s1[i]!='\0';i++)
{
for(j=0;(s2[j]!= '\0'&&s2[j]!= s1[i]);j++)
;
if ( s2[j]=='\0')
s1[k++]=s1[i];
}
s1[k]='\0';
printf("%s",s1);
}
// first h is compared with ol condition true when j becomes \0 condition fails
// h is moved to s1[k].... similarly for others
Strcat function
main()
{
char s[]="hello";
char t[]="world";
int i=0,j=0;
while ( s[i] !='\0')
i++;
while ( (s[i++]=t[j++]) != '\0');
s[i]='\0';
printf("%s",s);
}
Atof ( )
main()
{
char s[]=" 1.2234";
int i,sign;
float x,n,pow;
for(i=0;(s[i] == ' ');i++)
;
sign = (s[i] == '-') ? -1 : 1;
if ( s[i]=='+' s[i]=='-')
i++;
for( n = 0.0 ;(s[i] >='0' && s[i] <= '9');i++) n = 10.0 * n + (s[i]-'0'); if( s[i] == '.') i++; for(pow = 1.0;(s[i] >= '0' && s[i] <= '9');i++) { n = 10.0 * n + (s[i]-'0'); pow = pow * 10.0; } x = ((n*sign)/pow); printf("%5.4f",x); }
Atof () exponent string to float
main()
{
char s[]="1.2e+2";
int i,sign,expo;
float x,n,pow;
for(i=0;(s[i] == ' ');i++)
;
sign = (s[i] == '-') ? -1 : 1;
if ( s[i]=='+' s[i]=='-')
i++;
for( n = 0.0 ;(s[i] >='0' && s[i] <= '9');i++) n = 10.0 * n + (s[i]-'0'); if( s[i] == '.') i++; for(pow = 1.0;(s[i] >= '0' && s[i] <= '9');i++) { n = 10.0 * n + (s[i]-'0'); pow = pow * 10.0; } n = ((n*sign)/pow); if( s[i]== 'e' s[i] == 'E') { i++; sign = (s[i]=='-')?-1:1; if (s[i]=='+'s[i]=='-') i++; for( expo = 0; (s[i] >= '0' && s[i] <= '9');i++) expo = expo * 10 + (s[i] - '0'); if ( sign == 1) while ( expo-- > 0 )
n = n *10;
else
while (expo-- > 0)
n = n/10;
}
printf("%f",n);
}
Atoi () new…
main()
{
char s[]=" - 1234";
int i,n,sign;
for(i=0;(s[i] == ' ');i++)
;
sign = (s[i] == '-') ? -1 : 1;
if ( s[i]=='+' s[i]=='-')
i++;
for( n = 0 ;(s[i] >='0' && s[i] <= '9');i++) n = 10 * n + (s[i]-'0'); printf("%d",(n*sign)); } Concatenation files content in standard output
#include
#include
void filecopy(int,int);
#define SIZE 20
main( int argc,char *argv[])
{
int fd;
if(argc == 1)
{
printf("no command line arg,copy stdin to stdout\n");
filecopy(0,1);
}
else
{
while(--argc > 0)
{
fd = open(*++argv,O_RDONLY);
filecopy(fd,1);
}
}
close(fd);
}
void filecopy( int ifd,int ofd)
{
int n;
char buf[SIZE];
while( (n = read(ifd,buf,SIZE)) > 0)
if(write(ofd,buf,n)!= n)
printf("write error");
}
Compare files
#include
#include
#include
main( int argc, char *argv[])
{
FILE *fp1,*fp2;
void filecomp(FILE *fp1,FILE *fp2);
if ( argc != 3 )
{
fprintf ( stderr, "error in input" );
exit(1);
}
else
{
fp1 = fopen ( *++argv,"r" );
fp2 = fopen ( *++argv,"r" );
}
filecomp ( fp1,fp2 );
fclose ( fp1 );
fclose ( fp2 );
}
void filecomp ( FILE *fp1, FILE *fp2 )
{
char *p1,*p2;
char line1[80],line2[80];
do
{
p1 = fgets ( line1,10,fp1 );
p2 = fgets ( line2,10,fp2 );
if ( p1 == line1 && p2 == line2 )
{
if ( strcmp ( line1,line2 ) != 0 )
{
printf("difference in line %s",line1 );
p1 = p2 = NULL;
}
}
else if ( p1 !=line1 && p2 == line2 )
printf("end of first line");
else if ( p1 == line1 && p2 != line2)
printf( " end of second line ");
}
while ( p1 == line1 && p2 == line2 );
}
Expand a-z
main()
{
char s1[]="m-z";
char s2[30];
char c;
int i=0,j=0;
while((c=s1[i++]) !='\0')
{
if ( s1[i] == '-'&& s1[i+1] >= c)
{
i++;
while( c <>itoa ( ) integer to sting
void reverse(char s[]);
main()
{
int n = -123,i=0;
char s[4];
int sign;
if ((sign= n)<0) n =" -n">0);
if ( sign < i="0,j="(strlen(s)-1);i Replace tab with some number of blanks
#include
main()
{
int tab = 0,c,d;
printf("enter how many space you want to replace with tab\n");
scanf("%d",&tab);
while ((c=getchar()) !=EOF)
{
if ( c == '\\')
if (( d = getchar()) == 't')
while(tab-- > 0 )
putchar(' ');
else
{
putchar(c);
putchar(d);
}
else
putchar(c);
}
}
Replace tab by \t and newline by \n
#include
// to replace tab by \t and newline by \n
main()
{
int c,i=0,j;
char t[300],s[300];
while((c=getchar())!=EOF)
t[i++]=c;
for( i=0,j=0;t[i] !='\0';i++) // from t to s
{
switch(t[i])
{
case '\n' : s[j++]='\\';
s[j++]='n';
s[j++]=' ';
break;
case '\t' : s[j++]='\\';
s[j++]='t';
s[j++]=' ';
break;
default: s[j++]=t[i];
break;
}
s[j]='\0';
}
printf("%s",s);
}
Strcmp() implementation
int strcmp1(char *,char *);
main()
{int i=0;
char s[6]="hello";
char t[6]="hello";
i = strcmp1(s,t);
if( i ==0)
{
printf("strings are equal");
}
else if ( i > 0)
printf("first string is greater than secone\n");
else
printf("first string is smaller than second string");
}
int strcmp1(char s[],char t[])
{
int i;
for(i=0;s[i]==t[i];i++)
{
if(s[i]=='\0')
break;
}
return ( s[i]-t[i]);
}
Strcpy() implementation
main()
{
char *s ="hello";
char *t;
t = malloc(20);
while( (*t++ = *s++) !='\0')
;
printf("%s",t);
}
Strncat()implementation
void ncat(char *,char *,int);
main()
{
char s[20]="hello";
char t[]="priya";
int n=6;
ncat(s,t,n);
printf("%s",s);
}
void ncat(char *s,char *t,int n)
{
int i;
while(*s)
s++;
for(i=0;i< s="'\0';">Strncpy() implementation
void ncopy(char *,char *,int);
main()
{
char s[]="hello";
char t[5];
int n=7;
ncopy(s,t,n);
printf("%s",t);
}
void ncopy(char *s,char *t,int n)
{
while ( *s && n-- > 0)
*t++ = *s++;
while( n-- >=0)
*t++='\0';
}
To replace tab by \t
#include
main()
{
int c;
while((c=getchar())!= EOF)
{
if( c == '\t')
printf("\\t");
else if ( c == ' ')
printf("\\b");
if( c!='\t')
putchar(c);
}
}
To check no is prime or not
#include
main()
{
int n,res;
printf("enter the no to check\n");
scanf("%d",&n);
res=isPrime(n);
if ( res == 1)
printf("it is prime number\n");
else
printf("it is not prime number\n");
}
int isPrime(int n)
{
int i;
if (n<1) n="="2)" 2="="0)" i =" 2;" i ="="">Prime generation
#include
main()
{
int n,res,i;
printf("enter the limit\n");
scanf("%d",&n);
for( i=0;imakefile in unix
OUT: make1.o make2.o
cc -o OUT make1.o make2.o
clean: @rm *.o
decimal to binary for any number from 1 to 9999
#include
main()
{
int i,n;
static int x;
for(;;)
{
printf("\nEnter the number\n");
scanf("%d",&n);
if ( n==9999)
return;
else
{
for(i=0;i<32;i++)> To count number of times substring present in string
#include
main()
{
int count=0;
char *src="djahellohellosjdzchellofhkjsahellojf";
char *match="hello";
char *t1,*t2;
while(*src)
{
t1=src;
t2=match;
while((*t1++==*t2++)&&*t1!='\0'&&*t2!='\0');
if(*t2=='\0')
count++;
src++;
}
if(count==0)
printf("substring not present");
else
printf("substring present in %d number of times\n",count);
}
To display like for number 3
a b c b a
a b a
a
#include
main()
{
int i,j,k=0,n;
char ch='a';
scanf("%d",&n);
while(n!=0)
{
for(i=0;i n--;
}
}
To display number is even or odd without loop or test
#include
main()
{
int a=255;
char *A[]={"evn","odd"};
printf("%s",A[a%2]);
}
fork( )
main()
{
fork();
fork();
fork();
fork();
fork();
printf("Welcome to Orkut...\n");
fork();
}
// 2 ^5 (2 power 5 times it will come)
To check little endian or big endian
#include
main()
{
int x=1;
if(*(char*)&x ==1)
printf("little");
else
printf("big");
}
#include
main()
{
union un
{
int x;
char ar[sizeof(int)];
}ob;
ob.x=1;
if(ob.ar[0]==1)
Printf("little");
else
printf("big");
}
To display in n=4
a b c d c b a
a b c * c b a
a b * * * b a
a * * * * * a
main()
{
int i,j,k=0,n;
char ch='a';
printf("enter the number\n");
scanf("%d",&n);
int z=n;
int x=1,y;
while(n!=0)
{
y=x;
for(i=0;i n--;
x=x+2;
}
}
Program without main
#define str(s) #s
#define swap(y,x) x##y
int swap(in,ma)()
{
if (printf(str("Friends"))){}
return(0);
}
Random number generation
#include //printf()
#include //srand(), rand()
#include //time()
main()
{
int i;
srand(time(NULL));
for( i=0; i<10;>To print without semicolon
~ #include
main()
{
if(printf("sanmaya"))
;
}
To find size of variable without using sizeof operator
~ #include
main()
{
char var;
int size;
size = (char*)(&var+1)-(char*)(&var);
printf("%d",size);
}
Ptr problem
#include
int main()
{
char *s1;
char *s2;
s1="vinay";
s2="vinay";
printf("%p\t%p",s1,s2);
if(s1==s2)
printf("yes");
else
printf("No");
return;
}
//in same scope address of vinay is same
// two string literals in same scope shares same memory
TO count no of char
~ #include
int main()
{
int i;
char *str="AAAABCCCDD";
char *p=str+1,c,*st,w[3];
st=(char *)malloc(strlen(str));
while(c=*(--p))
{
int j=0;
while(c==*p++)
j++;
j==1?sprintf(w,"%c",c):sprintf(w,"%d%c",j,c);
strcat (st, w);
}
puts(st);
return 0;
}
Strstr()
#include
#include
main()
{
int count=0;
char *p="djahellosjdzchelfhkjsahellojf";
char *q="hello",*r;
while(1)
{
r = strstr(p,q);
if( r!= NULL)
{
count++;
p=r+strlen(q);
}
else
break;
}
if(count==0)
printf("substring not present");
else
printf("substring present in %d number of times\n",count);
}
Swap word
#include
#include
int main(void)
{
char a[6], b[6];
int j, len_a, len_b, len;
strcpy(a, "hello");
strcpy(b, "hipriya");
printf("Before: a = %s, b = %s\n", a, b);
/ get the max length of the two strings
Len_a = strlen(a);
len_b = strlen(b);
len = len_a > len_b ? len_a : len_b;
19 // for each character in the longer of the two strings, including the terminating '\0'
for (j = 0; j <= len; ++j) { // swap two characters char c = a[j]; a[j] = b[j]; b[j] = c; } printf("After: a = %s, b = %s\n", a, b); return 0; } TO print Armstrong numbers
0 1 153
1^3+5 ^3 +3 ^3 = 153
~ #include
main()
{
int i,x,sum=0,rem;
for(i=0;i<500;i++) x="i;" rem =" x%10;" sum =" sum" x="x/10;" i="="sum" sum="0;">TO remove array duplicate elements
~ void sort( int *a,int n)
{
int i=0,j,m;
for(i=0;iExample for assert( ) fun…..
#include
#include
main()
{
int x=10;
assert(x==1);
printf("hi");
}
a.out: assert.c:7: main: Assertion `x==1' failed.
Aborted
Compiler directive
#include
#if something ==0 //if we assign other than zero it will give error..t showa something s defined but t is not defined by using #define so error
int some =0;
#endif
main()
{
printf("%d",some);
}
---------0
TO delete file after execution automatically
#include
main()
{
unlink(argv[0]); //deletes a.out(executable)
unlink(__FILE__); //deletes source code
}
printf("%d\n",__LINE__); //line number
printf("%s\n",__FILE__); //file name
printf("%s\n",__DATE__); //date
printf("%s\n",__TIME__); // current time
Const example
const x;
x=10;
printf("%d",x);
In c its okay in c++ it s error
Enumeratons
enum { a,b,c,d,e,r,t,y,u,p}op;
printf("%d",sizeof(op)); // 4 bytes always in UNIX t does not depends on number of constants
gcd iteration
main()
{
int m=200,n=20;
int r= gcd(m,n);
printf("%d",r);
}
int gcd(int m,int n)
{
while(m !=n)
{
if (m>n)
m=m-n;
else
n=n-m;
}
return(m);
}
HASH FUNCTION
#include
int list[30],indexpos[30],indexsize,tabsize;
int create_hashtable(int,int);
int search_hash(int,int);
main()
{
int i,n,item;
system("clear");
printf("enter the size of original table\n");
scanf("%d",&n);
printf("entre the elements\n");
for(i=0;i
#define MAX(a,b) (a>b?a:b)
main()
{
int i=40,j=30,k=15;
int res;
res=MAX(i,MAX(j,k));
printf("%d",res);
}
To find little and big endian
#include
main()
{ int x=1;
if(*(char*)&x == 1)
printf ("little");
else
printf ("big");
}
union x
{
int x;
char a[sizeof(int)];
};
main()
{
union x ob;
ob.x=1;
if( ob.a[0]==1)
printf("little");
else
printf("big");
}
Little endian to big endan
void bitshow(int n);
main()
{unsigned long int x=1111;
printf("number is %d:",x);
bitshow(x);
printf("\n");
x= ( ((x & 0X000000FF ) <<>> 8 )+
((x & 0XFF000000 ) >> 24 ));
printf("big endian representation:");
bitshow(x);
}
To print own code
#include
int main ()
{
int c;
FILE *f = fopen (__FILE__, "r");
if (!f) return 1;
for (c=fgetc(f); c!=EOF;c=fgetc(f))
putchar (c);
fclose (f);
return 0;
}
TO print triangle
# include
int main ()
{
int k, j = 0, i, n, s, ll;
printf (" Enter The NUmber \n");
scanf ("%d", &n);
s = n;
while (j < k =" 0;" i =" 0;">Replacing “the” with “those” n file
#include
char str[]="the";
char str1[]="those";
char word[50];
main()
{
int c,count=0;
while((c = getchar()) != EOF)
{
word[count++]=c;
if (c== ' 'c == '\t' c== '\n')
{
word[--count]='\0';
if (! strcmp(word,str))
{
printf(" ");
printf("%s",str1);
}
else
{
printf(" ");
printf("%s",word);
}
count = 0;
}//end of if
}//end of while
}//end of main
Printing special number
25 36 125 216
5 ^2 =25
6 ^2= 36
5 ^3=125
#nclude
#include
main()
{
int i,x,remi,count=0;
int rem1,res;
for(i=10;i<1000;i++) x="i;" x="x/10;" rem1="i%10;" res =" pow(rem1,count);" res ="="" count ="0;">To display triangle (inside holo)
*
* *
* *
* *
* * * * *
#include
main()
{
int n,i,j,x;
static int m=1,p;
system("clear");
printf("entre the number\n");
scanf("%d",&n);
for(i=1;i<=n;i++) { for(j=i+1;j<=n;j++) { printf(" "); } x =i; if ( x==1) printf("*"); else if ( x Magic square
include
int
main ()
{
int m[3][3], r = 0, c = 1; //if [7][7] c=3
int k = 1;
while (k <= 9) { m[r][c] = k; if (k % 3 == 0) r = r + 1; else { r = r - 1; c = c + 1; } if (c < c =" 2;"> 2)
c = 0;
if (r < r =" 2;"> 2)
r = 0;
k++;
}
for (r = 0; r <= 2; r++) { printf("\n"); for (c = 0; c <=2 ; c++) printf ("%4d\t", m[r][c]); } } 8 1 6 sum is 15 both vertically and horzontaly 3 5 7 4 9 2 String tokenizer
#include
#include
int main()
{
char hold[6][8];
int i=0,j=0,k=0;
// printf("enter the string\n");
// scanf("%s",array);
char array[]= "hello+world+to+hdfhj+fsdfh";
while(array[i] != '\0')
{
if ( array[i]== '+')
{
i++;
hold[k][j]='\0';
j=0;
k++;
}
hold[k][j++]=array[i];
i++;
}
for(i=0;i <=k;i++) { printf("\n%s",hold[i]); } } To print 1 to 100 and 100 to 1 without using loop
#include
#include
void
prin_down ( int i, int min )
{
if ( i % 8 == 0 )
puts ( "" );
printf ( "%-3d\t", i );
if ( i > min )
prin_down( --i, min );
return;
}
void
prin_up ( int i, int max )
{
if ( i % 8 == 0 )
puts ( "" );
printf ( "%-3d\t", i );
if ( i <>Structure comparison
Write a program to compare two objects of a structure.
Ans
#include
#include
#include
int
main ( void )
{
struct A {
int _1; /* sizeof ( int ) == 4 */
int _2;
float _3; /* sizeof ( float ) == 4 */
char _4; /* sizeof ( char ) is always == 1 */
}a, b;
/* initialize a and b */
...
if ( memcmp ( &a, &b, sizeof a ) == 0 )
puts ( "The two structures are equal" );
else
puts ( "The structures are unequal" );
return EXIT_SUCCESS;
}
This program is very general, and might invoke undefined
behaviour. To make a structure object properly aligned,
the compiler inserts padding bytes whenever (or wherever)
necessary. The Standard does not specify what value these
padded bytes should take. In this example, the objects,
a and b, looks like this:
4 bytes 4 bytes 4 bytes 4 bytes (enlarged)
______ ______ ______ ____ ____ ____ ____
_1 _2 _3 _4 P P P
------ ------ ------ ---- ---- ---- ----
Byte # 0 4 8 12 13 14 15
P is a padding byte in the above illustration, whose value
is undefined. Some compilers may initialize such bytes to
zero, or some may leave it untouched. And, memcmp() compares
padding bytes also, even though these bytes have no meaning!
A more portable and dependable solution is to compare structure
members-by-member, i.e.,
if ( a._1 == b._1 &&
a._2 == b._2 &&
a._3 == b._3 &&
a._4 == b._4 )
puts ( "The two structures are equal" );
else
puts ( "The structures are unequal" );
MAX of 4 integers
#include
#include
#define max2( x, y ) (x) > (y) ? (x) : (y)
#define max4(a, b, c, d) max2 ( max2 ( (a), (b) ), max2 ( (c), (d) ) )
int
main ( void )
{
printf ( "Max: %d\n", max4 ( 10, 20, 30, 40 ) );
printf ( "Max: %d\n", max4 ( 10, 0, 3, 4 ) );
return EXIT_SUCCESS;
}
Combination of all strings
#include
#include
#include
void
string_combi ( char * s, int len )
{
int i;
char tmp;
static int j;
static char *p;
if ( !p )
p = s;
for ( i = 1; i <= len; i++ ) { if ( len > 2 )
string_combi ( s+1, len-1 );
else
{
j++;
printf ( "%d: %s\t", j, p );
if ( !( j%10 ) )
puts ( "" );
}
if ( i < tmp =" s[len-i];">GCD recursion
main()
{
int m=200,n=2;
int x= gcd(m,n);
printf("%d",x);
}
int gcd(int m,int n)
{
if (m==n)
return m;
if ( m==0) return n;
if(n==0)return m;
if(m DATA STRUCTURE
Tree:
#include
#include
struct tree
{
struct tree *left;
int data;
struct tree *right;
};
int inorder (struct tree *sr);
int insert (struct tree **sr, int num);
void Mirror( struct tree *s);
main ()
{
struct tree *bt;
int num, req, d, i = 1;
bt = NULL;
printf ("no. of node");
scanf ("%d", &req);
while (i <= req) { printf ("enter data:"); scanf ("%d", &num); insert (&bt, num); i++; } inorder (bt); } int insert (struct tree **sr, int num) { if ((*sr) == NULL) { (*sr) = (struct tree *) malloc (sizeof (struct tree)); (*sr)->left = NULL;
(*sr)->data = num;
(*sr)->right = NULL;
return;
}
else
{
if (num < (*sr)->data)
insert (&(*sr)->left, num);
else
insert (&(*sr)->right, num);
}
return;
}
int inorder(struct tree *sr)
{
if ((sr) != NULL)
{
inorder ((sr)->left);
printf ("%d\n", (sr)->data);
inorder ((sr)->right);
}
return;
}
void Mirror( struct tree *s) // print n preorder
{
struct tree *t;
if( s == NULL)
return;
else
{
Mirror( s->left);
Mirror(s->rght);
t= s->left;
s->left = s->right;
s->right= t;
}
}
Tree copy
#include
#include
struct btnode
{
struct btnode *left;
int data;
struct btnode *right;
};
int insert (struct btnode **sr, int num);
int preorder (struct btnode *sr);
int copy (struct btnode **src, struct btnode **tgt);
int
main ()
{
struct btnode *bt1, *bt2;
int num, req, d, i = 1;
bt1 = NULL;
printf ("no. of node");
scanf ("%d", &req);
while (i <= req) { printf ("enter data:"); scanf ("%d", &num); insert (&bt1, num); i++; } copy (&bt1, &bt2); printf ("\n original tree\n preorder traversal:"); preorder (bt1); printf ("\n\n\n copied tree\npreorder traversal:"); preorder (bt2); } int copy (struct btnode **src, struct btnode **tgt) { if (*src != NULL) { *tgt = (struct btnode *) malloc (sizeof (struct btnode)); (*tgt)->left = NULL;
(*tgt)->data = (*src)->data;
(*tgt)->right = NULL;
copy (&((*src)->left), &((*tgt)->left));
copy (&((*src)->right), &((*tgt)->right));
}
return;
}
int
insert (struct btnode **sr, int num)
{
if (*sr == NULL)
{
(*sr) = (struct btnode *) malloc (sizeof (struct btnode));
(*sr)->left = NULL;
(*sr)->data = num;
(*sr)->right = NULL;
return;
}
else
{
if (num < (*sr)->data)
insert (&((*sr)->left), num);
else
insert (&((*sr)->right), num);
}
return;
}
int
preorder (struct btnode *sr)
{
if (sr != NULL)
{
printf ("%d", sr->data);
preorder (sr->left);
preorder (sr->right);
}
return;
}
Tree compare
#include
#include
struct btnode
{
struct btnode *left;
int data;
struct btnode *right;
};
int insert (struct btnode **sr, int num);
int compare(struct btnode *sr1, struct btnode *sr2);
int flag = 1;
int
main ()
{
struct btnode *bt1, *bt2;
int num, req, d, i = 1;
bt1 = NULL;
bt2 = NULL;
printf ("no. of node for first tree");
scanf ("%d", &req);
while (i <= req) { printf ("enter data:"); scanf ("%d", &num); insert (&bt1, num); i++; } i = 1; printf (" no. of nodes for second tree "); scanf ("%d", &req); while (i <= req) { printf ("enter data:"); scanf ("%d", &num); insert (&bt2, num); i++; } compare (bt1, bt2); if (flag == 1) printf ("\n trees are Identical"); else printf ("\n trees are not Identical"); } int insert (struct btnode **sr, int num) { if (*sr == NULL) { (*sr) = (struct btnode *) malloc (sizeof (struct btnode)); (*sr)->left = NULL;
(*sr)->data = num;
(*sr)->right = NULL;
return;
}
else
{
if (num < (*sr)->data)
insert (&((*sr)->left), num);
else
insert (&((*sr)->right), num);
}
return;
}
int
compare (struct btnode *sr1, struct btnode *sr2)
{
int l, r;
l = (sr1 == NULL ? 1 : 0);
r = (sr2 == NULL ? 1 : 0);
if (l != r)
flag = 0;
if (sr1 != NULL && sr2 != NULL)
{
if (sr1->data != sr2->data)
flag = 0;
compare (sr1->left, sr2->left);
compare (sr1->right, sr2->right);
}
return;
}
To delete particular node in list……………..You have been given a pointer to an arbitrary node in a linked list,which you should delete without corrupting the list. The head of thelist in not given. ptr _____ _____ _____ _____ _____ 1 --> 3 --> 5 --> 7 --> 9 --- ----- ----- ----- ----- ----- ---- -- Solution: void del_node ( node_t *ptr ) { if ( ptr && ptr -> next ) { node_t *arb = ptr -> next; ptr -> data = ptr -> next -> data; ptr -> next = ptr -> next -> next; free ( arb ); } else if ( ptr && ptr -> next == NULL ) //when it is last node { free ( ptr ); ptr = NULL; } return; }
Reversing of linked list…………….
Question:
You have to reverse a linked list, but the condition is that data X which
resides in the node N should not change. For example,
Addr: 100 200 300 400 500
_____ _____ _____ _____ _____
1 --> 3 --> 5 --> 7 --> 9 ---
----- ----- ----- ----- -----
----
--
should become
Addr: 100 200 300 400 500
_____ _____ _____ _____ _____
1 <-- 3 <-- 5 <-- 7 <-- 9 ----- ----- ----- ----- ----- ---- -- Answer: Generally, we give the solution as follows: Addr: 100 200 300 400 500 _____ _____ _____ _____ _____ 9 --> 7 --> 5 --> 3 --> 1 ---
----- ----- ----- ----- -----
----
--
We write a function reverse () which takes two arguments: one a pointer
to the head, and the other, pointer to second node of the list.
void
reverse ( node_t *hd, node_t *nxt )
{
if ( nxt && nxt -> next )
revesre ( nxt, nxt -> next );
nxt -> next = hd;
hd -> next = NULL;
}
Circular linked list…………..
#include
#include
struct node
{
int info;
struct node *link;
};
typedef struct node * NODE;
NODE insert_front(int,NODE);
NODE insert_rear(int,NODE);
NODE delete_front(NODE);
NODE delete_rear(NODE);
NODE getnode();
void freenode(NODE);
void display(NODE);
main()
{ NODE last;
last = NULL;
int choice,item;
system ("clear");
do
{
printf ( "1.INSERT FRONT\n" );
printf ( "2.INSERT REAR\n" );
printf ( "3.DELETE FRONT\n" );
printf ( "4.DELETE REAR\n" );
printf ( "5.DISPLAY\n" );
printf ( "6.EXIT\n" );
printf ("Enter The Choice\n" );
scanf ( "%d", &choice );
switch ( choice )
{
case 1: printf ( "Enter the element to b inserted\n " );
scanf ( "%d", &item );
last = insert_front ( item,last );
break;
case 2: printf ( "Enter the element to b inserted\n " );
scanf ( "%d", &item );
last = insert_rear(item,last);
break;
case 3: last= delete_front(last );
break;
case 4: last = delete_rear(last);
break;
case 5: display(last);
break;
case 6: exit ( 0 );
break;
}
}while ( choice <= 6); } NODE insert_front ( int item, NODE last ) { NODE temp; temp = getnode( ); temp->info = item;
if ( last == NULL)
last = temp;
else
temp->link = last->link;
last->link= temp;
return last;
}
NODE insert_rear ( int item, NODE last )
{
NODE temp;
temp = getnode();
temp->info = item;
if ( last == NULL)
{
last = temp;
last->link = last;
}
else
{
temp->link = last->link;
last->link = temp;
}
return temp; // now temp is last node
}
void display ( NODE last )
{
NODE temp,first;
temp = last;
if ( last == NULL )
{
printf ( "list is empty" );
return;
}
printf ( "\n" );
printf ( "contents of list are\n ");
first= last;
for(temp=last->link;temp!=last;temp= temp->link)
{
printf ( "%d\t",temp->info );
}
printf("%d\n",temp->info); //TO PRINT LAST NODE
}
NODE getnode ()
{
NODE temp;
temp = (NODE)malloc (sizeof ( struct node ));
if ( temp == NULL )
{
printf ( "out of memory ");
exit ( 0 );
}
return temp;
}
NODE delete_front(NODE last)
{
NODE first,temp;
if ( last == NULL)
{
printf("list is empty\n");
return;
}
if ( last->link == last)
{
printf("%d deleted",last->info);
freenode(last);
last = NULL;
return last;
}
first = last->link;
temp = first->link;
printf("%d deleted\n",first->info);
freenode(first);
last->link = temp;
return last;
}
NODE delete_rear(NODE last)
{
NODE prev;
if ( last == NULL)
{
printf("list is empty\n");
return;
}
if ( last->link == last)
{
printf("%d deleted",last->info);
freenode(last);
return NULL;
}
prev = last->link; // to find prev of last node
while( prev->link != last)
{
prev = prev->link;
}
prev->link = last->link;
printf("%d deleted",last->info);
freenode(last);
return prev;
}
void freenode(NODE last)
{
free(last);
}
Double linked list……………….
// implementation of doubly linked list
#include
#include
// structure for doubly linked list
struct node
{
int info;
struct node *rlink;
struct node *llink;
};
typedef struct node *NODE;
//functions used
NODE getnode ( );
NODE insert_front ( int, NODE );
NODE insert_rear ( int, NODE );
NODE delete_front ( NODE );
NODE delete_rear ( NODE );
void display ( NODE );
void freenode ( NODE) ;
// main starts
main()
{
NODE head;
int item,choice;
system ( "clear" );
head = getnode ( );
head->rlink = head;
for ( ;; )
{
printf ( "1.INSERT FRONT\n" );
printf ( "2.INSERT REAR\n" );
printf ( "3.DELETE FRONT\n" );
printf ( "4.DELETE REAR\n" );
printf ( "5.DISPLAY\n" );
printf ( "6.EXIT\n" );
scanf ( "%d",&choice );
switch ( choice )
{
case 1: printf ( "enter the item to be inserted\n" );
scanf ( "%d",&item );
head = insert_front ( item, head );
break;
case 2: printf ( "enter the item to be inserted\n" );
scanf ( "%d",&item );
head = insert_rear ( item, head );
break;
case 3: head = delete_front ( head );
break;
case 4: head = delete_rear ( head );
break;
case 5: display ( head );
break;
case 6: exit ( 0 );
break;
default: exit ( 0 );
}// switch ends
} // for ends
}// main ends
//functions definitions
NODE insert_front ( int item, NODE head )
{
NODE temp,cur;
// node to be inserted
temp = getnode ( );
temp->info = item;
// node is inserted between head and first node
// head new first
cur = head->rlink;
head->rlink = temp;
temp->llink = head;
temp->rlink = cur;
cur->llink = temp;
return head;
}
NODE insert_rear ( int item, NODE head )
{
NODE temp,cur;
// node to be inserted
temp = getnode ( );
temp->info = item;
// node is inserted between head and first node
cur = head->llink;
head->llink = temp;
temp->rlink = head;
temp->llink = cur;
cur->rlink = temp;
return head;
}
NODE delete_front ( NODE head )
{
NODE cur ,next;
if ( head->rlink == head )
{
printf ( "list is empty\n" );
return head;
}
cur = head->rlink; // first node in list
next = cur->rlink; // second node in list in known
head->rlink = next;
next->llink = head;
printf ( "Deleted item is %d\n",cur->info );
freenode ( cur );
return head;
}
NODE delete_rear ( NODE head )
{
NODE cur, prev;
if ( head->rlink == head )
{
printf ( "list is empty\n" );
return head;
}
cur = head->llink; // last node
prev = cur->llink;
head->llink = prev;
prev->rlink = head;
printf ( "Deleted item is %d\n", cur->info);
freenode ( cur );
return head;
}
void display ( NODE head )
{
NODE temp;
if ( head->rlink == head )
{
printf ( "list is empty" );
exit ( 0 );
}
printf ( " content of list are\n" );
for ( temp = head->rlink; temp != head ; temp = temp->rlink )
printf ( "%d\t",temp->info );
printf ( "\n" );
}
NODE getnode ( )
{
NODE x;
x = ( NODE ) malloc ( sizeof( struct node) );
return x;
}
void freenode ( NODE x )
{
free ( x );
}
Linked list………………….
#include
#include
struct node
{
int info;
struct node *link;
};
typedef struct node * NODE;
main()
{
NODE first;
first = NULL;
int choice,item;
system ("clear");
do
{
printf ( "1.INSERT\n" );
printf ( "2.DISPLAY\n" );
printf ( "3.EXIT\n" );
printf ("Enter The Choice\n" );
scanf ( "%d", &choice );
switch ( choice )
{
case 1: printf ( "Enter the element to b inserted\n " );
scanf ( "%d", &item );
first = insert ( item,first );
break;
case 2: display ( first );
break;
case 3: exit ( 0 );
break;
}
}while ( choice <= 3); } NODE insert ( int item, NODE first ) { NODE temp; temp = getnode( ); temp->info = item;
temp->link = first;
return temp;
}
void display ( NODE first )
{
NODE temp;
temp = first;
if ( first == NULL )
{
printf ( "list is empty" );
return;
}
printf ( "\n" );
printf ( "contents of list are\n ");
while ( temp != NULL )
{
printf ( "%d\t",temp->info );
temp = temp->link;
}
printf ( "\n" );
}
NODE getnode ()
{
NODE temp;
temp = (NODE)malloc (sizeof ( struct node ));
if ( temp == NULL )
{
printf ( "out of memory ");
exit ( 0 );
}
return temp;
} Important prog in linked list……………
// to find middle node in list
NODE middle_node(NODE first)
{
NODE temp,cur;
temp=first;
cur = first;
while(temp != NULL)
{
temp= temp->link;
if( temp != NULL)
{
temp=temp->link;
cur = cur->link;
}
else
{
break;
}
}
printf("middle node = %d", cur->info);
return first;
}
// insert front in list
NODE insert_front(NODE first,int n)
{
NODE temp;
temp = getnode();
temp->info=n;
temp->link =first;
return temp;
}
// delete front from list
NODE delete_front(NODE first)
{
NODE temp;
temp = first;
first = first->link;
printf("deleted item id %d",temp->info);
freenode(temp);
return first;
}
// display list
void display(NODE first)
{
NODE temp;
if(first == NULL)
printf("empty list\n");
for(temp=first;temp!=NULL;temp=temp->link)
printf("%d\t",temp->info);
printf("\n");
}
// to get node
NODE getnode()
{
NODE temp;
temp =(NODE) malloc(sizeof(struct node));
if( temp== NULL)
printf("no memory\n");
return temp;
}
// insert rear
NODE insert_rear(NODE first,int n)
{
NODE temp,cur;
temp = getnode();
temp->info=n;
temp->link = NULL;
if( first == NULL)
return temp;
cur = first;
while(cur->link !=NULL)
{
cur = cur->link;
}
cur->link = temp;
return first;
}
// delete rear
NODE delete_rear(NODE first)
{
NODE prev,cur;
if ( first == NULL)
{
printf("list is empty\n");
return first;
}
if( first->link == NULL)
{
printf("deleted node is %d\n",first->info);
freenode(first);
first = NULL;
return first;
}
cur = first;
prev = NULL;
while( cur->link != NULL)
{
prev = cur;
cur = cur->link;
}
printf("deleted node is %d\n",cur->info);
freenode(cur);
prev->link = NULL;
return first;
}
// insert after some position
NODE insert_after(int item,NODE first,int n)
{
NODE temp,cur,next;
int count = 1;
temp = getnode();
temp->info = item;
temp->link = NULL;
if( first == NULL)
return temp;
cur = first;
while( cur != NULL && count < cur =" cur">link;
count++;
}
if ( cur == NULL)
{
printf("invalid position no\n");
exit(0);
}
next = cur->link;
cur->link= temp;
temp->link= next;
return first;
}
// insert before
NODE insert_before(int item,NODE first,int n)
{
NODE temp,cur,next,prev;
int count = 1;
temp = getnode();
temp->info = item;
temp->link = NULL;
cur = first;
if( first == NULL)
return temp;
if ( n == 1 ) // to add in first position
{
temp->link = cur;
return temp;
}
while( cur != NULL && (count+1) < prev =" cur;" cur =" cur">link;
count++;
}
if( count+1 == n) // to add in last position
{
prev->link = temp;
return first;
}
if ( count+1 < next =" cur-">link;
cur->link = temp;
temp->link=next;
return first;
}
// to delete after some position
NODE delete_after(int item,NODE first,int n)
{
NODE cur,next,prev;
int count = 1;
if( first == NULL)
{
printf("list is empty");
return;
}
prev = NULL;
cur = first;
while( cur != NULL && count < (n+1)) { prev = cur; cur = cur ->link;
count++;
}
next= cur->link;
prev->link =next;
printf("%d is deleted",cur->info);
freenode(cur);
return first;
}
// delete before some position
NODE delete_before(int item,NODE first,int n)
{
NODE cur,next,prev;
int count = 1;
if( first == NULL)
{
printf("list is empty");
return;
}
next = NULL;
prev = NULL;
cur = first;
if( n == 1 )
{
printf(" no element befor that to delete");
return;
}
if ( n == 2)
{
next = cur->link;
printf("%d is deleted\n",cur->info);
freenode(cur);
return next;
}
while( cur != NULL && (count+1) < prev =" cur;" cur =" cur">link;
count++;
}
next= cur->link;
prev->link =next;
printf("%d is deleted",cur->info);
freenode(cur);
return first;
}
// insert in order list
NODE insert ( int item, NODE first )
{
NODE temp,cur,prev;
// get node to be inserted
temp = getnode();
temp->info = item;
temp->link = NULL;
//if list is empty
if ( first == NULL )
return temp;
//insert at begining
if ( item <>info )
{
temp->link = first;
return temp;
}
cur = first;
prev = NULL;
while ( cur != NULL && item > cur->info )
{
prev = cur;
cur = cur->link;
}
prev->link = temp;
temp->link = cur;
return first;
}
// search a item in list
NODE search(int key ,NODE first)
{
NODE cur;
int pos;
if( first == NULL)
{
printf("list is empty");
return;
}
cur = first;
pos =1;
while (cur != NULL && key != cur->info)
{
pos++;
cur = cur->link;
}
if ( cur == NULL)
{
printf("unsuccessful");
return;
}
else
printf("successfull item found in position %d",pos);
return first;
}
// merge list
NODE merge ( NODE a, NODE b )
{
NODE i,j,k,c;
i = a;
j = b;
c =k= getnode();
while ( i != NULL && j != NULL )
{
if ( i->info <>info )
{
k->link = i;
i = i->link;
}
else
{
k->link = j;
j = j->link;
}
k = k->link;
}
while ( i != NULL )
{
k->link = i;
i= i->link;
}
while ( j != NULL )
{
k->link = j;
j= j->link;
}
return c->link;
}
// concat two lists
NODE concat ( NODE a, NODE b )
{
NODE cur;
if ( a == NULL)
return b;
else if ( b== NULL)
return a;
cur = a;
while( cur->link != NULL)
cur = cur->link;
cur->link = b;
return a;
}
// no of nodes
NODE nodes(NODE first)
{
NODE temp;
int count = 1;
temp = first;
if ( first == NULL)
{
printf("list is empty\n");
return;
}
while( temp->link != NULL)
{
temp = temp->link;
count++;
}
printf("total no of nodes == %d\n",count);
return first;
}
// insert specified position
NODE insert_specified(int item,NODE first,int n)
{
NODE temp,prev,cur;
int count;
temp = getnode();
temp->info = item;
temp->link=NULL;
if( first == NULL && n == 1)// inserting node for first time
return temp;
if ( first == NULL)
{
printf("invalid pos\n");
return first;
}
if ( n == 1)
{
temp->link = first;
return temp;
}
count = 1;
prev = NULL;
cur = first;
while( cur != NULL && count != n)
{
prev = cur;
cur = cur->link;
count++;
}
if ( count == n)
{
prev->link = temp;
temp->link = cur;
return first;
}
printf("invalid position");
return first;
}
// delete from specified position
NODE delete_specified(NODE first,int pos)
{
NODE prev,cur;
int count;
if( first == NULL )
{
printf("list is empty\n");
return first;
}
if (pos == 1)
{
cur = first;
first = first->link;
printf("%d deleted",cur->info);
freenode(cur);
return first;
}
count = 1;
prev = NULL;
cur = first;
while( cur != NULL && count != pos)
{
prev = cur;
cur = cur->link;
count++;
}
if ( cur == NULL)
{
printf("invalid position");
return first;
}
prev->link= cur->link;
return first;
}
// delete node whose info given
NODE delete_specified_info(NODE first,int item)
{
NODE prev,cur;
int count;
if( first == NULL )
{
printf("list is empty\n");
return first;
}
if (item == first->info)
{// delete first node
cur = first;
first = first->link;
printf("%d deleted",cur->info);
freenode(cur);
return first;
}
prev = NULL;
cur = first;
while( cur != NULL && item != cur->info)
{
prev = cur;
cur = cur->link;
}
if ( cur == NULL)
{
printf("item not found");
return first;
}
prev->link= cur->link;
freenode(cur);
return first;
}
// to replace all accurance of given value by other value
NODE replace(int a,int b,NODE first)
{
NODE cur;
int count = 0;
cur = first;
while (cur != NULL )
{
if ( a != cur->info)
cur = cur->link;
else
{
count++;
cur->info = b;
cur = cur->link;
}
}
if ( count == 0)
printf("item nnot found in list\n");
return first;
}
// replace some node value by other value
NODE replace(int a,int b,NODE first)
{
NODE cur;
int count = 0;
cur = first;
count =1;
while (cur != NULL )
{
if ( a != count)
{
cur = cur->link;
count++;
}
else
{
count++;
cur->info = b;
cur = cur->link;
return first;
}
}
if ( cur == NULL)
printf("node not found in list\n");
return first;
}
// sum of all elements in list
NODE sum(NODE first)
{
NODE cur;
int count = 0;
cur = first;
if ( first == NULL)
{
printf("list is empty\n");
return;
}
while (cur != NULL )
{
count = count+cur->info;
cur = cur->link;
}
printf("sum of all elements %d",count);
return first;
}
// delete all duplicate ele with specified info
NODE delete_specified_info(NODE first,int item)
{
NODE prev,cur;
int count=0;
if( first == NULL )
{
printf("list is empty\n");
return first;
}
if (item == first->info)
{// delete first node
cur = first;
first = first->link;
printf("%d deleted",cur->info);
freenode(cur);
}
prev = NULL;
cur = first;
while( cur != NULL)
{
if( item != cur->info)
{
prev = cur;
cur = cur->link;
}
else
{
count++;
prev->link= cur->link;
freenode(cur);
return first;
}
}
if( count == 0)
printf ("item not found in list\n");
return first;
}
// split list... each successive elements should move to seperate list
NODE split(NODE first)
{
NODE i,j,cur;
i = NULL;
j= NULL;
int count=1;
cur = first;
while( cur != NULL)
{
if ( count%2 != 0)
{
i = insert(cur->info,i);
cur = cur->link;
count++;
}
else
{
j= insert(cur->info,j);
cur = cur->link;
count++;
}
}
printf("first list is \n");
display(i);
printf("second list is \n");
display(j);
return first;
}
// split list into two evn odd lists
NODE split(NODE first)
{
NODE i,j,cur;
i = NULL;
j= NULL;
cur = first;
while( cur != NULL)
{
if ( (cur->info)%2 == 0)
{
i = insert(cur->info,i);
cur = cur->link;
}
else
{
j= insert(cur->info,j);
cur = cur->link;
}
}
printf("even list is \n");
display(i);
printf("odd list is \n");
display(j);
return first;
}
// CIRCULAR LIST
// combining two circular list into one circular list
NODE com( NODE a, NODE b )
{
NODE i,j,k,c,m;
i = a->link;
m = a->link;
j = b->link;
c = k = getnode();
while ( i != a)
{
i = i->link;
}
i->link = b->link;
while( i != b)
{
i= i->link;
}
i->link=m;
return i;
}
// insert front
NODE insert_front ( int item, NODE last )
{
NODE temp;
temp = getnode( );
temp->info = item;
if ( last == NULL)
last = temp;
else
temp->link = last->link;
last->link= temp;
return last;
}
// insert rear
NODE insert_rear ( int item, NODE last )
{
NODE temp;
temp = getnode();
temp->info = item;
if ( last == NULL)
{
last = temp;
last->link = last;
}
else
{
temp->link = last->link;
last->link = temp;
}
return temp; // now temp is last node
}
// delete front
NODE delete_front(NODE last)
{
NODE first,temp;
if ( last == NULL)
{
printf("list is empty\n");
return;
}
if ( last->link == last)
{
printf("%d deleted",last->info);
freenode(last);
last = NULL;
return last;
}
first = last->link;
temp = first->link;
printf("%d deleted\n",first->info);
freenode(first);
last->link = temp;
return last;
}
// delete rear
NODE delete_rear(NODE last)
{
NODE prev;
if ( last == NULL)
{
printf("list is empty\n");
return;
}
if ( last->link == last)
{
printf("%d deleted",last->info);
freenode(last);
return NULL;
}
prev = last->link; // to find prev of last node
while( prev->link != last)
{
prev = prev->link;
}
prev->link = last->link;
printf("%d deleted",last->info);
freenode(last);
return prev;
}
// doubly linked list
struct node
{
int info;
struct node *rlink;
struct node *llink;
};
head = getnode ( );
head->rlink = head;
NODE insert_front ( int item, NODE head )
{
NODE temp,cur;
temp = getnode ( );
temp->info = item;
// node is inserted between head and first node
// head new first
cur = head->rlink;
head->rlink = temp;
temp->llink = head;
temp->rlink = cur;
cur->llink = temp;
return head;
}
NODE insert_rear ( int item, NODE head )
{
NODE temp,cur;
// node to be inserted
temp = getnode ( );
temp->info = item;
// node is inserted between head and first node
cur = head->llink;
head->llink = temp;
temp->rlink = head;
temp->llink = cur;
cur->rlink = temp;
return head;
}
NODE delete_front ( NODE head )
{
NODE cur ,next;
if ( head->rlink == head )
{
printf ( "list is empty\n" );
return head;
}
cur = head->rlink; // first node in list
next = cur->rlink; // second node in list in known
head->rlink = next;
next->llink = head;
printf ( "Deleted item is %d\n",cur->info );
freenode ( cur );
return head;
NODE delete_rear ( NODE head )
{
NODE cur, prev;
if ( head->rlink == head )
{
printf ( "list is empty\n" );
return head;
}
cur = head->llink; // last node
prev = cur->llink;
head->llink = prev;
prev->rlink = head;
printf ( "Deleted item is %d\n", cur->info);
freenode ( cur );
return head;
}void display ( NODE head )
{
NODE temp;
if ( head->rlink == head )
{
printf ( "list is empty" );
exit ( 0 );
}
printf ( " content of list are\n" );
for ( temp = head->rlink; temp != head ; temp = temp->rlink )
printf ( "%d\t",temp->info );
printf ( "\n" );
}
NODE insert_left ( int item,int pos, NODE head )
{
NODE temp,cur,prev;
if ( head->rlink == head )
{
printf ( "list is empty" );
return head;
}
// search for position
cur = head->rlink;
while ( cur != head && pos != cur->info )
{
cur = cur->rlink;
}
if ( cur == head )
{
printf ( "position not found\n " );
return head;
}
prev = cur->llink;
// node to be inserted
temp = getnode ( );
temp->info = item;
prev->rlink = temp;
temp->llink = prev;
cur->llink = temp;
temp->rlink = cur;
return head;
}
NODE insert_right( int item,int pos, NODE head )
{
NODE temp,cur,next;
if ( head->rlink == head )
{
printf ( "list is empty" );
return head;
}
// search for position
cur = head->rlink;
while ( cur != head && pos != cur->info )
{
cur = cur->rlink;
}
if ( cur == head )
{
printf ( "position not found\n " );
return head;
}
next = cur->rlink;
// node to be inserted
temp = getnode ( );
temp->info = item;
cur->rlink = temp;
temp->llink = cur;
temp->rlink = next;
next->llink = temp;
return head;
}
NODE delete_info ( int item,NODE head )
{
NODE cur ,prev,next;
if ( head->rlink == head )
{
printf ( "list is empty\n" );
return head;
}
cur = head->rlink; // first node in list
while ( cur != head && item != cur->info )
{
cur = cur->rlink;
}
if ( cur == head )
{
printf ( "item not found\n" );
return head;
}
//item found
prev = cur->llink;
next = cur->rlink;
prev->rlink = next;
next->llink = prev;
freenode( cur );
return head;
}
NODE delete_all ( int item,NODE head )
{
int count=0;
NODE cur, prev,next;
if ( head->rlink == head )
{
printf ( "list is empty\n" );
return head;
}
cur = head->rlink; // last node
while ( cur != head )
{
if ( item != cur->info)
cur = cur->rlink;
else
{
count++;
prev = cur->llink;
next = cur->rlink;
prev ->rlink = next;
next->llink = prev;
freenode ( cur );
cur = next; // next search starts from this point
}
}
if ( count == 0 )
{
printf ( "item not found in list \n" );
}
return head;
}
Reversing of lnked list………
NODE rev ( NODE first)
{
NODE cur,temp;
cur = NULL;
while ( first != NULL )
{
temp = first;
first = first ->link;
temp->link = cur;
cur = temp;
}
return cur;
}
STACK
#define SIZE 20
struct stack
{
int item[SIZE];
int top;
};
void push(struct stack *s,int);
int pop(struct stack *s);
void display(struct stack *s);
main()
{
struct stack *s;
s->top = -1;
int ch,item;
printf("STACK OPETAIONS\n");
do
{
printf("\n 1.PUSH\n");
printf("2.POP\n");
printf("3.DISPLAY\n");
printf("4.EXIT\n");
printf("ENTER YOUR CHOICE\n");
scanf("%d",&ch);
switch(ch)
{
case 1: printf("Enter the item to pushed onto stack\n");
scanf("%d",&item);
push(s,item);
break;
case 2: item = pop(s);
printf("deleted item is %d\n",item);
break;
case 3: display(s);
break;
case 4: exit(0);
}
}while( ch <= 4); } void push( struct stack *s,int item) { if( s->top == SIZE-1)
{
printf("stack is overflow\n");
exit(0);
}
s->item[++(s->top)]=item;
printf("top is %d\n",s->top);
}
int pop(struct stack *s)
{
int item;
if ( s->top == -1 )
{
printf("stack is empty\n");
exit(0);
}
item = s->item[s->top--];
return item;
}
void display( struct stack *s)
{
int i;
if ( s->top == -1 )
{
printf("stack is empty\n");
exit(0);
}
printf("stack elements are\n");
for(i=s->top;i>=0;i--)
printf("%d\t",s->item[i]);
}
Stack using array
#define SIZE 20
int item[SIZE];
int top=-1;
int item1; // item to be inserted
void push();
int pop();
void display();
main()
{
int ch;
printf("STACK OPETAIONS\n");
do
{
printf("\n 1.PUSH\n");
printf("2.POP\n");
printf("3.DISPLAY\n");
printf("4.EXIT\n");
printf("ENTER YOUR CHOICE\n");
scanf("%d",&ch);
switch(ch)
{
case 1: printf("Enter the item to pushed onto stack\n");
scanf("%d",&item1);
push();
break;
case 2: item1 = pop();
printf("deleted item is %d\n",item1);
break;
case 3: display();
break;
case 4: exit(0);
}
}while( ch <= 4); } void push() { if( top == SIZE-1) { printf("stack is overflow\n"); exit(0); } item[++top]=item1; } int pop() { if ( top == -1 ) { printf("stack is empty\n"); exit(0); } item1 = item[top]; top--; return item1; } void display( ) { int i; if (top == -1 ) { printf("stack is empty\n"); exit(0); } printf("stack elements are\n"); for(i=top;i>=0;i--)
printf("%d\t",item[i]);
}
Copy linked list: insert() display() getnode() are same
void copy(NODE s,NODE *t); // copy from s to t
main()
{
NODE first,first1;
first = NULL;
first1 = NULL;
int choice,item,n;
printf("enter how many elements u want to insert\n");
scanf("%d",&n);
while( n)
{
printf("enter the element\n");
scanf("%d",&item);
first = insert ( item,first );
n--;
}
printf("list before copy\n");
display(first);
copy(first,&first1);
printf("list after copy\n");
display(first1);
}
void copy(NODE s,NODE *t)
{
if ( s != NULL)
{
(*t) = malloc ( sizeof ( struct node));
(*t)->info = s->info;
(*t)->link = NULL;
copy( s->link,&((*t)->link));
}
}
Comparing two list:
int compare (NODE s, NODE t);
main ()
{
NODE first, first1;
first = NULL;
first1 = NULL;
int flag, item, n,n1;
printf ("enter no of lements for first list\n");
scanf ("%d", &n);
while (n)
{
printf ("enter the element\n");
scanf ("%d", &item);
first = insert (item, first);
n--;
}
printf ("enter no of lements for second list\n");
scanf ("%d", &n1);
if( n != n1)
{
printf("unequal\n");
exit(0);
}
while (n1)
{
printf ("enter the element\n");
scanf ("%d", &item);
first1 = insert (item, first1);
n1--;
}
flag = compare (first, first1);
if( flag)
printf("equal");
else
printf("unequal");
}
int
compare (NODE first, NODE first1)
{
static int flag;
if (first == NULL && first1 == NULL)
flag = 1;
else
{
if (first->info != first1->info)
flag = 0;
else
compare (first->link, first1->link);
}
return flag;
}
Recursive reverse linked list
NODE * rev ( NODE * root)
{
If ( root)
{
rev( root->next);
printf(“%d”,root->info);
}
}
To find middle node in list
void middle(NODE first)
{
NODE p,q;
p= first;
q= first;
if( q->link->link != NULL)
{
p= p->link;
q=q->link->link;
}
printf("%middle ele is %d\n",p->info);
}
Delete particular node first pointer not given
struct node
{
int info;
struct node *link;
};
typedef struct node * NODE;
NODE getnode();
NODE insert(int ,NODE);
void display(NODE);
void del(NODE);
NODE a[7];
static int i=0;
main()
{
NODE first;
first = NULL;
int choice,item,n;
printf("enter how many elements u want to insert\n");
scanf("%d",&n);
while( n)
{
printf("enter the element\n");
scanf("%d",&item);
first = insert ( item,first );
n--;
}
printf("list is\n");
display(first);
del(a[1]);
display(first);
}
NODE insert ( int item, NODE first )
{
NODE temp;
temp = getnode( );
a[i++]=temp;
temp->info = item;
temp->link = first;
return temp;
}
void display ( NODE first )
{
NODE temp;
temp = first;
if ( first == NULL )
{
printf ( "list is empty" );
return;
}
printf ( "\n" );
printf ( "contents of list are\n ");
while ( temp != NULL )
{
printf ( "%d %u\n",temp->info,&temp->info );
temp = temp->link;
}
printf ( "\n" );
}
NODE getnode ()
{
NODE temp;
temp = (NODE)malloc (sizeof ( struct node ));
if ( temp == NULL )
{
printf ( "out of memory ");
exit ( 0 );
}
return temp;
}
void del( NODE x)
{
NODE t;
if ( x->link == NULL)
printf("cont delete\n");
else
{
t=x->link;
x->info = t->info;
x->link = t->link;
free(t);
}
}
Reversing of list---iterative
NODE rev( NODE first)
{
NODE p,q,r;
p=first;
q=p->link;
p->link = NULL;
while(q!= NULL)
{
r = q->link;
q->link =p;
p = q;
q = r;
}
return p;
}
Sorting of linked list
void sort (NODE first)
{
NODE tmp,cur;
for (tmp = first; tmp->link != NULL; tmp = tmp->link)
for (cur = tmp->link; cur != NULL; cur = cur->link)
{
if (tmp->info > cur->info)
{
int n;
n = cur->info;
cur->info = tmp->info;
tmp->info = n;
}
}
}
atoi( ) using bit operaion
main()
{
char *s= "12349";
int i=0;
while (*s)
{
i = (i<<3)+(i<<1)+(*s>Coverting decimal to binary
main()
{
int x=10;
int i;
for(i=0;i<32;i++)>To change/Swap value
main()
{
int x=3;
int y=2;
printf("before %d %d\n",x,y);
x = x^y;
y = x^y;
x = y^x;
printf("after %d %d",x,y);
}
To check no is power of two or not
main()
{
int n;
printf("enter the number\n");
scanf ("%d",&n);
if( n & n-1)
printf("not power of two");
else
printf("power of two");
}
To count 1s in number
-main()
{
int b;
int x=15;
for(b=0;x!=0; x&=(x-1))
++b;
printf("%d",b);
}
-main()
{
int i,x;
printf("enter the no\n");
scanf("%d",&x);
for(i=0;x!=0;i++)
x=x>>1;
printf("count = %d",i);
}
-main()
{
int b=0;
int x=15;
for ( b=0; x!=0; x >>=1)
{
if ( x & 01 )
b++;
}
printf(" No on ones :%d",b);
}
Bit invert from postion P, N bits inverted
int temp[32];
void bitshow(int);
main()
{
int x=11;
int p=3;
int n=2;
int z;
printf("no is %d\n",x);
bitshow(x);
z = ( x ^ (~(~0 << lsb="0,p,i;" i="0;i<32;i++)" lsb =" x" x =" x">> 1;
}
for(p=31;p>=0;p--)
{
printf("%d",temp[p]);
}
}
Bit rotate right
/* Program To Right Rotate Bits */
#include
#include
void rotate ( unsigned long int,int ); // Rotate Right function
void bitshow ( unsigned long int ); // To display 32 bits
int temp[32]; // To hold Bit values
main()
{
int n=5;
unsigned long int x=15;
system ( "clear" );
rotate ( x, n );
}
void rotate ( unsigned long int x, int n )
{
int s=1; // counter to know no of rotates
long int mask;
int lsb;
mask = 1 << lsb =" x" x =" x">> 1;
if ( lsb )
{
x = mask;
}
printf ( "\n%d Rotate:",s );
bitshow ( x );
s++;
} // while ends
printf("\n");
} //function ends
void bitshow ( unsigned long int x )
{
int p,i;
for( i=0; i<32; x =" x">> 1;
}
for ( p=31; p>=0; p--)
printf ( "%d",temp[p] );
} //function ends
Program to set bits
int temp[32];
void bitshow(int);
main()
{
int x=10;
int p=3;
int n=2;
int y=1;
int z;
z = (x & ~(~(~0 <<>Bit SWAP
void swap(int p3,int p4)
{
int lsb=0,p,i;
for(i=0;i<32;i++) lsb =" x" x =" x">> 1;
}
p=temp[p3];
temp[p3]=temp[p4];
temp[p4]=p;
for(p=31;p>=0;p--)
printf("%d",temp[p]);
}
Program to get bits
main()
{
int x=10; //number
int p=3; // from which position
int n=2; // n numbers right
printf("%d",(x>>(p+1-n) & ~(~0 <<>To set particular bit
#include
void bitshow(int);
main()
{
int n,pos;
int mask=1;
printf("entre the number\n");
scanf("%d",&n);
printf("enter the position u want to set\n");
scanf("%d",&pos);
bitshow(n);
mask = mask <<(pos-1); n= nmask; // to set use OR printf("\nafter setting bit\n"); bitshow(n); } To reset BIT
#include
void bitshow(int);
main()
{
int n,pos;
int mask=1;
printf("entre the number\n");
scanf("%d",&n);
printf("enter the position u want to reset\n");
scanf("%d",&pos);
bitshow(n);
mask = mask <<(pos-1); n= n ^ mask; //to reset use XOR printf("\nafter resetting bit\n"); bitshow(n); } To check bit is on or not main()
{
int n,pos;
int mask=1;
printf("entre the number\n");
scanf("%d",&n);
printf("enter the position u want to check\n");
scanf("%d",&pos);
bitshow(n);
n= n>>(pos-1);
n = n&1;
if (n ==1 )
printf("\n%d bit is on\n",pos);
else
printf("\n%d bit is off\n",pos);
}
Bit complement
main()
{
int x=3;
x=~x;
printf("%d",x);
} // -4
BIT REVERSE
main()
{
int x,i;
printf("enter the number\n");
scanf("%d",&x);
printf("no is %d:",x);
for(i=0;i<32;i++) prefix =" i&1<<31)?1">>i&1)?1:0);
}
Bit operation to find min max number
main()
{
int x=10; // we want to find the minimum of x and y
int y=20;
int min,max; // the result goes here
min = y + ((x - y) & -(x < max =" x" min =" %d" max =" %d">Multiplication of two number using bit operation
#include
main()
{
int i,n,m,temp=0;
printf ( "enter two num\n" );
scanf ( "%d %d ",&n,&m );
for(i=0;i<31;i++) temp =" temp+(m<
main()
{
long int n;
int sum=0,base =1,rem;
printf("enter binary form\n");
scanf("%ld",&n);
while(n!=0)
{
rem = n %2;
sum = sum+rem * base;
base = base *2;
n= n/10;
}
printf("%d",sum);
}
Decimal to binary
#include
main()
{
int n,i=0;
printf("enter number\n");
scanf("%d",&n);
for(i=0;i<32;i++)>Decimal to hexa
#include
main()
{
int n,i=0,rem=0,j;
char hexa[10];
printf("enter number\n");
scanf("%d",&n);
while(n)
{
rem = n %16;
if ( rem < n="n/16;" j="i-1;j">=0;j--)
printf("%c",hexa[j]);
}
Decimal to octal
#include
main()
{
int n,i=0,rem,j;
char s[10];
printf("enter number\n");
scanf("%d",&n);
while(n)
{
rem = n%8;
s[i++]=rem;
n=n/8;
}
s[i]='\0';
for(j=i-1;j>=0;j--)
printf("%d",s[j]);
}
Hexa to decimal
#include
main()
{
char s[]="OX1a";
int i=0,hex;
int base = 1,sum=0;
if (s[i] == '0' s[i]=='O')
i++;
if (s[i]== 'x' s[i]=='X')
i++;
while (s[i] !='\0')
{
i++;
};
--i;
for(;i>=2;i--)
{
if (s[i]>='0'&& s[i]<='9') hex=(s[i]-'0'); if (s[i]>='a' &&s[i]<='f') hex =(s[i]-'a')+10; if (s[i]>='A' &&s[i]<='F') hex =(s[i]-'A')+10; sum += hex*base; base = base *16; } printf("%d",sum); } Octal to decimal
#include
main()
{
long int n;
int sum=0,base =1,rem;
printf("enter octal form\n");
scanf("%ld",&n);
while(n!=0)
{
rem=n%10;
sum = sum+ rem * base;
base = base *8;
n= n/10;
}
printf("%d",sum);
}
FILE RELATED PROGRAMS
To print content of file:
#include
#include
main()
{
FILE *fp;
int c;
fp = fopen("p1.c","r");
while ((c = getc(fp)) != EOF )
{
putchar(c);
}
}
Cut a file upto some position
#include
#include
main()
{
int pos,i=0,count=0,len,c;
FILE *fp;
printf ("enter the position value\n");
scanf ("%d",&pos);
fp = fopen("p1.c","r");
fseek(fp,-2,2);
len = ftell(fp);
fseek(fp,0,0);
if( pos > len )
printf("file size is less.....content of file is\n");
while ( (c = getc(fp)) !=EOF && (count != pos))
{
putchar(c);
count++;
}
printf("\n");
if(pos
#include
#include
#include
char * word;
//int size;
//char* malloc (int);
//char* realloc (char *,int);
main()
{
int fd,fd1,fd2;
int count=0;
char c;
word =(char*) malloc(50);
fd = open ("p1.c",O_RDONLY);
fd1 = open ( "f1.c",O_WRONLY);
fd2 = open ( "f2.c",O_WRONLY);
while ( read (fd,&c,1) == 1 )
{
word[count++]=c;
// if ( count >= size )
// word = realloc(word,(size+20));
if ( c == ' ' c== '\t' c == '\n')
{
if ( count % 2)
write (fd1,word,count);
else
write ( fd2,word,count );
count = 0;
}
}
}
To convert first and last char of each word in file uppercase
#include
#include
main(int argc,char *argv[])
{
FILE *fp;
int c,lastc;
char a[20];
int i=0,x;
lastc = '\t';
fp = fopen("p1.c","r");
while ((c = getc(fp)) != EOF )
{
if( c ==' ' c == '\t')
printf("%c",c);
else
if (( c != ' ' c!= '\t' c!='\n') && (lastc ==' ' lastc == '\t' lastc=='\n'))
{
c= c +'A'-'a';
a[i++]=c;
}
else if (( c == ' ' c== '\t' c=='\n') && (lastc !=' ' lastc != '\t' lastc!='\n'))
{// i--;
lastc=lastc+'A'-'a';
a[i++]=lastc;
}
else
{
a[i++]=c;
}
lastc=c;
}
for(x=0;xLs command implementation…to list all files in directory
#include
#include
#include
#include
int main( int argc,char *argv[])
{
DIR *dp;
struct dirent *drp;
char *name;
name = malloc(30);
if( argc != 2)
printf("error");
getpwd(name);
if ( ( dp = opendir(name) )== NULL )
printf("error in opening dir");
while((drp = readdir(dp)) != NULL)
printf("%s\n",drp->d_name);
closedir(dp);
exit(0);
}
To convert vowel upper
#include
#include
main()
{
FILE *fp;
int c;
fp = fopen("p1.c","r");
while ((c = getc(fp)) != EOF )
{
if(c == 'a' c== 'e' c=='i'c=='o'c=='u')
{
c = c +'A'-'a';
printf("%c",c);
}
else
printf("%c",c);
}
}
Reversing of file contents
#include
#include
main()
{
FILE *fp;
int c;
int x,y;
fp = fopen("p1.c","r");
x= ftell(fp);
printf( "Intial value of fp is %d\n",x);
fseek(fp,-1,2);
y = ftell (fp);
printf ( "length of file is %d",y);
while ( ftell (fp) > x)
{
c = getc(fp);
printf("%c",c);
fseek ( fp,-2,1);
}
c = getc(fp);
printf("%c",c);
}
Reversing of lines in file
#include
main()
{
FILE *fp,*fp1;
int c,i=0,x,j,k,s;
char a[50];
fp = fopen ( "p1.c","r");
fp1 = fopen ("p2.c","w");
while ( (c = getc(fp))!= EOF )
{
a[i++]=c;
}
i--;
for( x = i ; x >= -1 ; x--)
{ int k;
if ( a[x] == '\n' x == -1)
{ int s;
for ( s = (x+1);sReversing of each word in file
#include
#include
main()
{
int c;
FILE *fp;
char a[50];
int i=0,x,j,k;
fp = fopen("p1.c","r");
while ( (c = getc(fp)) !=EOF )
{
a[i++]=c;
}
i--;
for(x=i;x>=-1;x--)
{
int k;
if(a[x]==' ' a[x] == '\t' a[x]== '\n' x == -1)
{ int s;
j=x;
printf(" ");
for(s=(j+1);sIMP PROGRAMS:
TO Remove more that line blank line in input:
#include
#define BLANK 'a'
main()
{
int c,lastc;
lastc = BLANK;
while ( (c=getchar()) != EOF)
{
if ( c!= ' ')
putchar(c);
if ( c == ' ')
if (lastc != ' ')
putchar(c);
lastc = c;
}
}
TO count blanks char tabs etc
#include
main()
{
int c,nl=0,nt=0,nc=0,nb=0;
while((c=getchar())!= EOF)
{
if( c == ' ')
nb++;
else if( c == '\t')
nt++;
else if(c == '\n')
nl++;
else
nc++;
}
printf(" no of char =%d\n",nc);
printf(" no of newlines =%d\n",nl);
printf(" no of tabs =%d\n",nt);
printf(" no of blanks =%d\n",nb);
CHAR count in input
#include
main()
{
int count=0;
while(getchar() != EOF)
++count;
printf("\nchar count is %d",count);
}
String copy fun
void copy ( char to[],char from[])
{
int i;
i=0;
while ((to[i]=from[i]) != '\0')
++i;
}
TO print longest line in input
#include
#define MAXLINE 1000
int getline ( char line[],int max);
void copy( char to[],char from[]);
main()
{
int len,max;
char line[MAXLINE];
char longest[MAXLINE];
max =0;
while ((len = getline(line,MAXLINE)) > 0)
if ( len > max)
{
max = len;
copy ( longest,line );
}
if ( max > 0)
printf("\n %s",longest);
}
int getline( char s[],int lim)
{
int c,i;
for( i=0;i
#include
char word[100];
main()
{
int count=0,c,i;
while((c=getchar())!=EOF)
{
word[count++]=c;
if( c == ' ' c == '\t' c == '\n' )
{
word[--count]='\0';
printf("%s:\t",word);
for(i=0;i
char word[100];
main()
{
int count=0,c,i;
while((c=getchar())!=EOF)
{
word[count++]=c;
if( c == ' ' c == '\t' c == '\n' )
{
word[--count]='\0';
printf("%s:\t",word);
for(i=0;i
#include
main()
{
int c,i,digit[10];
for(i=0;i<10;i++) c="getchar())!="">= '0' && c <= '9') ++digit[c -'0']; } for(i=0;i<10;i++)>ONE word per line
#include
char word[100];
main()
{
int count=0,c,i;
while((c=getchar())!=EOF)
{
word[count++]=c;
if( c == ' ' c == '\t' c == '\n' )
{
word[--count]='\0';
printf("%s\t",word);
printf("length %d\n",count);
count =0;
}
}
}
Reverse string
void reverse(char s[]);
main()
{
char str[]="hello";
reverse(str);
printf("%s",str);
}
void reverse( char s[])
{
int i,j;
char temp;
i=0;
while ( s[i] !='\0')
++i;
--i;
printf(" i value is %d",i);
j=0;
while ( j < temp =" s[j];">Atoi( ) function string to integer
#include
main()
{
int n;
char str[10]="12345";
n = atoi(str);
printf ( "%d",n);
}
int atoi ( char str[])
{
int n = 0 ,i;
for(i = 0; str[i] >= '0' && str [i] <= '9';i++) n = 10 * n +(str[i]-'0'); return n; } TO check leap year
main()
{
int year;
printf("enter the year you want to test\n");
scanf("%d",&year);
if(( year%4 == 0 && year %100 != 0 ) year %400 == 0)
printf("entered year is leap year\n");
else
printf("not leap year\n");
}
To convert lower to upper in file#include
main()
{
FILE *fp;
int c;
fp = fopen ( "abc.c","r+");
while ( (c = fgetc(fp)) != EOF)
{
if ( c >= 'a' && c <= 'z') { c = c+'A'-'a'; printf("%c",c); } else printf("%c",c); } } Shothand notation
main()
{
int x=2,y=3,z;
x *= y+1;
printf("%d",x);
}
// answer is 8
x *= y+1
x = (x)*(y+1)
x = 2 *(3+1)
x = 8
its not equal to x= x*y+1;
SQueez character
main()
{
char s[]="hello";
char c = 'l';
void sq( char s[],char c);
sq(s,c);
}
void sq(char s[],char c)
{
int i,j;
for(i=j=0;s[i]!='\0';i++)
{
if ( s[i] != c)
s[j++]=s[i];
}
s[j]='\0';
printf("%s",s);
}
Squeeze string
main()
{
char s1[]="hello";
char s2[]="ol";
int i,j,k;
for(i=k=0;s1[i]!='\0';i++)
{
for(j=0;(s2[j]!= '\0'&&s2[j]!= s1[i]);j++)
;
if ( s2[j]=='\0')
s1[k++]=s1[i];
}
s1[k]='\0';
printf("%s",s1);
}
// first h is compared with ol condition true when j becomes \0 condition fails
// h is moved to s1[k].... similarly for others
Strcat function
main()
{
char s[]="hello";
char t[]="world";
int i=0,j=0;
while ( s[i] !='\0')
i++;
while ( (s[i++]=t[j++]) != '\0');
s[i]='\0';
printf("%s",s);
}
Atof ( )
main()
{
char s[]=" 1.2234";
int i,sign;
float x,n,pow;
for(i=0;(s[i] == ' ');i++)
;
sign = (s[i] == '-') ? -1 : 1;
if ( s[i]=='+' s[i]=='-')
i++;
for( n = 0.0 ;(s[i] >='0' && s[i] <= '9');i++) n = 10.0 * n + (s[i]-'0'); if( s[i] == '.') i++; for(pow = 1.0;(s[i] >= '0' && s[i] <= '9');i++) { n = 10.0 * n + (s[i]-'0'); pow = pow * 10.0; } x = ((n*sign)/pow); printf("%5.4f",x); }
Atof () exponent string to float
main()
{
char s[]="1.2e+2";
int i,sign,expo;
float x,n,pow;
for(i=0;(s[i] == ' ');i++)
;
sign = (s[i] == '-') ? -1 : 1;
if ( s[i]=='+' s[i]=='-')
i++;
for( n = 0.0 ;(s[i] >='0' && s[i] <= '9');i++) n = 10.0 * n + (s[i]-'0'); if( s[i] == '.') i++; for(pow = 1.0;(s[i] >= '0' && s[i] <= '9');i++) { n = 10.0 * n + (s[i]-'0'); pow = pow * 10.0; } n = ((n*sign)/pow); if( s[i]== 'e' s[i] == 'E') { i++; sign = (s[i]=='-')?-1:1; if (s[i]=='+'s[i]=='-') i++; for( expo = 0; (s[i] >= '0' && s[i] <= '9');i++) expo = expo * 10 + (s[i] - '0'); if ( sign == 1) while ( expo-- > 0 )
n = n *10;
else
while (expo-- > 0)
n = n/10;
}
printf("%f",n);
}
Atoi () new…
main()
{
char s[]=" - 1234";
int i,n,sign;
for(i=0;(s[i] == ' ');i++)
;
sign = (s[i] == '-') ? -1 : 1;
if ( s[i]=='+' s[i]=='-')
i++;
for( n = 0 ;(s[i] >='0' && s[i] <= '9');i++) n = 10 * n + (s[i]-'0'); printf("%d",(n*sign)); } Concatenation files content in standard output
#include
#include
void filecopy(int,int);
#define SIZE 20
main( int argc,char *argv[])
{
int fd;
if(argc == 1)
{
printf("no command line arg,copy stdin to stdout\n");
filecopy(0,1);
}
else
{
while(--argc > 0)
{
fd = open(*++argv,O_RDONLY);
filecopy(fd,1);
}
}
close(fd);
}
void filecopy( int ifd,int ofd)
{
int n;
char buf[SIZE];
while( (n = read(ifd,buf,SIZE)) > 0)
if(write(ofd,buf,n)!= n)
printf("write error");
}
Compare files
#include
#include
#include
main( int argc, char *argv[])
{
FILE *fp1,*fp2;
void filecomp(FILE *fp1,FILE *fp2);
if ( argc != 3 )
{
fprintf ( stderr, "error in input" );
exit(1);
}
else
{
fp1 = fopen ( *++argv,"r" );
fp2 = fopen ( *++argv,"r" );
}
filecomp ( fp1,fp2 );
fclose ( fp1 );
fclose ( fp2 );
}
void filecomp ( FILE *fp1, FILE *fp2 )
{
char *p1,*p2;
char line1[80],line2[80];
do
{
p1 = fgets ( line1,10,fp1 );
p2 = fgets ( line2,10,fp2 );
if ( p1 == line1 && p2 == line2 )
{
if ( strcmp ( line1,line2 ) != 0 )
{
printf("difference in line %s",line1 );
p1 = p2 = NULL;
}
}
else if ( p1 !=line1 && p2 == line2 )
printf("end of first line");
else if ( p1 == line1 && p2 != line2)
printf( " end of second line ");
}
while ( p1 == line1 && p2 == line2 );
}
Expand a-z
main()
{
char s1[]="m-z";
char s2[30];
char c;
int i=0,j=0;
while((c=s1[i++]) !='\0')
{
if ( s1[i] == '-'&& s1[i+1] >= c)
{
i++;
while( c <>itoa ( ) integer to sting
void reverse(char s[]);
main()
{
int n = -123,i=0;
char s[4];
int sign;
if ((sign= n)<0) n =" -n">0);
if ( sign < i="0,j="(strlen(s)-1);i
#include
main()
{
int tab = 0,c,d;
printf("enter how many space you want to replace with tab\n");
scanf("%d",&tab);
while ((c=getchar()) !=EOF)
{
if ( c == '\\')
if (( d = getchar()) == 't')
while(tab-- > 0 )
putchar(' ');
else
{
putchar(c);
putchar(d);
}
else
putchar(c);
}
}
Replace tab by \t and newline by \n
#include
// to replace tab by \t and newline by \n
main()
{
int c,i=0,j;
char t[300],s[300];
while((c=getchar())!=EOF)
t[i++]=c;
for( i=0,j=0;t[i] !='\0';i++) // from t to s
{
switch(t[i])
{
case '\n' : s[j++]='\\';
s[j++]='n';
s[j++]=' ';
break;
case '\t' : s[j++]='\\';
s[j++]='t';
s[j++]=' ';
break;
default: s[j++]=t[i];
break;
}
s[j]='\0';
}
printf("%s",s);
}
Strcmp() implementation
int strcmp1(char *,char *);
main()
{int i=0;
char s[6]="hello";
char t[6]="hello";
i = strcmp1(s,t);
if( i ==0)
{
printf("strings are equal");
}
else if ( i > 0)
printf("first string is greater than secone\n");
else
printf("first string is smaller than second string");
}
int strcmp1(char s[],char t[])
{
int i;
for(i=0;s[i]==t[i];i++)
{
if(s[i]=='\0')
break;
}
return ( s[i]-t[i]);
}
Strcpy() implementation
main()
{
char *s ="hello";
char *t;
t = malloc(20);
while( (*t++ = *s++) !='\0')
;
printf("%s",t);
}
Strncat()implementation
void ncat(char *,char *,int);
main()
{
char s[20]="hello";
char t[]="priya";
int n=6;
ncat(s,t,n);
printf("%s",s);
}
void ncat(char *s,char *t,int n)
{
int i;
while(*s)
s++;
for(i=0;i< s="'\0';">Strncpy() implementation
void ncopy(char *,char *,int);
main()
{
char s[]="hello";
char t[5];
int n=7;
ncopy(s,t,n);
printf("%s",t);
}
void ncopy(char *s,char *t,int n)
{
while ( *s && n-- > 0)
*t++ = *s++;
while( n-- >=0)
*t++='\0';
}
To replace tab by \t
#include
main()
{
int c;
while((c=getchar())!= EOF)
{
if( c == '\t')
printf("\\t");
else if ( c == ' ')
printf("\\b");
if( c!='\t')
putchar(c);
}
}
To check no is prime or not
#include
main()
{
int n,res;
printf("enter the no to check\n");
scanf("%d",&n);
res=isPrime(n);
if ( res == 1)
printf("it is prime number\n");
else
printf("it is not prime number\n");
}
int isPrime(int n)
{
int i;
if (n<1) n="="2)" 2="="0)" i =" 2;" i ="="">Prime generation
#include
main()
{
int n,res,i;
printf("enter the limit\n");
scanf("%d",&n);
for( i=0;i
OUT: make1.o make2.o
cc -o OUT make1.o make2.o
clean: @rm *.o
decimal to binary for any number from 1 to 9999
#include
main()
{
int i,n;
static int x;
for(;;)
{
printf("\nEnter the number\n");
scanf("%d",&n);
if ( n==9999)
return;
else
{
for(i=0;i<32;i++)> To count number of times substring present in string
#include
main()
{
int count=0;
char *src="djahellohellosjdzchellofhkjsahellojf";
char *match="hello";
char *t1,*t2;
while(*src)
{
t1=src;
t2=match;
while((*t1++==*t2++)&&*t1!='\0'&&*t2!='\0');
if(*t2=='\0')
count++;
src++;
}
if(count==0)
printf("substring not present");
else
printf("substring present in %d number of times\n",count);
}
To display like for number 3
a b c b a
a b a
a
#include
main()
{
int i,j,k=0,n;
char ch='a';
scanf("%d",&n);
while(n!=0)
{
for(i=0;i
}
}
To display number is even or odd without loop or test
#include
main()
{
int a=255;
char *A[]={"evn","odd"};
printf("%s",A[a%2]);
}
fork( )
main()
{
fork();
fork();
fork();
fork();
fork();
printf("Welcome to Orkut...\n");
fork();
}
// 2 ^5 (2 power 5 times it will come)
To check little endian or big endian
#include
main()
{
int x=1;
if(*(char*)&x ==1)
printf("little");
else
printf("big");
}
#include
main()
{
union un
{
int x;
char ar[sizeof(int)];
}ob;
ob.x=1;
if(ob.ar[0]==1)
Printf("little");
else
printf("big");
}
To display in n=4
a b c d c b a
a b c * c b a
a b * * * b a
a * * * * * a
main()
{
int i,j,k=0,n;
char ch='a';
printf("enter the number\n");
scanf("%d",&n);
int z=n;
int x=1,y;
while(n!=0)
{
y=x;
for(i=0;i
x=x+2;
}
}
Program without main
#define str(s) #s
#define swap(y,x) x##y
int swap(in,ma)()
{
if (printf(str("Friends"))){}
return(0);
}
Random number generation
#include
#include
#include
main()
{
int i;
srand(time(NULL));
for( i=0; i<10;>To print without semicolon
~ #include
main()
{
if(printf("sanmaya"))
;
}
To find size of variable without using sizeof operator
~ #include
main()
{
char var;
int size;
size = (char*)(&var+1)-(char*)(&var);
printf("%d",size);
}
Ptr problem
#include
int main()
{
char *s1;
char *s2;
s1="vinay";
s2="vinay";
printf("%p\t%p",s1,s2);
if(s1==s2)
printf("yes");
else
printf("No");
return;
}
//in same scope address of vinay is same
// two string literals in same scope shares same memory
TO count no of char
~ #include
int main()
{
int i;
char *str="AAAABCCCDD";
char *p=str+1,c,*st,w[3];
st=(char *)malloc(strlen(str));
while(c=*(--p))
{
int j=0;
while(c==*p++)
j++;
j==1?sprintf(w,"%c",c):sprintf(w,"%d%c",j,c);
strcat (st, w);
}
puts(st);
return 0;
}
Strstr()
#include
#include
main()
{
int count=0;
char *p="djahellosjdzchelfhkjsahellojf";
char *q="hello",*r;
while(1)
{
r = strstr(p,q);
if( r!= NULL)
{
count++;
p=r+strlen(q);
}
else
break;
}
if(count==0)
printf("substring not present");
else
printf("substring present in %d number of times\n",count);
}
Swap word
#include
#include
int main(void)
{
char a[6], b[6];
int j, len_a, len_b, len;
strcpy(a, "hello");
strcpy(b, "hipriya");
printf("Before: a = %s, b = %s\n", a, b);
/ get the max length of the two strings
Len_a = strlen(a);
len_b = strlen(b);
len = len_a > len_b ? len_a : len_b;
19 // for each character in the longer of the two strings, including the terminating '\0'
for (j = 0; j <= len; ++j) { // swap two characters char c = a[j]; a[j] = b[j]; b[j] = c; } printf("After: a = %s, b = %s\n", a, b); return 0; } TO print Armstrong numbers
0 1 153
1^3+5 ^3 +3 ^3 = 153
~ #include
main()
{
int i,x,sum=0,rem;
for(i=0;i<500;i++) x="i;" rem =" x%10;" sum =" sum" x="x/10;" i="="sum" sum="0;">TO remove array duplicate elements
~ void sort( int *a,int n)
{
int i=0,j,m;
for(i=0;i
#include
#include
main()
{
int x=10;
assert(x==1);
printf("hi");
}
a.out: assert.c:7: main: Assertion `x==1' failed.
Aborted
Compiler directive
#include
#if something ==0 //if we assign other than zero it will give error..t showa something s defined but t is not defined by using #define so error
int some =0;
#endif
main()
{
printf("%d",some);
}
---------0
TO delete file after execution automatically
#include
main()
{
unlink(argv[0]); //deletes a.out(executable)
unlink(__FILE__); //deletes source code
}
printf("%d\n",__LINE__); //line number
printf("%s\n",__FILE__); //file name
printf("%s\n",__DATE__); //date
printf("%s\n",__TIME__); // current time
Const example
const x;
x=10;
printf("%d",x);
In c its okay in c++ it s error
Enumeratons
enum { a,b,c,d,e,r,t,y,u,p}op;
printf("%d",sizeof(op)); // 4 bytes always in UNIX t does not depends on number of constants
gcd iteration
main()
{
int m=200,n=20;
int r= gcd(m,n);
printf("%d",r);
}
int gcd(int m,int n)
{
while(m !=n)
{
if (m>n)
m=m-n;
else
n=n-m;
}
return(m);
}
HASH FUNCTION
#include
int list[30],indexpos[30],indexsize,tabsize;
int create_hashtable(int,int);
int search_hash(int,int);
main()
{
int i,n,item;
system("clear");
printf("enter the size of original table\n");
scanf("%d",&n);
printf("entre the elements\n");
for(i=0;i
#define MAX(a,b) (a>b?a:b)
main()
{
int i=40,j=30,k=15;
int res;
res=MAX(i,MAX(j,k));
printf("%d",res);
}
To find little and big endian
#include
main()
{ int x=1;
if(*(char*)&x == 1)
printf ("little");
else
printf ("big");
}
union x
{
int x;
char a[sizeof(int)];
};
main()
{
union x ob;
ob.x=1;
if( ob.a[0]==1)
printf("little");
else
printf("big");
}
Little endian to big endan
void bitshow(int n);
main()
{unsigned long int x=1111;
printf("number is %d:",x);
bitshow(x);
printf("\n");
x= ( ((x & 0X000000FF ) <<>> 8 )+
((x & 0XFF000000 ) >> 24 ));
printf("big endian representation:");
bitshow(x);
}
To print own code
#include
int main ()
{
int c;
FILE *f = fopen (__FILE__, "r");
if (!f) return 1;
for (c=fgetc(f); c!=EOF;c=fgetc(f))
putchar (c);
fclose (f);
return 0;
}
TO print triangle
# include
int main ()
{
int k, j = 0, i, n, s, ll;
printf (" Enter The NUmber \n");
scanf ("%d", &n);
s = n;
while (j < k =" 0;" i =" 0;">Replacing “the” with “those” n file
#include
char str[]="the";
char str1[]="those";
char word[50];
main()
{
int c,count=0;
while((c = getchar()) != EOF)
{
word[count++]=c;
if (c== ' 'c == '\t' c== '\n')
{
word[--count]='\0';
if (! strcmp(word,str))
{
printf(" ");
printf("%s",str1);
}
else
{
printf(" ");
printf("%s",word);
}
count = 0;
}//end of if
}//end of while
}//end of main
Printing special number
25 36 125 216
5 ^2 =25
6 ^2= 36
5 ^3=125
#nclude
#include
main()
{
int i,x,remi,count=0;
int rem1,res;
for(i=10;i<1000;i++) x="i;" x="x/10;" rem1="i%10;" res =" pow(rem1,count);" res ="="" count ="0;">To display triangle (inside holo)
*
* *
* *
* *
* * * * *
#include
main()
{
int n,i,j,x;
static int m=1,p;
system("clear");
printf("entre the number\n");
scanf("%d",&n);
for(i=1;i<=n;i++) { for(j=i+1;j<=n;j++) { printf(" "); } x =i; if ( x==1) printf("*"); else if ( x
include
int
main ()
{
int m[3][3], r = 0, c = 1; //if [7][7] c=3
int k = 1;
while (k <= 9) { m[r][c] = k; if (k % 3 == 0) r = r + 1; else { r = r - 1; c = c + 1; } if (c < c =" 2;"> 2)
c = 0;
if (r < r =" 2;"> 2)
r = 0;
k++;
}
for (r = 0; r <= 2; r++) { printf("\n"); for (c = 0; c <=2 ; c++) printf ("%4d\t", m[r][c]); } } 8 1 6 sum is 15 both vertically and horzontaly 3 5 7 4 9 2 String tokenizer
#include
#include
int main()
{
char hold[6][8];
int i=0,j=0,k=0;
// printf("enter the string\n");
// scanf("%s",array);
char array[]= "hello+world+to+hdfhj+fsdfh";
while(array[i] != '\0')
{
if ( array[i]== '+')
{
i++;
hold[k][j]='\0';
j=0;
k++;
}
hold[k][j++]=array[i];
i++;
}
for(i=0;i <=k;i++) { printf("\n%s",hold[i]); } } To print 1 to 100 and 100 to 1 without using loop
#include
#include
void
prin_down ( int i, int min )
{
if ( i % 8 == 0 )
puts ( "" );
printf ( "%-3d\t", i );
if ( i > min )
prin_down( --i, min );
return;
}
void
prin_up ( int i, int max )
{
if ( i % 8 == 0 )
puts ( "" );
printf ( "%-3d\t", i );
if ( i <>Structure comparison
Write a program to compare two objects of a structure.
Ans
#include
#include
#include
int
main ( void )
{
struct A {
int _1; /* sizeof ( int ) == 4 */
int _2;
float _3; /* sizeof ( float ) == 4 */
char _4; /* sizeof ( char ) is always == 1 */
}a, b;
/* initialize a and b */
...
if ( memcmp ( &a, &b, sizeof a ) == 0 )
puts ( "The two structures are equal" );
else
puts ( "The structures are unequal" );
return EXIT_SUCCESS;
}
This program is very general, and might invoke undefined
behaviour. To make a structure object properly aligned,
the compiler inserts padding bytes whenever (or wherever)
necessary. The Standard does not specify what value these
padded bytes should take. In this example, the objects,
a and b, looks like this:
4 bytes 4 bytes 4 bytes 4 bytes (enlarged)
______ ______ ______ ____ ____ ____ ____
_1 _2 _3 _4 P P P
------ ------ ------ ---- ---- ---- ----
Byte # 0 4 8 12 13 14 15
P is a padding byte in the above illustration, whose value
is undefined. Some compilers may initialize such bytes to
zero, or some may leave it untouched. And, memcmp() compares
padding bytes also, even though these bytes have no meaning!
A more portable and dependable solution is to compare structure
members-by-member, i.e.,
if ( a._1 == b._1 &&
a._2 == b._2 &&
a._3 == b._3 &&
a._4 == b._4 )
puts ( "The two structures are equal" );
else
puts ( "The structures are unequal" );
MAX of 4 integers
#include
#include
#define max2( x, y ) (x) > (y) ? (x) : (y)
#define max4(a, b, c, d) max2 ( max2 ( (a), (b) ), max2 ( (c), (d) ) )
int
main ( void )
{
printf ( "Max: %d\n", max4 ( 10, 20, 30, 40 ) );
printf ( "Max: %d\n", max4 ( 10, 0, 3, 4 ) );
return EXIT_SUCCESS;
}
Combination of all strings
#include
#include
#include
void
string_combi ( char * s, int len )
{
int i;
char tmp;
static int j;
static char *p;
if ( !p )
p = s;
for ( i = 1; i <= len; i++ ) { if ( len > 2 )
string_combi ( s+1, len-1 );
else
{
j++;
printf ( "%d: %s\t", j, p );
if ( !( j%10 ) )
puts ( "" );
}
if ( i < tmp =" s[len-i];">GCD recursion
main()
{
int m=200,n=2;
int x= gcd(m,n);
printf("%d",x);
}
int gcd(int m,int n)
{
if (m==n)
return m;
if ( m==0) return n;
if(n==0)return m;
if(m
Tree:
#include
#include
struct tree
{
struct tree *left;
int data;
struct tree *right;
};
int inorder (struct tree *sr);
int insert (struct tree **sr, int num);
void Mirror( struct tree *s);
main ()
{
struct tree *bt;
int num, req, d, i = 1;
bt = NULL;
printf ("no. of node");
scanf ("%d", &req);
while (i <= req) { printf ("enter data:"); scanf ("%d", &num); insert (&bt, num); i++; } inorder (bt); } int insert (struct tree **sr, int num) { if ((*sr) == NULL) { (*sr) = (struct tree *) malloc (sizeof (struct tree)); (*sr)->left = NULL;
(*sr)->data = num;
(*sr)->right = NULL;
return;
}
else
{
if (num < (*sr)->data)
insert (&(*sr)->left, num);
else
insert (&(*sr)->right, num);
}
return;
}
int inorder(struct tree *sr)
{
if ((sr) != NULL)
{
inorder ((sr)->left);
printf ("%d\n", (sr)->data);
inorder ((sr)->right);
}
return;
}
void Mirror( struct tree *s) // print n preorder
{
struct tree *t;
if( s == NULL)
return;
else
{
Mirror( s->left);
Mirror(s->rght);
t= s->left;
s->left = s->right;
s->right= t;
}
}
Tree copy
#include
#include
struct btnode
{
struct btnode *left;
int data;
struct btnode *right;
};
int insert (struct btnode **sr, int num);
int preorder (struct btnode *sr);
int copy (struct btnode **src, struct btnode **tgt);
int
main ()
{
struct btnode *bt1, *bt2;
int num, req, d, i = 1;
bt1 = NULL;
printf ("no. of node");
scanf ("%d", &req);
while (i <= req) { printf ("enter data:"); scanf ("%d", &num); insert (&bt1, num); i++; } copy (&bt1, &bt2); printf ("\n original tree\n preorder traversal:"); preorder (bt1); printf ("\n\n\n copied tree\npreorder traversal:"); preorder (bt2); } int copy (struct btnode **src, struct btnode **tgt) { if (*src != NULL) { *tgt = (struct btnode *) malloc (sizeof (struct btnode)); (*tgt)->left = NULL;
(*tgt)->data = (*src)->data;
(*tgt)->right = NULL;
copy (&((*src)->left), &((*tgt)->left));
copy (&((*src)->right), &((*tgt)->right));
}
return;
}
int
insert (struct btnode **sr, int num)
{
if (*sr == NULL)
{
(*sr) = (struct btnode *) malloc (sizeof (struct btnode));
(*sr)->left = NULL;
(*sr)->data = num;
(*sr)->right = NULL;
return;
}
else
{
if (num < (*sr)->data)
insert (&((*sr)->left), num);
else
insert (&((*sr)->right), num);
}
return;
}
int
preorder (struct btnode *sr)
{
if (sr != NULL)
{
printf ("%d", sr->data);
preorder (sr->left);
preorder (sr->right);
}
return;
}
Tree compare
#include
#include
struct btnode
{
struct btnode *left;
int data;
struct btnode *right;
};
int insert (struct btnode **sr, int num);
int compare(struct btnode *sr1, struct btnode *sr2);
int flag = 1;
int
main ()
{
struct btnode *bt1, *bt2;
int num, req, d, i = 1;
bt1 = NULL;
bt2 = NULL;
printf ("no. of node for first tree");
scanf ("%d", &req);
while (i <= req) { printf ("enter data:"); scanf ("%d", &num); insert (&bt1, num); i++; } i = 1; printf (" no. of nodes for second tree "); scanf ("%d", &req); while (i <= req) { printf ("enter data:"); scanf ("%d", &num); insert (&bt2, num); i++; } compare (bt1, bt2); if (flag == 1) printf ("\n trees are Identical"); else printf ("\n trees are not Identical"); } int insert (struct btnode **sr, int num) { if (*sr == NULL) { (*sr) = (struct btnode *) malloc (sizeof (struct btnode)); (*sr)->left = NULL;
(*sr)->data = num;
(*sr)->right = NULL;
return;
}
else
{
if (num < (*sr)->data)
insert (&((*sr)->left), num);
else
insert (&((*sr)->right), num);
}
return;
}
int
compare (struct btnode *sr1, struct btnode *sr2)
{
int l, r;
l = (sr1 == NULL ? 1 : 0);
r = (sr2 == NULL ? 1 : 0);
if (l != r)
flag = 0;
if (sr1 != NULL && sr2 != NULL)
{
if (sr1->data != sr2->data)
flag = 0;
compare (sr1->left, sr2->left);
compare (sr1->right, sr2->right);
}
return;
}
To delete particular node in list……………..You have been given a pointer to an arbitrary node in a linked list,which you should delete without corrupting the list. The head of thelist in not given. ptr _____ _____ _____ _____ _____ 1 --> 3 --> 5 --> 7 --> 9 --- ----- ----- ----- ----- ----- ---- -- Solution: void del_node ( node_t *ptr ) { if ( ptr && ptr -> next ) { node_t *arb = ptr -> next; ptr -> data = ptr -> next -> data; ptr -> next = ptr -> next -> next; free ( arb ); } else if ( ptr && ptr -> next == NULL ) //when it is last node { free ( ptr ); ptr = NULL; } return; }
Reversing of linked list…………….
Question:
You have to reverse a linked list, but the condition is that data X which
resides in the node N should not change. For example,
Addr: 100 200 300 400 500
_____ _____ _____ _____ _____
1 --> 3 --> 5 --> 7 --> 9 ---
----- ----- ----- ----- -----
----
--
should become
Addr: 100 200 300 400 500
_____ _____ _____ _____ _____
1 <-- 3 <-- 5 <-- 7 <-- 9 ----- ----- ----- ----- ----- ---- -- Answer: Generally, we give the solution as follows: Addr: 100 200 300 400 500 _____ _____ _____ _____ _____ 9 --> 7 --> 5 --> 3 --> 1 ---
----- ----- ----- ----- -----
----
--
We write a function reverse () which takes two arguments: one a pointer
to the head, and the other, pointer to second node of the list.
void
reverse ( node_t *hd, node_t *nxt )
{
if ( nxt && nxt -> next )
revesre ( nxt, nxt -> next );
nxt -> next = hd;
hd -> next = NULL;
}
Circular linked list…………..
#include
#include
struct node
{
int info;
struct node *link;
};
typedef struct node * NODE;
NODE insert_front(int,NODE);
NODE insert_rear(int,NODE);
NODE delete_front(NODE);
NODE delete_rear(NODE);
NODE getnode();
void freenode(NODE);
void display(NODE);
main()
{ NODE last;
last = NULL;
int choice,item;
system ("clear");
do
{
printf ( "1.INSERT FRONT\n" );
printf ( "2.INSERT REAR\n" );
printf ( "3.DELETE FRONT\n" );
printf ( "4.DELETE REAR\n" );
printf ( "5.DISPLAY\n" );
printf ( "6.EXIT\n" );
printf ("Enter The Choice\n" );
scanf ( "%d", &choice );
switch ( choice )
{
case 1: printf ( "Enter the element to b inserted\n " );
scanf ( "%d", &item );
last = insert_front ( item,last );
break;
case 2: printf ( "Enter the element to b inserted\n " );
scanf ( "%d", &item );
last = insert_rear(item,last);
break;
case 3: last= delete_front(last );
break;
case 4: last = delete_rear(last);
break;
case 5: display(last);
break;
case 6: exit ( 0 );
break;
}
}while ( choice <= 6); } NODE insert_front ( int item, NODE last ) { NODE temp; temp = getnode( ); temp->info = item;
if ( last == NULL)
last = temp;
else
temp->link = last->link;
last->link= temp;
return last;
}
NODE insert_rear ( int item, NODE last )
{
NODE temp;
temp = getnode();
temp->info = item;
if ( last == NULL)
{
last = temp;
last->link = last;
}
else
{
temp->link = last->link;
last->link = temp;
}
return temp; // now temp is last node
}
void display ( NODE last )
{
NODE temp,first;
temp = last;
if ( last == NULL )
{
printf ( "list is empty" );
return;
}
printf ( "\n" );
printf ( "contents of list are\n ");
first= last;
for(temp=last->link;temp!=last;temp= temp->link)
{
printf ( "%d\t",temp->info );
}
printf("%d\n",temp->info); //TO PRINT LAST NODE
}
NODE getnode ()
{
NODE temp;
temp = (NODE)malloc (sizeof ( struct node ));
if ( temp == NULL )
{
printf ( "out of memory ");
exit ( 0 );
}
return temp;
}
NODE delete_front(NODE last)
{
NODE first,temp;
if ( last == NULL)
{
printf("list is empty\n");
return;
}
if ( last->link == last)
{
printf("%d deleted",last->info);
freenode(last);
last = NULL;
return last;
}
first = last->link;
temp = first->link;
printf("%d deleted\n",first->info);
freenode(first);
last->link = temp;
return last;
}
NODE delete_rear(NODE last)
{
NODE prev;
if ( last == NULL)
{
printf("list is empty\n");
return;
}
if ( last->link == last)
{
printf("%d deleted",last->info);
freenode(last);
return NULL;
}
prev = last->link; // to find prev of last node
while( prev->link != last)
{
prev = prev->link;
}
prev->link = last->link;
printf("%d deleted",last->info);
freenode(last);
return prev;
}
void freenode(NODE last)
{
free(last);
}
Double linked list……………….
// implementation of doubly linked list
#include
#include
// structure for doubly linked list
struct node
{
int info;
struct node *rlink;
struct node *llink;
};
typedef struct node *NODE;
//functions used
NODE getnode ( );
NODE insert_front ( int, NODE );
NODE insert_rear ( int, NODE );
NODE delete_front ( NODE );
NODE delete_rear ( NODE );
void display ( NODE );
void freenode ( NODE) ;
// main starts
main()
{
NODE head;
int item,choice;
system ( "clear" );
head = getnode ( );
head->rlink = head;
for ( ;; )
{
printf ( "1.INSERT FRONT\n" );
printf ( "2.INSERT REAR\n" );
printf ( "3.DELETE FRONT\n" );
printf ( "4.DELETE REAR\n" );
printf ( "5.DISPLAY\n" );
printf ( "6.EXIT\n" );
scanf ( "%d",&choice );
switch ( choice )
{
case 1: printf ( "enter the item to be inserted\n" );
scanf ( "%d",&item );
head = insert_front ( item, head );
break;
case 2: printf ( "enter the item to be inserted\n" );
scanf ( "%d",&item );
head = insert_rear ( item, head );
break;
case 3: head = delete_front ( head );
break;
case 4: head = delete_rear ( head );
break;
case 5: display ( head );
break;
case 6: exit ( 0 );
break;
default: exit ( 0 );
}// switch ends
} // for ends
}// main ends
//functions definitions
NODE insert_front ( int item, NODE head )
{
NODE temp,cur;
// node to be inserted
temp = getnode ( );
temp->info = item;
// node is inserted between head and first node
// head new first
cur = head->rlink;
head->rlink = temp;
temp->llink = head;
temp->rlink = cur;
cur->llink = temp;
return head;
}
NODE insert_rear ( int item, NODE head )
{
NODE temp,cur;
// node to be inserted
temp = getnode ( );
temp->info = item;
// node is inserted between head and first node
cur = head->llink;
head->llink = temp;
temp->rlink = head;
temp->llink = cur;
cur->rlink = temp;
return head;
}
NODE delete_front ( NODE head )
{
NODE cur ,next;
if ( head->rlink == head )
{
printf ( "list is empty\n" );
return head;
}
cur = head->rlink; // first node in list
next = cur->rlink; // second node in list in known
head->rlink = next;
next->llink = head;
printf ( "Deleted item is %d\n",cur->info );
freenode ( cur );
return head;
}
NODE delete_rear ( NODE head )
{
NODE cur, prev;
if ( head->rlink == head )
{
printf ( "list is empty\n" );
return head;
}
cur = head->llink; // last node
prev = cur->llink;
head->llink = prev;
prev->rlink = head;
printf ( "Deleted item is %d\n", cur->info);
freenode ( cur );
return head;
}
void display ( NODE head )
{
NODE temp;
if ( head->rlink == head )
{
printf ( "list is empty" );
exit ( 0 );
}
printf ( " content of list are\n" );
for ( temp = head->rlink; temp != head ; temp = temp->rlink )
printf ( "%d\t",temp->info );
printf ( "\n" );
}
NODE getnode ( )
{
NODE x;
x = ( NODE ) malloc ( sizeof( struct node) );
return x;
}
void freenode ( NODE x )
{
free ( x );
}
Linked list………………….
#include
#include
struct node
{
int info;
struct node *link;
};
typedef struct node * NODE;
main()
{
NODE first;
first = NULL;
int choice,item;
system ("clear");
do
{
printf ( "1.INSERT\n" );
printf ( "2.DISPLAY\n" );
printf ( "3.EXIT\n" );
printf ("Enter The Choice\n" );
scanf ( "%d", &choice );
switch ( choice )
{
case 1: printf ( "Enter the element to b inserted\n " );
scanf ( "%d", &item );
first = insert ( item,first );
break;
case 2: display ( first );
break;
case 3: exit ( 0 );
break;
}
}while ( choice <= 3); } NODE insert ( int item, NODE first ) { NODE temp; temp = getnode( ); temp->info = item;
temp->link = first;
return temp;
}
void display ( NODE first )
{
NODE temp;
temp = first;
if ( first == NULL )
{
printf ( "list is empty" );
return;
}
printf ( "\n" );
printf ( "contents of list are\n ");
while ( temp != NULL )
{
printf ( "%d\t",temp->info );
temp = temp->link;
}
printf ( "\n" );
}
NODE getnode ()
{
NODE temp;
temp = (NODE)malloc (sizeof ( struct node ));
if ( temp == NULL )
{
printf ( "out of memory ");
exit ( 0 );
}
return temp;
} Important prog in linked list……………
// to find middle node in list
NODE middle_node(NODE first)
{
NODE temp,cur;
temp=first;
cur = first;
while(temp != NULL)
{
temp= temp->link;
if( temp != NULL)
{
temp=temp->link;
cur = cur->link;
}
else
{
break;
}
}
printf("middle node = %d", cur->info);
return first;
}
// insert front in list
NODE insert_front(NODE first,int n)
{
NODE temp;
temp = getnode();
temp->info=n;
temp->link =first;
return temp;
}
// delete front from list
NODE delete_front(NODE first)
{
NODE temp;
temp = first;
first = first->link;
printf("deleted item id %d",temp->info);
freenode(temp);
return first;
}
// display list
void display(NODE first)
{
NODE temp;
if(first == NULL)
printf("empty list\n");
for(temp=first;temp!=NULL;temp=temp->link)
printf("%d\t",temp->info);
printf("\n");
}
// to get node
NODE getnode()
{
NODE temp;
temp =(NODE) malloc(sizeof(struct node));
if( temp== NULL)
printf("no memory\n");
return temp;
}
// insert rear
NODE insert_rear(NODE first,int n)
{
NODE temp,cur;
temp = getnode();
temp->info=n;
temp->link = NULL;
if( first == NULL)
return temp;
cur = first;
while(cur->link !=NULL)
{
cur = cur->link;
}
cur->link = temp;
return first;
}
// delete rear
NODE delete_rear(NODE first)
{
NODE prev,cur;
if ( first == NULL)
{
printf("list is empty\n");
return first;
}
if( first->link == NULL)
{
printf("deleted node is %d\n",first->info);
freenode(first);
first = NULL;
return first;
}
cur = first;
prev = NULL;
while( cur->link != NULL)
{
prev = cur;
cur = cur->link;
}
printf("deleted node is %d\n",cur->info);
freenode(cur);
prev->link = NULL;
return first;
}
// insert after some position
NODE insert_after(int item,NODE first,int n)
{
NODE temp,cur,next;
int count = 1;
temp = getnode();
temp->info = item;
temp->link = NULL;
if( first == NULL)
return temp;
cur = first;
while( cur != NULL && count < cur =" cur">link;
count++;
}
if ( cur == NULL)
{
printf("invalid position no\n");
exit(0);
}
next = cur->link;
cur->link= temp;
temp->link= next;
return first;
}
// insert before
NODE insert_before(int item,NODE first,int n)
{
NODE temp,cur,next,prev;
int count = 1;
temp = getnode();
temp->info = item;
temp->link = NULL;
cur = first;
if( first == NULL)
return temp;
if ( n == 1 ) // to add in first position
{
temp->link = cur;
return temp;
}
while( cur != NULL && (count+1) < prev =" cur;" cur =" cur">link;
count++;
}
if( count+1 == n) // to add in last position
{
prev->link = temp;
return first;
}
if ( count+1 < next =" cur-">link;
cur->link = temp;
temp->link=next;
return first;
}
// to delete after some position
NODE delete_after(int item,NODE first,int n)
{
NODE cur,next,prev;
int count = 1;
if( first == NULL)
{
printf("list is empty");
return;
}
prev = NULL;
cur = first;
while( cur != NULL && count < (n+1)) { prev = cur; cur = cur ->link;
count++;
}
next= cur->link;
prev->link =next;
printf("%d is deleted",cur->info);
freenode(cur);
return first;
}
// delete before some position
NODE delete_before(int item,NODE first,int n)
{
NODE cur,next,prev;
int count = 1;
if( first == NULL)
{
printf("list is empty");
return;
}
next = NULL;
prev = NULL;
cur = first;
if( n == 1 )
{
printf(" no element befor that to delete");
return;
}
if ( n == 2)
{
next = cur->link;
printf("%d is deleted\n",cur->info);
freenode(cur);
return next;
}
while( cur != NULL && (count+1) < prev =" cur;" cur =" cur">link;
count++;
}
next= cur->link;
prev->link =next;
printf("%d is deleted",cur->info);
freenode(cur);
return first;
}
// insert in order list
NODE insert ( int item, NODE first )
{
NODE temp,cur,prev;
// get node to be inserted
temp = getnode();
temp->info = item;
temp->link = NULL;
//if list is empty
if ( first == NULL )
return temp;
//insert at begining
if ( item <>info )
{
temp->link = first;
return temp;
}
cur = first;
prev = NULL;
while ( cur != NULL && item > cur->info )
{
prev = cur;
cur = cur->link;
}
prev->link = temp;
temp->link = cur;
return first;
}
// search a item in list
NODE search(int key ,NODE first)
{
NODE cur;
int pos;
if( first == NULL)
{
printf("list is empty");
return;
}
cur = first;
pos =1;
while (cur != NULL && key != cur->info)
{
pos++;
cur = cur->link;
}
if ( cur == NULL)
{
printf("unsuccessful");
return;
}
else
printf("successfull item found in position %d",pos);
return first;
}
// merge list
NODE merge ( NODE a, NODE b )
{
NODE i,j,k,c;
i = a;
j = b;
c =k= getnode();
while ( i != NULL && j != NULL )
{
if ( i->info <>info )
{
k->link = i;
i = i->link;
}
else
{
k->link = j;
j = j->link;
}
k = k->link;
}
while ( i != NULL )
{
k->link = i;
i= i->link;
}
while ( j != NULL )
{
k->link = j;
j= j->link;
}
return c->link;
}
// concat two lists
NODE concat ( NODE a, NODE b )
{
NODE cur;
if ( a == NULL)
return b;
else if ( b== NULL)
return a;
cur = a;
while( cur->link != NULL)
cur = cur->link;
cur->link = b;
return a;
}
// no of nodes
NODE nodes(NODE first)
{
NODE temp;
int count = 1;
temp = first;
if ( first == NULL)
{
printf("list is empty\n");
return;
}
while( temp->link != NULL)
{
temp = temp->link;
count++;
}
printf("total no of nodes == %d\n",count);
return first;
}
// insert specified position
NODE insert_specified(int item,NODE first,int n)
{
NODE temp,prev,cur;
int count;
temp = getnode();
temp->info = item;
temp->link=NULL;
if( first == NULL && n == 1)// inserting node for first time
return temp;
if ( first == NULL)
{
printf("invalid pos\n");
return first;
}
if ( n == 1)
{
temp->link = first;
return temp;
}
count = 1;
prev = NULL;
cur = first;
while( cur != NULL && count != n)
{
prev = cur;
cur = cur->link;
count++;
}
if ( count == n)
{
prev->link = temp;
temp->link = cur;
return first;
}
printf("invalid position");
return first;
}
// delete from specified position
NODE delete_specified(NODE first,int pos)
{
NODE prev,cur;
int count;
if( first == NULL )
{
printf("list is empty\n");
return first;
}
if (pos == 1)
{
cur = first;
first = first->link;
printf("%d deleted",cur->info);
freenode(cur);
return first;
}
count = 1;
prev = NULL;
cur = first;
while( cur != NULL && count != pos)
{
prev = cur;
cur = cur->link;
count++;
}
if ( cur == NULL)
{
printf("invalid position");
return first;
}
prev->link= cur->link;
return first;
}
// delete node whose info given
NODE delete_specified_info(NODE first,int item)
{
NODE prev,cur;
int count;
if( first == NULL )
{
printf("list is empty\n");
return first;
}
if (item == first->info)
{// delete first node
cur = first;
first = first->link;
printf("%d deleted",cur->info);
freenode(cur);
return first;
}
prev = NULL;
cur = first;
while( cur != NULL && item != cur->info)
{
prev = cur;
cur = cur->link;
}
if ( cur == NULL)
{
printf("item not found");
return first;
}
prev->link= cur->link;
freenode(cur);
return first;
}
// to replace all accurance of given value by other value
NODE replace(int a,int b,NODE first)
{
NODE cur;
int count = 0;
cur = first;
while (cur != NULL )
{
if ( a != cur->info)
cur = cur->link;
else
{
count++;
cur->info = b;
cur = cur->link;
}
}
if ( count == 0)
printf("item nnot found in list\n");
return first;
}
// replace some node value by other value
NODE replace(int a,int b,NODE first)
{
NODE cur;
int count = 0;
cur = first;
count =1;
while (cur != NULL )
{
if ( a != count)
{
cur = cur->link;
count++;
}
else
{
count++;
cur->info = b;
cur = cur->link;
return first;
}
}
if ( cur == NULL)
printf("node not found in list\n");
return first;
}
// sum of all elements in list
NODE sum(NODE first)
{
NODE cur;
int count = 0;
cur = first;
if ( first == NULL)
{
printf("list is empty\n");
return;
}
while (cur != NULL )
{
count = count+cur->info;
cur = cur->link;
}
printf("sum of all elements %d",count);
return first;
}
// delete all duplicate ele with specified info
NODE delete_specified_info(NODE first,int item)
{
NODE prev,cur;
int count=0;
if( first == NULL )
{
printf("list is empty\n");
return first;
}
if (item == first->info)
{// delete first node
cur = first;
first = first->link;
printf("%d deleted",cur->info);
freenode(cur);
}
prev = NULL;
cur = first;
while( cur != NULL)
{
if( item != cur->info)
{
prev = cur;
cur = cur->link;
}
else
{
count++;
prev->link= cur->link;
freenode(cur);
return first;
}
}
if( count == 0)
printf ("item not found in list\n");
return first;
}
// split list... each successive elements should move to seperate list
NODE split(NODE first)
{
NODE i,j,cur;
i = NULL;
j= NULL;
int count=1;
cur = first;
while( cur != NULL)
{
if ( count%2 != 0)
{
i = insert(cur->info,i);
cur = cur->link;
count++;
}
else
{
j= insert(cur->info,j);
cur = cur->link;
count++;
}
}
printf("first list is \n");
display(i);
printf("second list is \n");
display(j);
return first;
}
// split list into two evn odd lists
NODE split(NODE first)
{
NODE i,j,cur;
i = NULL;
j= NULL;
cur = first;
while( cur != NULL)
{
if ( (cur->info)%2 == 0)
{
i = insert(cur->info,i);
cur = cur->link;
}
else
{
j= insert(cur->info,j);
cur = cur->link;
}
}
printf("even list is \n");
display(i);
printf("odd list is \n");
display(j);
return first;
}
// CIRCULAR LIST
// combining two circular list into one circular list
NODE com( NODE a, NODE b )
{
NODE i,j,k,c,m;
i = a->link;
m = a->link;
j = b->link;
c = k = getnode();
while ( i != a)
{
i = i->link;
}
i->link = b->link;
while( i != b)
{
i= i->link;
}
i->link=m;
return i;
}
// insert front
NODE insert_front ( int item, NODE last )
{
NODE temp;
temp = getnode( );
temp->info = item;
if ( last == NULL)
last = temp;
else
temp->link = last->link;
last->link= temp;
return last;
}
// insert rear
NODE insert_rear ( int item, NODE last )
{
NODE temp;
temp = getnode();
temp->info = item;
if ( last == NULL)
{
last = temp;
last->link = last;
}
else
{
temp->link = last->link;
last->link = temp;
}
return temp; // now temp is last node
}
// delete front
NODE delete_front(NODE last)
{
NODE first,temp;
if ( last == NULL)
{
printf("list is empty\n");
return;
}
if ( last->link == last)
{
printf("%d deleted",last->info);
freenode(last);
last = NULL;
return last;
}
first = last->link;
temp = first->link;
printf("%d deleted\n",first->info);
freenode(first);
last->link = temp;
return last;
}
// delete rear
NODE delete_rear(NODE last)
{
NODE prev;
if ( last == NULL)
{
printf("list is empty\n");
return;
}
if ( last->link == last)
{
printf("%d deleted",last->info);
freenode(last);
return NULL;
}
prev = last->link; // to find prev of last node
while( prev->link != last)
{
prev = prev->link;
}
prev->link = last->link;
printf("%d deleted",last->info);
freenode(last);
return prev;
}
// doubly linked list
struct node
{
int info;
struct node *rlink;
struct node *llink;
};
head = getnode ( );
head->rlink = head;
NODE insert_front ( int item, NODE head )
{
NODE temp,cur;
temp = getnode ( );
temp->info = item;
// node is inserted between head and first node
// head new first
cur = head->rlink;
head->rlink = temp;
temp->llink = head;
temp->rlink = cur;
cur->llink = temp;
return head;
}
NODE insert_rear ( int item, NODE head )
{
NODE temp,cur;
// node to be inserted
temp = getnode ( );
temp->info = item;
// node is inserted between head and first node
cur = head->llink;
head->llink = temp;
temp->rlink = head;
temp->llink = cur;
cur->rlink = temp;
return head;
}
NODE delete_front ( NODE head )
{
NODE cur ,next;
if ( head->rlink == head )
{
printf ( "list is empty\n" );
return head;
}
cur = head->rlink; // first node in list
next = cur->rlink; // second node in list in known
head->rlink = next;
next->llink = head;
printf ( "Deleted item is %d\n",cur->info );
freenode ( cur );
return head;
NODE delete_rear ( NODE head )
{
NODE cur, prev;
if ( head->rlink == head )
{
printf ( "list is empty\n" );
return head;
}
cur = head->llink; // last node
prev = cur->llink;
head->llink = prev;
prev->rlink = head;
printf ( "Deleted item is %d\n", cur->info);
freenode ( cur );
return head;
}void display ( NODE head )
{
NODE temp;
if ( head->rlink == head )
{
printf ( "list is empty" );
exit ( 0 );
}
printf ( " content of list are\n" );
for ( temp = head->rlink; temp != head ; temp = temp->rlink )
printf ( "%d\t",temp->info );
printf ( "\n" );
}
NODE insert_left ( int item,int pos, NODE head )
{
NODE temp,cur,prev;
if ( head->rlink == head )
{
printf ( "list is empty" );
return head;
}
// search for position
cur = head->rlink;
while ( cur != head && pos != cur->info )
{
cur = cur->rlink;
}
if ( cur == head )
{
printf ( "position not found\n " );
return head;
}
prev = cur->llink;
// node to be inserted
temp = getnode ( );
temp->info = item;
prev->rlink = temp;
temp->llink = prev;
cur->llink = temp;
temp->rlink = cur;
return head;
}
NODE insert_right( int item,int pos, NODE head )
{
NODE temp,cur,next;
if ( head->rlink == head )
{
printf ( "list is empty" );
return head;
}
// search for position
cur = head->rlink;
while ( cur != head && pos != cur->info )
{
cur = cur->rlink;
}
if ( cur == head )
{
printf ( "position not found\n " );
return head;
}
next = cur->rlink;
// node to be inserted
temp = getnode ( );
temp->info = item;
cur->rlink = temp;
temp->llink = cur;
temp->rlink = next;
next->llink = temp;
return head;
}
NODE delete_info ( int item,NODE head )
{
NODE cur ,prev,next;
if ( head->rlink == head )
{
printf ( "list is empty\n" );
return head;
}
cur = head->rlink; // first node in list
while ( cur != head && item != cur->info )
{
cur = cur->rlink;
}
if ( cur == head )
{
printf ( "item not found\n" );
return head;
}
//item found
prev = cur->llink;
next = cur->rlink;
prev->rlink = next;
next->llink = prev;
freenode( cur );
return head;
}
NODE delete_all ( int item,NODE head )
{
int count=0;
NODE cur, prev,next;
if ( head->rlink == head )
{
printf ( "list is empty\n" );
return head;
}
cur = head->rlink; // last node
while ( cur != head )
{
if ( item != cur->info)
cur = cur->rlink;
else
{
count++;
prev = cur->llink;
next = cur->rlink;
prev ->rlink = next;
next->llink = prev;
freenode ( cur );
cur = next; // next search starts from this point
}
}
if ( count == 0 )
{
printf ( "item not found in list \n" );
}
return head;
}
Reversing of lnked list………
NODE rev ( NODE first)
{
NODE cur,temp;
cur = NULL;
while ( first != NULL )
{
temp = first;
first = first ->link;
temp->link = cur;
cur = temp;
}
return cur;
}
STACK
#define SIZE 20
struct stack
{
int item[SIZE];
int top;
};
void push(struct stack *s,int);
int pop(struct stack *s);
void display(struct stack *s);
main()
{
struct stack *s;
s->top = -1;
int ch,item;
printf("STACK OPETAIONS\n");
do
{
printf("\n 1.PUSH\n");
printf("2.POP\n");
printf("3.DISPLAY\n");
printf("4.EXIT\n");
printf("ENTER YOUR CHOICE\n");
scanf("%d",&ch);
switch(ch)
{
case 1: printf("Enter the item to pushed onto stack\n");
scanf("%d",&item);
push(s,item);
break;
case 2: item = pop(s);
printf("deleted item is %d\n",item);
break;
case 3: display(s);
break;
case 4: exit(0);
}
}while( ch <= 4); } void push( struct stack *s,int item) { if( s->top == SIZE-1)
{
printf("stack is overflow\n");
exit(0);
}
s->item[++(s->top)]=item;
printf("top is %d\n",s->top);
}
int pop(struct stack *s)
{
int item;
if ( s->top == -1 )
{
printf("stack is empty\n");
exit(0);
}
item = s->item[s->top--];
return item;
}
void display( struct stack *s)
{
int i;
if ( s->top == -1 )
{
printf("stack is empty\n");
exit(0);
}
printf("stack elements are\n");
for(i=s->top;i>=0;i--)
printf("%d\t",s->item[i]);
}
Stack using array
#define SIZE 20
int item[SIZE];
int top=-1;
int item1; // item to be inserted
void push();
int pop();
void display();
main()
{
int ch;
printf("STACK OPETAIONS\n");
do
{
printf("\n 1.PUSH\n");
printf("2.POP\n");
printf("3.DISPLAY\n");
printf("4.EXIT\n");
printf("ENTER YOUR CHOICE\n");
scanf("%d",&ch);
switch(ch)
{
case 1: printf("Enter the item to pushed onto stack\n");
scanf("%d",&item1);
push();
break;
case 2: item1 = pop();
printf("deleted item is %d\n",item1);
break;
case 3: display();
break;
case 4: exit(0);
}
}while( ch <= 4); } void push() { if( top == SIZE-1) { printf("stack is overflow\n"); exit(0); } item[++top]=item1; } int pop() { if ( top == -1 ) { printf("stack is empty\n"); exit(0); } item1 = item[top]; top--; return item1; } void display( ) { int i; if (top == -1 ) { printf("stack is empty\n"); exit(0); } printf("stack elements are\n"); for(i=top;i>=0;i--)
printf("%d\t",item[i]);
}
Copy linked list: insert() display() getnode() are same
void copy(NODE s,NODE *t); // copy from s to t
main()
{
NODE first,first1;
first = NULL;
first1 = NULL;
int choice,item,n;
printf("enter how many elements u want to insert\n");
scanf("%d",&n);
while( n)
{
printf("enter the element\n");
scanf("%d",&item);
first = insert ( item,first );
n--;
}
printf("list before copy\n");
display(first);
copy(first,&first1);
printf("list after copy\n");
display(first1);
}
void copy(NODE s,NODE *t)
{
if ( s != NULL)
{
(*t) = malloc ( sizeof ( struct node));
(*t)->info = s->info;
(*t)->link = NULL;
copy( s->link,&((*t)->link));
}
}
Comparing two list:
int compare (NODE s, NODE t);
main ()
{
NODE first, first1;
first = NULL;
first1 = NULL;
int flag, item, n,n1;
printf ("enter no of lements for first list\n");
scanf ("%d", &n);
while (n)
{
printf ("enter the element\n");
scanf ("%d", &item);
first = insert (item, first);
n--;
}
printf ("enter no of lements for second list\n");
scanf ("%d", &n1);
if( n != n1)
{
printf("unequal\n");
exit(0);
}
while (n1)
{
printf ("enter the element\n");
scanf ("%d", &item);
first1 = insert (item, first1);
n1--;
}
flag = compare (first, first1);
if( flag)
printf("equal");
else
printf("unequal");
}
int
compare (NODE first, NODE first1)
{
static int flag;
if (first == NULL && first1 == NULL)
flag = 1;
else
{
if (first->info != first1->info)
flag = 0;
else
compare (first->link, first1->link);
}
return flag;
}
Recursive reverse linked list
NODE * rev ( NODE * root)
{
If ( root)
{
rev( root->next);
printf(“%d”,root->info);
}
}
To find middle node in list
void middle(NODE first)
{
NODE p,q;
p= first;
q= first;
if( q->link->link != NULL)
{
p= p->link;
q=q->link->link;
}
printf("%middle ele is %d\n",p->info);
}
Delete particular node first pointer not given
struct node
{
int info;
struct node *link;
};
typedef struct node * NODE;
NODE getnode();
NODE insert(int ,NODE);
void display(NODE);
void del(NODE);
NODE a[7];
static int i=0;
main()
{
NODE first;
first = NULL;
int choice,item,n;
printf("enter how many elements u want to insert\n");
scanf("%d",&n);
while( n)
{
printf("enter the element\n");
scanf("%d",&item);
first = insert ( item,first );
n--;
}
printf("list is\n");
display(first);
del(a[1]);
display(first);
}
NODE insert ( int item, NODE first )
{
NODE temp;
temp = getnode( );
a[i++]=temp;
temp->info = item;
temp->link = first;
return temp;
}
void display ( NODE first )
{
NODE temp;
temp = first;
if ( first == NULL )
{
printf ( "list is empty" );
return;
}
printf ( "\n" );
printf ( "contents of list are\n ");
while ( temp != NULL )
{
printf ( "%d %u\n",temp->info,&temp->info );
temp = temp->link;
}
printf ( "\n" );
}
NODE getnode ()
{
NODE temp;
temp = (NODE)malloc (sizeof ( struct node ));
if ( temp == NULL )
{
printf ( "out of memory ");
exit ( 0 );
}
return temp;
}
void del( NODE x)
{
NODE t;
if ( x->link == NULL)
printf("cont delete\n");
else
{
t=x->link;
x->info = t->info;
x->link = t->link;
free(t);
}
}
Reversing of list---iterative
NODE rev( NODE first)
{
NODE p,q,r;
p=first;
q=p->link;
p->link = NULL;
while(q!= NULL)
{
r = q->link;
q->link =p;
p = q;
q = r;
}
return p;
}
Sorting of linked list
void sort (NODE first)
{
NODE tmp,cur;
for (tmp = first; tmp->link != NULL; tmp = tmp->link)
for (cur = tmp->link; cur != NULL; cur = cur->link)
{
if (tmp->info > cur->info)
{
int n;
n = cur->info;
cur->info = tmp->info;
tmp->info = n;
}
}
}
Subscribe to:
Posts (Atom)