Subscribe:Posts Comments | Read Articles on Various Topics - Pro Articles

By PDMACpayday loans

You Are Here: Home » C and C++, Technical Interview Questions » C C++ programming languages Question Papers

Here are some C and C++ computer languages written placement test paper and technical / tech hr interview questions. See other related questions, programs and free to download resources for job test preparation.

Why doesn’t the following statement work?
char str[ ] = “Hello” ;
strcat ( str, ‘!’ ) ;
Ans: The string function strcat( ) concatenates strings and not a character. The basic difference between a string and a character is that a string is a collection of characters, represented by an array of characters whereas a character is a single character. To make the above statement work writes the statement as shown below:
strcat ( str, “!” ) ;

How do I know how many elements an array can hold?
Ans: The amount of memory an array can consume depends on the data type of an array. In DOS environment, the amount of memory an array can consume depends on the current memory model (i.e. Tiny, Small, Large, Huge, etc.). In general an array cannot consume more than 64 kb. Consider following program, which shows the maximum number of elements an array of type int, float and char can have in case of Small memory model.
main( )
{
int i[32767] ;
float f[16383] ;
char s[65535] ;
}

How do I write code that reads data at memory location specified by segment and offset?
Ans: Use peekb( ) function. This function returns byte(s) read from specific segment and offset locations in memory. The following program illustrates use of this function. In this program from VDU memory we have read characters and its attributes of the first row. The information stored in file is then further read and displayed using peek( ) function.
#include
#include
main( )
{
char far *scr = 0xB8000000 ;
FILE *fp ;
int offset ;
char ch ;
if ( ( fp = fopen ( “scr.dat”, “wb” ) ) == NULL )
{
printf ( “\nUnable to open file” ) ;
exit( ) ;
}
// reads and writes to file
for ( offset = 0 ; offset < 160 ; offset++ )
fprintf ( fp, “%c”, peekb ( scr, offset ) ) ;
fclose ( fp ) ;
if ( ( fp = fopen ( “scr.dat”, “rb” ) ) == NULL )
{
printf ( “\nUnable to open file” ) ;
exit( ) ;
}
// reads and writes to file
for ( offset = 0 ; offset < 160 ; offset++ )
{
fscanf ( fp, “%c”, &ch ) ;
printf ( “%c”, ch ) ;
}
fclose ( fp ) ;
}
Note:: Questions for engineers, freshers, campus IT services, software placement test drives, b.tech cse – computer science engineering, ece – electronics and communication, ee – electrical, it – information technology, me – mechanical branches placement papers and technical / tech hr interview questions are available here.
How do I compare character data stored at two different memory locations?
Ans: Sometimes in a program we require to compare memory ranges containing strings. In such a situation we can use functions like memcmp( ) or memicmp( ). The basic difference between two functions is that memcmp( ) does a case-sensitive comparison whereas memicmp( ) ignores case of characters. Following program illustrates the use of both the functions.
#include
main( )
{
char *arr1 = “Kicit” ;
char *arr2 = “kicitNagpur” ;
int c ;
c = memcmp ( arr1, arr2, sizeof ( arr1 ) ) ;
if ( c == 0 )
printf ( “\nStrings arr1 and arr2 compared using memcmp are identical” ) ;
else
printf ( “\nStrings arr1 and arr2 compared using memcmp are not identical”
) ;
c = memicmp ( arr1, arr2, sizeof ( arr1 ) ) ;
if ( c == 0 )
printf ( “\nStrings arr1 and arr2 compared using memicmp are identical” )
;
else
printf ( “\nStrings arr1 and arr2 compared using memicmp are not
identical” ) ;
}

See more error finding questions, programs, debugging questions from C++, C, Java computer languages sample technical test paper questions and written employment test question papers MCQ.

Fixed-size objects are more appropriate as compared to variable size data objects. Using variable-size data objects saves very little space. Variable size data objects usually have some overhead. Manipulation of fixed-size data objects is usually faster and easier. Use fixed size when maximum size is clearly bounded and close to average. And use variable-size data objects when a few of the data items are bigger than the average size. For example,
char *num[10] = { “One”, “Two”, “Three”, “Four”,
“Five”, “Six”, “Seven”, “Eight”, “Nine”, “Ten” } ;
Instead of using the above, use
char num[10][6] = { “One”, “Two”, “Three”, “Four”,
“Five”, “Six”, “Seven”, “Eight”, “Nine”, “Ten” } ;
The first form uses variable-size data objects. It allocates 10 pointers, which are pointing to 10 string constants of variable size. Assuming each pointer is of 4 bytes, it requires 90 bytes. On the other hand, the second form uses fixed size data objects. It allocates 10 arrays of 6 characters each. It requires only 60 bytes of space. So, the variable-size in this case does not offer any advantage over fixed size.

More popular, important previously asked questions from C, C++ and Java languages are available for programming tests and interviews, coding tests, employment aptitude and technical tests, Multiple choice questions for placement papers, IT programmers / engineers job written test papers and other latest exam test papers are available.

Leave a Reply

© Copyright 2010 Latestexams. All Rights Reserved | Privacy Policy | Terms & Conditions