Wednesday, 24 July 2013

Accenture Programs-Questions Previously asked questions


Rendered Image

Accenture Programs-Questions Previously asked questions

Factorial of number?
Sorting an array??
Fibonacci series?
Perfect number?
Armstrong number?
Reverse of string(with and without string reverse)
Can you write a c program for 2x3 and 3x1 matrix multiplication?

Accenture Technical Questions

Difference between Arrays and Linked List?
What are pointers in c?
What is data warehousing?
What is Recursion Function?
What is TDM?
What are the layers of OSI Model?
Difference between TCP and UDP?
What is Function Overloading?
What is the difference between C and Java?
What is the difference between array and pointer?
What is normalisation?and their types?
What is the difference between Char and Varchar in DBMS?
What is the difference between C and CPP?
Why C is procedural?
What are the phases of a compiler?
Define Routing Algorithm?
Define map and hash functions?
What is circular linked list?
What are the types of data models?

Accenture GD Topics
GD Topics
Duration
15 to 20 minutes
GD Panel
10 to 12 Members

RECENT GD TOPICS

Status of women in india?
How Indians are harassed in Australia and what should we do to help them?
Innovation in Software?
Dress code is Necessary for College Students are not?
Ragging should be legalised?
Effect of cinema on Youth?
India china economy?
Reservation System in India?
Politics in India between regional and national parties?
Impact of Global Warming?
Impact of IT on India?
Why India is Lagging in Olympics?
Should Hockey still be the national game of India?
Impact of Televisions on Humans?
should actors join Politics?

Accenture HR Interview

Project
Explain Your Current Project?

Accenture -RECENT HR INTERVIEW QUESTIONS

Tell me about yourself?
Why Accenture?
What are your short term and long term goals?
What do you know about Accenture?
Can you go anywhere for working in Accenture?
Are you ready to sign a service Agreement?
Tell me top 3 Indian IT Companies?
Which is your favorite subject?
What are your Achievements?
What are your Hobbies?
Do you have any question for me?

Accenture aptitude questions, Accenture free on line mock test questions with answers,

1. Some guy holding a glass of wine in his hand looking around in the room says, "This is same as it was four years ago, how old are your two kids now?" Other guy says "Three now, Pam had one more in the meanwhile." Pam says, "If you multiply their ages, answer is 96 and if you add the ages of first two kids, addition is same as our house number." The first guy says, "You are very smart but that doesn't tell me their ages." Pam says, "It's very simple, just think." What are the ages of three kids?

Ans: 8, 6, 2

2. My rack contains 8 Red colour ties, 13 violate colour ties,10 Blue colour ties, 5 Pink colour ties, 4 green colour ties. If electricity gone and i want at least two ties of same colour then how many ties i should take out from my rack?

Ans : 6 ties.

3. Two trains leaving from two station 50 miles away from each other with costant speed of 60 miles per hour, approaches towards each other on diffrent tracks. if lenght of each train is 1/6 mile. when they meet How much time they need to pass each other totally?

ANS : 10 sec. ( not sure)

4. A man walks east and turns right and then from there to his left and then 45degrees to his right. In which direction did he go

Ans. North west

5. A man shows his friend a woman sitting in a park and says that she the daughter of my grandmother's only son. What is the relation between the two

Ans. Daughter

6. water is continuously poured from a reservoir to a locality at the steady rate of 10,000 liters per hour. When delivery exceeds demand the excess water is stored in a tank. If the demand for 8 consecutive three-hour periods is 10000,10000,45000,25000,40000,15000,60000 and 35000 liters respectively, what will be the minimum capacity required of the water tank (in 1000 litres) to meet the demand?

Ans:40

7. If 5 tomatoes are worth 8 oranges,5 oranges are worth 4 apples, 7 apples are worth 3 pineapples and 7 pineapples cost rs.203,then he approx price of each tomato is

Ans.16

8.The radius of the circle is reduced from 5cm to 4cm then the % change of area .

Ans: 36%

9.Two workers can type two pages in two minuets then how many persons can type 18 pages in 6 minuets

Ans: 6

10. X is min of { n+5,6-n} then what is the min of X if,0 <1?

Ans 5.5

Accenture programming Questions

1. What is the output of the program
void main()
{
char s[]="oracle is the best";
char t[40];
char *ss,*tt;
while(*tt++=*ss++);
printf("%s",t);
getch();
}
// A. oracle is the best
// B. Core dump
// c. Error Message
// D. Goes into infinite loop
Ans: B. core dump (Garbage value)

2. .//What is the output of the program
void main()
{
fork();
printf(" Hello World");
getch();
}
// A. Hello World
// B. Hello World Hello World
// c. Error Message
// D. None of these
Ans: B

3. What is the output of the program
void main()
{
int i,j,k;
i=2;
j=4;
k=i++>j&2;
printf("%d\n",k);
if(++k && ++i<--j|| i++)
{
j=++k;
}
printf(" %d %d %d",i,-j--,k);
getch();
}
// A. 4,-3,2
// B. 5,-3,2
// c. 4,-2,2
// D. 5,-2,2
Ans: D

4. public void static main(String []args)
{
String s1=new String("test");
String s2=new String("test");
if(s1==s2)
System.out.println("Both are equal");
Boolean b1=new Boolean("true");
Boolean b2=new Boolean("false");
if(b1.equals(b2))
System.out.println("some message");
}
output=?

9.
x=7;
y=0;
if(x=y)y=7;
else
y=5;
what is the value of y

5.The ratio between the radius and height of a cone is 3:4. What is the curved surface area of the cone?
1) 15p m2
2) 12p m2
3) 9p m2
4) Data inadequate
5) None of these

6. A man stands on the top of a pole and makes an angle of 60° on the surface of a ground. He slides 20 m down and makes an angle of 30°at the same point. If he takes 10 seconds to reach the ground from here, find his speed.
1) 6 km/hr
2) 5 km/hr
3) 10 km/hr
4) 8 km/hr
5) 10.80 km/hr

7.The compound interest for first and second years is 200 and 220 on a certain amount. Find the sum.

8. Marked price of a commodity is 35% above the cost price. If he gives a discount of 15%, how much he gains on the deal.

9. 5 mangoes + 4 oranges = 7 mangoes + 1 orange. Find the ratio of mango to orange.

10. Length of a rectangle is increased by 50% and breadth is decreased by 25% what is the difference in the area

11. Mr X position in a class is 13th from first and 17th from last, and 8th from the first and 13th from last in passed candidates list, then how many candidates failed in the exam

12. Two successive discounts of 20% and 15% is equal to a net discount of .....

13. A two digit number is 4 times to its sum of digits , when 9 is added to the number, the digits will get reversed. Then what is that number?

Ans: 12

14. When do you say that a digraph is a cyclic
A)if and only if its first search does not have back arcs
B)a digraph is acyclic if and only if its first search does not have back vertices
C)if and only if its first search does not have same dfnumber
D)None of these

15.A function ‘q’ that accepts a pointer to a character as argument and returns a pointer to an array of integer can be declared as:
A)int (*q(char*)) []
B)int *q(char*) []
C)int(*q)(char*) []
D)None of the Above


16.study the code:
#include
void main()
{
const int a=100;
int *p;
p=&a;
(*p)++;
printf("a=%dn(*p)=%dn",a,*p);
}
What is printed?



17. In how many ways can a lock be opened if that lock has three digit number lock if
i) the last digit is 9
ii) and sum of the first two digits is less than or equal to the last digit. numbers are from 0-9

18. A person sold an item at a profit of 12% .If he sold it at a loss of 12% then he would get Rs.6/- less. What is the cost price?

19. (1 ½ /((3/4-2/5 )/(2/3+4/5))) * ((2 ¾/((4/3-2/5 )/(5/3+6/5))) (Numbers different)

20. Avg age of X number of adults in a class is 30yrs. If 12 new adults with avg age of 32 joined with them then the avg age increases by one. Find X?
Accenture -2010 Questions
1. What is the value of *second_ptr
int *first_ptr;
int *second_ptr;

*second_ptr = 30;

ptr value = 1;

first_ptr = &value

second_ptr = first_ptr;

(A) 30
(B) 1
(C) first_ptr
(D) None of the above

2. What is the output of the program

void main()

{

int i,j,k;

i=2;

j=4;

k=i++>j&2;

printf("%d\n",k);

if(++k && ++i<--j|| i++)

{

j=++k;

}

printf(" %d %d %d",i,-j--,k);

getch();

}

A. 4,-3,2

B. 5,-3,2

c. 4,-2,2

D. 5,-2,2

Ans: D


3. Output of the following program is
main()
{
int i=0;
for(i=0;i<20;i++)
{
switch(i){
case 0:
i+=5;
case 1:
i+=2;
case 5:
i+=5;
default:
i+=4;
break;
}
}
}
(

4. Find the approximate value of the following equation. 6.23% of 258.43 - ? + 3.11% of 127 = 13.87
1) 2
2) 4
3) 8
4) 6
5) 10

5. A train overtakes 2 persons walking at 3 km/hr and 5 km/hr respectively in the same direction and completely passes them in 8 seconds and 10 seconds respectively. Find the speed of the train.
1) 15 km/hr
2) 13 km/hr
3) 10 km/hr
4) 10 km/hr
5) None of these

6. The ratio between the radius and height of a cone is 3:4. What is the curved surface area of the cone?
1) 15p m2
2) 12p m2
3) 9p m2
4) Data inadequate
5) None of these

7. In a business P and Q invested amounts in the ratio 3:4, whereas the ratio between amounts invested by P and R was 6:7. If Rs 106501.50 was their profit, how much amount did Q receive?
1) Rs 40572
2) Rs 30429
3) Rs 35500.50
4) Rs 34629
5) None of these


8. A function ‘q’ that accepts a pointer to a character as argument and returns a pointer to an array of integer can be declared as:
A)int (*q(char*)) []
B)int *q(char*) []
C)int(*q)(char*) []
D)None of the Above

9. Identify the correct argument for the function call fflush() in ANSI C:
A)stdout
B)stdin
C)stderr
D)All the above

10. Which of the Following will define a type NODE that is a node in a Linked list?
A)struct node {NODE*next;int x;};type def struct node NODE;
B)typedef struct NODE {struct NODE *next;int x;};
C)typedef struct NODE {NODE *next;int x;};
D)typedef struct {NODE *next;int x;}NODE;

11.Which of these statements are false w.r.t File Functions?

i)fputs() ii)fdopen() iii)fgetpos() iv)ferror()



10.Study the code:
void show()
main()
{
show();
}
void show (char *s)
{
printf("%sn",s);
}

What will happen if it is compiled & run on an ANSI C Compiler?

A)It will compile & nothing will be printed when it is executed
B)it will compile but not link
C)the compiler will generate an error
D)the compiler will generate a warning

12. After 10 years A will be twice the age of B before 10 years.and now if the difference is 9 years between them then what is the age of B after 10 years

Ans 49

13. Races and games ---- 2 questions from this chapter like (A beats B by 10 meters and B beats C by 15 metres the A beats C by )

14. In the year 1990 there are 5000 men 3000 women 2000 boys .in 1994 men are increased by 20% women are increased by ratio of boys and women (this type of question but some what difficult I mean it takes too much time to solve)

15. The equivalent compound ratio of 5:6::7:10::6:5 ( question of this type this is not exact question).

16. Work can be done by 8 men and 10 women in 25 days, the same work can be done by 10 children and 5 women . in how many days 2 children and 3 men (similar to this)

17. One Cannot Take the address of a Bit Field

b.bit fields cannot be arrayed
c.Bit-Fields are machine Dependant
d.Bit-fields cannot be declared as static
Which of the Following Statements are true w.r.t Bit-Fields


18. What is the function of ceil(X) defined in math.h do?

A)It returns the value rounded down to the next lower integer
B)it returns the value rounded up to the next higher integer
C)the Next Higher Value
D)the next lower value


19. A shopkeeper labels the price of article 15% above the cost price. If he allow Rs 51.20 discount on an article of Rs 1024, find his profit percent.

1) 10%
2) 8%
3) 12%
4) 9%
5) 9.25%

20.Which of the following numbers are completely divisible by 11?

A. 3245682
B. 283712
C. 438416
D. 36894

1) Only A
2) Only B
3) Only C
4) Only D
5) All are divisible
Accenture 2011 question papers

1. #include
void main()
{
char s1[]="abcd";
char s2[10];
char s3[]="efgh";
int i;
clrscr();
i=strcmp(strcat(s3,ctrcpy(s2,s1))strcat(s3,"abcd"));
printf("%d",i);
}

What will be the output?

2. Look at the Code:
main()
{
int a[]={1,2,3},i;
for(i=0;i<3;i++)
{
printf("%d",*a);
a++;
}
}

3. Which Statement is/are True w.r.t the above code?
I.Executes Successfully & Prints the contents of the array
II.Gives the Error:Lvalue Required
III.The address of the array should not be changed
IV.None of the Above.

A)Only I B)Only II C)II & III D)IV

4. study the code:
#include
void main()
{
const int a=100;
int *p;
p=&a;
(*p)++;
printf("a=%dn(*p)=%dn",a,*p);
}
What is printed?



5. Which of the following are valid “include” formats?
A)#include and #include[file.h]
B)#include (file.h) and #include
C)#include [file.h] and #include “file.h”
D)#include and #include “file.h”

6. Work can be done by 8 men and 10 women in 25 days, the same work can be done by 10 children and 5 women . in how many days 2 children and 3 men (similar to this)

7. One man or two women or three boys can do a work in 44 days then one man, one women and one boy together can fininsh the same work in ---- dyas

8. (998-1) (998-2) (998-3)????.. (998-n)=------- when n>1000 ans is zero

9.Study the Following Points:
a.One Cannot Take the address of a Bit Field
b.bit fields cannot be arrayed
c.Bit-Fields are machine Dependant
d.Bit-fields cannot be declared as static
Which of the Following Statements are true w.r.t Bit-Fields


10. What is the function of ceil(X) defined in math.h do?
A)It returns the value rounded down to the next lower integer
B)it returns the value rounded up to the next higher integer
C)the Next Higher Value
D)the next lower value

11.The ratio between the radius and height of a cone is 3:4. What is the curved surface area of the cone?

1) 15p m2
2) 12p m2
3) 9p m2
4) Data inadequate
5) None of these

12. A man stands on the top of a pole and makes an angle of 60° on the surface of a ground. He slides 20 m down and makes an angle of 30°at the same point. If he takes 10 seconds to reach the ground from here, find his speed.

1) 6 km/hr
2) 5 km/hr
3) 10 km/hr
4) 8 km/hr
5) 10.80 km/hr

13. Which of the following values of 'n' satisfies the in-equality n2 - 24n + 143 < 0?

1) n < 11
2) n > 13
3) 11 < n < 13
4) 11 > n > 13
5) None of these

14. If 2x+y = 11, 2y+z = 12 and z+2x = 8, find the value of 2x + 3y +4z.

1) 29
2) 33
3) 25
4) 39
5) None of these

15. What is not true about the following statements about java.
a) it is compiled using javac compiler
b) the compiled files have .class extension.
c) such files cannot be transfered from one comp to another.
d) they use the java interpreter

Ans: c

16. Which of the Following is not defined in string.h?

A)strspn()
B)strerror()
C)memchr()
D)strod()

17.Identify the correct argument for the function call fflush() in ANSI C:

A)stdout
B)stdin
C)stderr
D)All the above

18. Which of the Following will define a type NODE that is a node in a Linked list?
A)struct node {NODE*next;int x;};type def struct node NODE;
B)typedef struct NODE {struct NODE *next;int x;};
C)typedef struct NODE {NODE *next;int x;};
D)typedef struct {NODE *next;int x;}NODE;


19. How many columns are retrived from this query:
SELECT address1 || ',' ||address2 ||','
||address2 "Address" FROM =
employee;

A. 3
B. 2
C. 1
D. 0

20. What is the is the result of the fallowing Code
Piece=20
Insert into table A value(a1):
CREATE TABLE B AS SELECT * FROM A;
ROLLBACK ;

A. Table B gets created with the row inserted in the first statement.
B. Table B is not created
C. Table B gets created , but no row gets inserted into Table A
D. Rollback throws up an exception .

Accenture Latest Placement paper 2012-2013 Technical HR and Group discussion Topics

Rendered Image

Accenture Latest Placement paper 2012-2013 Technical HR and Group discussion Topics




Which is the parameter that is added to every non-static member function when it is called?

Answer: 'this' pointer
What is a binary semaphore? What is its use?

Answer:

A binary semaphore is one, which takes only 0 and 1 as values. They are used to implement mutual exclusion and synchronize concurrent processes.

What is thrashing?

Answer:

It is a phenomenon in virtual memory schemes when the processor spends most of its time swapping pages, rather than executing instructions. This is due to an inordinate number of page faults.

What are turnaround time and response time?

Answer:

Turnaround time is the interval between the submission of a job and its completion. Response time is the interval between submission of a request, and the first response to that request.

What is data structure?

Answer: A data structure is a way of organizing data that considers not only the items stored, but also their relationship to each other. Advance knowledge about the relationship between data items allows designing of efficient algorithms for the manipulation of data.

List out the areas in which data structures are applied extensively?

Answer: The name of areas are:

Compiler Design,
Operating System,
Database Management System,
Statistical analysis package,
Numerical Analysis,
Graphics,
Artificial Intelligence,
Simulation

What are the major data structures used in the following areas : RDBMS, Network data model & Hierarchical data model.

Answer: The major data structures used are as follows:

RDBMS - Array (i.e. Array of structures)
Network data model - Graph
Hierarchical data model - Trees
What is the data structures used to perform recursion?

Answer: Stack. Because of its LIFO (Last In First Out) property it remembers its 'caller' so knows whom to return when the function has to return. Recursion makes use of system stack for storing the return addresses of the function calls.

Every recursive function has its equivalent iterative (non-recursive) function. Even when such equivalent iterative procedures are written, explicit stack is to be used.
Predict the output or error(s) for the following:

void main()
{
int const * p=5;
printf("%d",++(*p));
}

Answer:

Compiler error: Cannot modify a constant value.

Explanation: p is a pointer to a "constant integer". But we tried to change the value of the "constant integer".

main()
{
char s[ ]="man";
int i;
for(i=0;s[ i ];i++)
printf("\n%c%c%c%c",s[ i ],*(s+i),*(i+s),i[s]);
}

Answer:

mmmm
aaaa
nnnn

Explanation:s[i], *(i+s), *(s+i), i[s] are all different ways of expressing the same idea. Generally array name is the base address for that array. Here s is the base address. i is the index number/displacement from the base address. So, indirecting it with * is same as s[i]. i[s] may be surprising. But in the case of C it is same as s[i].

main()
{
float me = 1.1;
double you = 1.1;
if(me==you)
printf("I love U");
else
printf("I hate U");
}

Answer:

I hate U

Explanation: For floating point numbers (float, double, long double) the values cannot be predicted exactly. Depending on the number of bytes, the precession with of the value represented varies. Float takes 4 bytes and long double takes 10 bytes. So float stores 0.9 with less precision than long double.

Rule of Thumb:

Never compare or at-least be cautious when using floating point numbers with relational operators (== , >, <, <=, >=,!= ).
List out few of the Application of tree data-structure?

Answer: The list is as follows:

The manipulation of Arithmetic expression,
Symbol Table construction,
Syntax analysis.
List out few of the applications that make use of Multi linked Structures?

Answer: The applications are listed below:

Sparse matrix,
Index generation.

In tree construction which is the suitable efficient data structure?

Answer: Linked list is the efficient data structure.

What is the type of the algorithm used in solving the 8 Queens problem?

Answer: Backtracking
In RDBMS, what is the efficient data structure used in the internal storage representation?

Answer: B+ tree. Because in B+ tree, all the data is stored only in leaf nodes, that makes searching easier. This corresponds to the records that shall be stored in leaf nodes.

Whether Linked List is linear or Non-linear data structure?

Answer: According to Access strategies Linked list is a linear one.
According to Storage Linked List is a Non-linear one.


Tuesday, 23 July 2013

Trick To Find User Surname Of Any Reliance Mobile Number

Trick To Find User Surname Of Any Reliance Mobile Number

reliance number
reliance number
While searching on web for finding details of user of particular mobile number, I came across a website that can help you to get little information about that user. In this tutorial i will teach you to find surname of Reliance mobile number user in few simple steps. Basically this website is for recharge but it helps you to get information about user of that mobile number. So lets dive into it.


   1. Go to this  Website
   2. Enter Mobile Number in Reliance Subscriber Number.
   3. Email address is optional so you don't need to enter.
   4. Done!!!

Top 5 Cool Notepad Virus Tricks

Top 5 Cool Notepad Virus Tricks


notepad tricks
I had previously share some Interesting computer tricks as well as cool Batch file programs. In this post i will share with you guys some of the cool notepad tricks.As name suggest you don't require any program other then notepad. So lets get started.

1. World Trade Center Attack Trick

world trade center trick
world trade center trick


The flight number of the plane that had hit World Trade Center on  (9/11) was Q33NY. Now we call this trick or a coincidence or something else but whatever it is you will be definately amazed by the this trick.

    1. Open Notepad and Type “Q33N” (without quotes) in capital letters.
    2. Increase the font size to 72.
    3. Change the Font to Wingdings.


2. Matrix Effect Trick

matrix effect trick

matrix effect trick
In this trick i will show you to make a batch file in notepad which will act as matrix effect that you might have seen in movies.Matrix effect is basically number flashes in green color.

    1. Open Noteapad and copy below code into it.

@echo off
color 02
:start
echo %random% %random% %random% %random% %random% %random% %random% %random% %random% %random%
goto start

    2. Now save this file as Matrix.bat (name can be anything but .bat is must)
    3. Open your saved file and you will have matrix effect on your screen.



3. Creating Virus That Format C Drive



In this trick we will be creating virus in notepad using batch file programming. This virus is really simple to create yet very dangerous. opening this file we delete or format C drive of your computer.

    1. Open Notepad and copy below code into it.

@Echo off
Del C:\ *.* |y
 
    2. Then Save this file as virus.bat
    3. Now, running this file format C Drive.
Learn To Make Dangerous Virus In Minute
4. Making Personal Diary Using Notepad

notepad tricks

notepad tricks
Here you will learn to use notepad as Digital diary or a log book to keep record of your daily work instead of using pen and paper.

    1. Open Notepad and Type .LOG (in capital Letters and press enter
    2. Save the program with any name and close it.
    3. Open the file again. Now you can see current date and time, This will happen every time you reopen notepad

5. Dancing Keyboard Led

keyboard dancing led

keyboard dancing led

In this part i will show you to make interesting file using notepad which will make keyboard led to dance. basically we will be creating a visual basic script.

    1. Open Notepad and copy below codes into it.

Set wshShell =wscript.CreateObject("WScript.Shell")
do
wscript.sleep 100
wshshell.sendkeys "{CAPSLOCK}"
wshshell.sendkeys "{NUMLOCK}"
wshshell.sendkeys "{SCROLLLOCK}"
loop
    2. Then save this file as dance.vbs (name can be anything but .vbs is must)
    3. Open your save file and see your keyboard led blinking like disco lights.

Finding Ip Address Of A Website Using Command Prompt Or CMD

Finding Ip Address Of A Website Using Command Prompt Or CMD



In this tutorial i will teach you to find Ip Address of any website using Command Prompt or in short CMD. Using IP Address you can find location of the website server and do more stuff. I will demostrate this tutorial with Google but you can use this method to find IP Address of any website like twitter, facebook etc. So lets get started.
How to find IP ?

1. Go to Start > Type CMD and press Enter.

2. Now write Ping followed by website URL whose IP you want to find.
finding ip adddress of website

finding ip adddress of website

3. It will take less then a second and come up with the results as shown below.
finding ip adddress of website

finding ip adddress of website

In  my next post i will show you another easy way to find website IP Address and teach you to use this IP to find its location.

How to Hack Windows Password Without Any Software





Lost your windows password or want to hack your friends computer or want to hack your school computer ? then here’s  a hack to change your victims account passwor Without using any software 


There are many ways to hack a windows password but in this this tutorial I will explain How to Hack Windows Password Without Any Software follow the simple steps to hack a windows account

1. When you start your computer press f8 and select Safe mode as shown in the picture  and press Enter


2. Once you enter  the main menu you will see two accounts one is the administrator account and other is your victims account login in the administrator account

3. Now go to Start and open  control panel 

4. Now select User Accounts



5. Now select your victims account



6. Now select Remove The Password 

7. Now Restart  the computer and login the victims account without any password And do what ever you want  ( you can create your own password for the account )


Note :- This hack wont work if the admin account is either blocked or password Protected ,


Tuesday, 16 July 2013

bricks game source code c




bricks game source code c:



# include "process.h"
# include "dos.h"
# include "stdlib.h"
# include "graphics.h"
# include "stdio.h"
#include<conio.h>
#include<ctype.h>
# define NULL 0
# define YES 1
# define NO 0

int maxx, maxy, midx, midy ;
int bri[5][20] ;

/* plays different types of music */
music ( int type )
{
/* natural frequencies of 7 notes */
float octave[7] = { 130.81, 146.83, 164.81, 174.61, 196, 220, 246.94 } ;
int n, i ;

switch ( type )
{
case 1 :
for ( i = 0 ; i < 7 ; i++ )
{
sound ( octave[i] * 8 ) ;
delay ( 30 ) ;
}
nosound() ;
break ;

case 2 :
for ( i = 0 ; i < 15 ; i++ )
{
n = random ( 7 ) ;
sound ( octave[n] * 4 ) ;
delay ( 100 ) ;
}
nosound() ;
break ;

case 3 :
while ( !kbhit() )
{
n = random ( 7 ) ;
sound ( octave[n] * 4 ) ;
delay ( 100 ) ;
}
nosound() ;

/* flush the keyboard buffer */
if ( getch() == 0 )
getch() ;

break ;

case 4 :
for ( i = 4 ; i >= 0 ; i-- )
{
sound ( octave[i] * 4 ) ;
delay ( 15 ) ;
}
nosound() ;
break ;

case 5 :
sound ( octave[6] * 2 ) ;
delay ( 50 ) ;
nosound() ;
}
}



/* creates opening screen */
mainscreen()
{
/* array showing the positions where a brick is needed to form the figure BRICKS */
int ff[12][40] = {
1,1,1,1,0,0,0,1,1,1,1,0,0,0,1,1,1,1,1,0,0,0,1,1,1,0,0,1,0,0,0,0,1,0,0,0,1,1,1,0,
1,0,0,0,1,0,0,1,0,0,0,1,0,0,0,0,1,0,0,0,0,1,0,0,0,1,0,1,0,0,0,1,0,0,0,1,0,0,0,1,
1,0,0,0,0,1,0,1,0,0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,0,0,0,1,0,0,1,0,0,0,1,0,0,0,0,0,
1,0,0,0,0,1,0,1,0,0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,0,0,0,1,0,1,0,0,0,0,1,0,0,0,0,0,
1,0,0,0,1,0,0,1,0,0,0,1,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,1,0,0,0,0,0,
1,1,1,1,0,0,0,1,1,1,1,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,1,1,1,0,0,
1,0,0,0,1,0,0,1,0,0,0,1,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,0,0,0,1,0,
1,0,0,0,0,1,0,1,0,0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,0,0,0,1,0,1,0,0,0,0,0,0,0,0,0,1,
1,0,0,0,0,1,0,1,0,0,0,0,1,0,0,0,1,0,0,0,1,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,1,
1,0,0,0,1,0,0,1,0,0,0,0,1,0,0,0,1,0,0,0,0,1,0,0,0,1,0,1,0,0,0,1,0,0,1,0,0,0,0,1,
1,1,1,1,0,0,0,1,0,0,0,0,1,0,1,1,1,1,1,0,0,0,1,1,1,0,0,1,0,0,0,0,1,0,0,1,1,1,1,0,
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
} ;
int i, j, lx = 0, ly = 0, ch ;

/* draw boundary */
rectangle ( 0, 0, maxx, maxy ) ;

/* form the word BRICKS */
for ( i = 0 ; i < 12 ; i++ )
{
for ( j = 0 ; j < 40 ; j++ )
{
if ( ff[i][j] )
rectangle ( lx, ly, lx + 15, ly + 9 ) ;
lx = lx + 16 ;
}
lx = 0 ;
ly = ly + 10 ;
}

/* draw pattern at the bottom of the screen */
line ( 0, maxy - 12, maxx, maxy - 12 ) ;
setfillstyle ( XHATCH_FILL, WHITE ) ;
floodfill ( 2, maxy - 2, WHITE ) ;

/* draw the paddle and the ball */
setfillstyle ( SOLID_FILL, WHITE ) ;
rectangle ( midx - 25, maxy - 7 - 12, midx + 25, maxy - 12 ) ;
floodfill ( midx, maxy - 1 - 12, 1 ) ;
circle ( midx, maxy - 13 - 12, 12 ) ;
floodfill ( midx, maxy - 10 - 12, 1 ) ;

music ( 3 ) ;  /* play music */

/* display menu */
while ( 1 )
{
/* clear the region below the word BRICKS */
setviewport ( 1, 125 - 12, maxx - 1, maxy - 1, 1 ) ;
clearviewport() ;

setviewport ( 0, 0, maxx, maxy, 1 ) ;
outtextxy ( 20, 135, "Select any of the following:" ) ;
outtextxy ( 20, 155, "Play ( P )" ) ;
outtextxy ( 20, 165, "Instructions ( I )" ) ;
outtextxy ( 20, 175, "Exit ( E )" ) ;

ch = 0 ;

/* continue till the correct choice is made */
while ( ! ( ch == 'E' || ch == 'I' || ch == 'P' ) )
{
fflush ( stdin ) ;

/* if a special key is hit, flush the keyboard buffer */
if ( ( ch = getch() ) == 0 )
getch() ;
else
ch = toupper ( ch ) ;
}

if ( ch == 'P' )
break ;

switch ( ch )
{
case 'I' :
setviewport ( 1, 125 - 12, maxx - 1, maxy - 1, 1 ) ;
clearviewport() ;

setviewport ( 0, 0, maxx, maxy, 1 ) ;
settextstyle ( DEFAULT_FONT, HORIZ_DIR, 1 ) ;
outtextxy ( 20, 125, "         Instructions        " ) ;
settextstyle ( DEFAULT_FONT, HORIZ_DIR, 0 ) ;
outtextxy ( 20, 140, "Use left and right arrow keys to move paddle." ) ;
outtextxy ( 20, 150, "If you don't collect the ball on the paddle, you lose the ball." ) ;
outtextxy ( 20, 160, "On loosing a ball you loose 20 points." ) ;
outtextxy ( 20, 170, "On taking a brick you gain 5 points." ) ;
outtextxy ( 20, 185, "Press any key..." ) ;
fflush ( stdin ) ;
if ( getch() == 0 )
getch() ;
break ;

case 'E' :
closegraph() ;
restorecrtmode() ;
exit ( 0 ) ;
}
}

setviewport ( 1, 125 - 12, maxx - 1, maxy - 1, 1 ) ;
clearviewport() ;

/* prompt the user for the level desired */
setviewport ( 0, 0, maxx, maxy, 1 ) ;
outtextxy ( 20, 135, "Select any of the following levels:" ) ;
outtextxy ( 20, 155, "Novice ( N )" ) ;
outtextxy ( 20, 165, "Advanced ( A )" ) ;
outtextxy ( 20, 175, "Expert ( E )" ) ;

/* get user's choice */
fflush ( stdin ) ;
if ( ( ch = getch() ) == 0 )
getch() ;

clearviewport() ;

/* return the choice made by the user */
return ( ch ) ;
}
/* draws a brick at the proper position */
drawbrick ( int lx, int ly )
{
rectangle ( lx, ly, lx + 31, ly + 9 ) ;
rectangle ( lx + 2, ly - 2, lx + 31 - 2, ly + 9 - 2 ) ;
floodfill ( lx + 1, ly + 1, 2 ) ;
}


/* draws bricks at the start of the game */

bricks()
{
int i, j, lx = 0, ly = 0 ;

for ( i = 0 ; i < 5 ; i++ )  /* 5 rows */
{
for ( j = 0 ; j < 20 ; j++ )  /* 20 columns */
{
/* draw a brick at appropriate coordinates */
drawbrick ( lx, ly ) ;

lx = lx + 32 ;
}

lx = 0 ;
ly = ly + 10 ;
}
}


/* erases the specified brick */
erasebrick ( int b, int l )
{
/* b - brick number, l - layer */

setcolor ( BLACK ) ;
rectangle ( b * 32, l * 10, ( b * 32 ) + 31 , ( l * 10 ) + 9 ) ;
rectangle ( b * 32 + 1, l * 10, ( b * 32 ) + 31 - 1, ( l * 10 ) + 9 - 1 ) ;
rectangle ( b * 32 + 2, l * 10, ( b * 32 ) + 31 - 2, ( l * 10 ) + 9 - 2 ) ;
setcolor ( WHITE ) ;
}


main()
{
union REGS ii, oo ;
int ballx, bally, paddlex, paddley, dx = 1, dy = -1, oldx, oldy ;
int gm = CGAHI, gd = CGA, playerlevel ;
int i, flag = 0, speed = 25, welldone = NO, score = 0, chance = 4, area ;
int layer[5] = { 10, 20, 30, 40, 50 }, limit = 50, currentlayer = 4 ;
char *p1, *p2 ;

/* initialise the graphics system */
initgraph ( &gd, &gm, "c:\\Turboc3\\BGI" ) ;

/* get the maximum x and y screen coordinates */
maxx = getmaxx() ;
maxy = getmaxy() ;

/* calculate center of screen */
midx = maxx / 2 ;
midy = maxy / 2 ;

/* display opening screen and receive player's level */
playerlevel = mainscreen() ;

/* set speed of ball as per the level chosen */
switch ( playerlevel )
{
case 'A' :
case 'a' :
speed = 15 ;
break ;

case 'E' :
case 'e' :
speed = 10 ;
}

/* draw the bricks, the paddle and the ball */
rectangle ( 0, 0, maxx, maxy - 12 ) ;
bricks() ;
rectangle ( midx - 25, maxy - 7 - 12, midx + 25, maxy - 12 ) ;
floodfill ( midx, maxy - 1 - 12, 1 ) ;
circle ( midx, maxy - 13 - 12, 12 ) ;
floodfill ( midx, maxy - 10 - 12, 1 ) ;

/* allocate memory for storing the image of the paddle */
area = imagesize ( midx - 12, maxy - 18, midx + 12, maxy - 8 ) ;
p1 = (char*)malloc ( area ) ;

/* allocate memory for storing the image of the ball */
area = imagesize ( midx - 25, maxy - 7, midx + 25, maxy - 1 ) ;
p2 = (char*)malloc ( area ) ;

/* if memory allocation unsuccessful */
if ( p1 == NULL || p2 == NULL )
{
puts ( "Insufficient memory!!" ) ;
exit ( 1 ) ;
}

/* store the image of the paddle and the ball into allocated memory */
getimage ( midx - 12, maxy - 7 - 12 - 12 + 1, midx + 12, maxy - 8 - 12, p1 ) ;
getimage ( midx - 25, maxy - 7 - 12, midx + 25, maxy - 1 - 12, p2 ) ;

/* store current position of the paddle and ball */
paddlex = midx - 25 ;
paddley = maxy - 7 - 12 ;
ballx = midx - 12 ;
bally = maxy - 7 - 12 + 1 - 12 ;

/* display balls in hand ( initially 3 ) */
gotoxy ( 45, 25 ) ;
printf ( "Balls Remaining:" ) ;
for ( i = 0 ; i < 3 ; i++ )
{
circle ( 515 + i * 35, maxy - 5, 12 ) ;
floodfill ( 515 + i * 35, maxy - 5, 1 ) ;
}

/* display initial score */
gotoxy ( 1, 25 ) ;
printf ( "Your Score:   %4d", score ) ;

/* select font and alignment for displaying text */
settextjustify ( CENTER_TEXT, CENTER_TEXT ) ;
settextstyle ( SANS_SERIF_FONT, HORIZ_DIR, 4 ) ;

while ( 1 )
{
flag = 0 ;

/* save the current x and y coordinates of the ball */
oldx = ballx ;
oldy = bally ;

/* update ballx and bally to move the ball in appropriate direction */
ballx = ballx + dx ;
bally = bally + dy ;

/* as per the position of ball determine the layer of bricks to check */
if ( bally > 40 )
{
limit = 50 ;
currentlayer = 4 ;
}
else
{
if ( bally > 30 )
{
limit = 40 ;
currentlayer = 3 ;
}
else
{
if ( bally > 20 )
{
limit = 30 ;
currentlayer = 2 ;
}
else
{
if ( bally > 10 )
{
limit = 20 ;
currentlayer = 1 ;
}
else
{
limit = 10 ;
currentlayer = 0 ;
}
}
}
}

/* if the ball hits the left boundary, deflect it to the right */
if ( ballx < 1 )
{
music ( 5 ) ;
ballx = 1 ;
dx = -dx ;
}

/* if the ball hits the right boundary, deflect it to the left */
if ( ballx > ( maxx - 24 - 1 ) )
{
music ( 5 ) ;
ballx = maxx - 24 - 1 ;
dx = -dx ;
}

/* if the ball hits the top boundary, deflect it down */
if ( bally < 1 )
{
music ( 5 ) ;
bally = 1 ;
dy = -dy ;
}

/* if the ball is in the area occupied by the bricks */
if ( bally < limit )
{
/* if there is no brick present exactly at the top of the ball */
if ( bri[currentlayer][ ( ballx + 10 ) / 32 ] == 1 )
{
/* determine if the boundary of the ball touches a brick */
for ( i = 1 ; i <= 6 ; i++ )
{
/* check whether there is a brick to the right of the ball */
if ( bri[currentlayer][ ( ballx + i + 10 ) / 32 ] == 0 )
{
/* if there is a brick */
ballx = ballx + i ;
flag = 1 ;
break ;
}

/* check whether there is a brick to the left of the ball */
if ( bri[currentlayer][ ( ballx - i + 10 ) / 32 ] == 0 )
{
ballx = ballx - i ;
flag = 1 ;
break ;
}
}

/* if the ball does not touch a brick at the top, left or right */
if ( !flag )
{
/* check if the ball has moved above the current layer */
if ( bally < layer[currentlayer - 1] )
{
/* if so, change current layer appropriately */
currentlayer-- ;
limit = layer[currentlayer] ;
}

/* put the image of the ball at the old coordinates */
putimage ( oldx, oldy, p1, OR_PUT ) ;

/* erase the image at the old coordinates */
putimage ( oldx, oldy, p1, XOR_PUT ) ;

/* place the image of the ball at the new coordinates */
putimage ( ballx, bally, p1, XOR_PUT ) ;

/* introduce delay */
delay ( speed ) ;

/* carry on with moving the ball */
continue ;
}
}

/* control comes to this point only if the ball is touching a brick */
music ( 4 ) ;  /* play music */

/* erase the brick hit by the ball */
erasebrick ( ( ballx + 10 ) / 32, currentlayer ) ;

/* if the brick hit happens to be on the extreme right */
if ( ( ballx + 10 ) / 32 == 19 )
line ( maxx, 0, maxx, 50 ) ;  /* redraw right boundary */

/* if the brick hit happens to be on the extreme left */
if ( ( ballx + 10 ) / 32 == 0 )
line ( 0, 0, 0, 50 ) ;  /* redraw left boundary */

/* if the brick hit happens to be in the topmost layer */
if ( currentlayer == 0 )
line ( 0, 0, maxx, 0 ) ;  /* redraw top boundary */

/* set appropriate array element to 1 to indicate absence of brick */
bri[currentlayer][ ( ballx + 10 ) / 32 ] = 1 ;

bally = bally + 1 ;  /* update the y coordinate */
dy = -dy ;  /* change the direction of the ball */
score += 5 ;  /* increment score */
gotoxy ( 16, 25 ) ;
printf ( "%4d", score ) ;  /* print latest score */

/* if the first brick is hit during a throw */
if ( welldone == NO )
welldone = YES ;
else
{
/* for the consecutive bricks hit during the same throw */
outtextxy ( midx, midy, "Well done!" ) ;
music ( 1 ) ;
}
}

/* clear part of the screen used for displaying Well done message */
if ( bally > 50 && welldone == YES )
{
setviewport ( midx - 32 * 2.5, midy - 32 / 2, midx + 32 * 2.5, midy + 32 / 2, 1 ) ;
clearviewport() ;
setviewport ( 0, 0, maxx, maxy, 1 ) ;
welldone = NO ;
}

/* if the ball has reached the bottom */
if ( bally > 180 - 12 )
{
welldone = NO ;

/* if the paddle has missed the ball */
if ( ballx < paddlex - 20 || ballx > paddlex + 50 )
{
/* continue the descent of the ball */
while ( bally < 177 )
{
/* erase the image of the ball at the old coordinates */
putimage ( oldx, oldy, p1, XOR_PUT ) ;

/* put the image of the ball at the updated coordinates */
putimage ( ballx, bally, p1, XOR_PUT ) ;

/* introduce delay */
delay ( speed ) ;

/* save the current x and y coordinates of the ball */
oldx = ballx ;
oldy = bally ;

/* update ballx and bally to move the ball in appropriate direction */
ballx = ballx + dx ;
bally = bally + dy ;
}

chance-- ;  /* decrement the number of chances */
score -= 20 ;  /* decrement 20 points for each ball lost */
gotoxy ( 16, 25 ) ;
printf ( "%4d", score ) ;  /* print latest score */
music ( 2 ) ;

/* erase one out of the available balls */
if ( chance )
putimage ( 515 + ( chance - 1 ) * 35 - 12 , maxy - 10, p1, XOR_PUT ) ;

/* if the last ball is being played */
if ( chance == 1 )
{
gotoxy ( 45, 25 ) ;
printf ( "Your last ball... Be careful!" ) ;
}

/* if all the balls are lost */
if ( !chance )
{
gotoxy ( 45, 25 ) ;
printf ( "Press any key...              " ) ;
outtextxy ( midx, midy, "I warned you! Try again" ) ;
music ( 3 ) ;

closegraph() ;
restorecrtmode() ;
exit ( 0 ) ;
}
}

/* if ball is collected on paddle */
music ( 5 ) ;
bally = 180 - 12 ;  /* restore the y coordinate of ball */
dy = -dy ;  /* deflect the ball upwards */
}

/* put the image of the ball at the old coordinates */
putimage ( oldx, oldy, p1, OR_PUT ) ;

/* erase the image of the ball at the old coordinates */
putimage ( oldx, oldy, p1, XOR_PUT ) ;

/* put the image of the ball at the upadted coordinates */
putimage ( ballx, bally, p1, XOR_PUT ) ;

/* if all the bricks have been destroyed */
if ( score == 500 - ( ( 4 - chance ) * 20 ) )
{
outtextxy ( midx, midy, "You win !!!" ) ;

if ( score < 500 )
outtextxy ( midx, midy + 30, "Try scoring 500" ) ;
else
outtextxy ( midx, midy + 30, "You are simply GREAT!" ) ;

music ( 3 ) ;

closegraph() ;
restorecrtmode() ;
exit ( 0 ) ;
}

/* introduce delay */
delay ( speed ) ;

/* if the user has pressed a key to move the paddle */
if ( kbhit() )
{
/* issue interrupt to obtain the ascii and scan codes of key hit */
ii.h.ah = 0 ;
int86 ( 22, &ii, &oo ) ;

/* put the image of the paddle at the old coordinates */
putimage ( paddlex, paddley, p2, OR_PUT ) ;

/* erase the image of the paddle at the old coordinates */
putimage ( paddlex, paddley, p2, XOR_PUT ) ;

/* if Esc key has been pressed */
if ( oo.h.ah == 1 )
exit ( 0 ) ;

/* right arrow key */
if ( oo.h.ah == 75 )
paddlex = paddlex - 20 ;

/* left arrow key */
if ( oo.h.ah == 77 )
paddlex = paddlex + 20 ;

/* if paddle goes beyond left boundary */
if ( paddlex < 0 )
paddlex = 0 ;

/* if paddle goes beyond right boundary */
if ( paddlex > 589 )
paddlex = 589 ;

/* put the image of the paddle at the proper position */
putimage ( paddlex, paddley, p2, XOR_PUT ) ;
}
}
}

Sunday, 14 July 2013

Car Race Game in C++

You have to reach the finish line before the time goes out.
There are many hurdles in your way.
So be careful.


Code:

#include <iostream.h>
#include <dos.h>
#include <graphics.h>
#include <conio.h>
#include <stdlib.h>
#include <stdio.h>
#include <time.h>
#include <ctype.h>

class car
{
private:
int x1,y1,x2,y2,col,col2,col3;
public:
car():x1(200),y1(300),x2(270),y2(200),col(4)
{}
car(int a,int b,int c,int d,int e,int f,int
g):x1(a),y1(b),x2(c),y2(d),col(e),col2(f),col3(g)
{}
void get(int a,int b,int c,int d,int e,int f,int g)
{
x1=a;
y1=b;
x2=c;
y2=d;
col=e;
col2=f;
col3=g;
if (x1<=180)
{
sound(1000);
x1=200;
x2=270;
}
if (x2>=430)
{
sound(1000);
x1=340;
x2=410;
}
}
void draw()
{
setcolor(col);
setfillstyle(1,col);
rectangle(x1,y1,x2,y2);          //car body
floodfill(x1+10,y2+10,col);
setcolor(col2);                  //windows
setfillstyle(2,col2);
rectangle(x1+10,y1-70,x2-10,y2+10);
floodfill(x1+15,y2+15,col2);
rectangle(x1+10,y1-10,x2-10,y2+70);
floodfill(x1+15,y1-15,col2);
setcolor(col3);                  //wheels
setfillstyle(1,col3);
rectangle(x1-10,y2+5,x1,y2+20);
floodfill(x1-4,y2+12,col3);
rectangle(x2,y2+5,x2+10,y2+20);
floodfill(x2+4,y2+12,col3);
rectangle(x1-15+1,y1-25,x1,y1-5);
floodfill(x1-10,y1-20,col3);
rectangle(x2,y1-25,x2+15,y1-5);
floodfill(x2+4,y1-20,col3);
}
void collide(int col)
{
setcolor(col);
setfillstyle(1,col);
line(x1-5,y2-3,x1,y2);
line(x1-5,y2-5,x1,y2-5);
line(x1-5,y2-3,x1-5,y2-5);
line(x1,y2-5,x1+5,y2-3);
line(x1+5,y2-3,x1+10,y2-15);
line(x1+10,y2-15,x1+20,y2-3);
line(x1+20,y2-3,x1+30,y2-10);
line(x1+30,y2-10,x1+35,y2-3);
line(x1+35,y2-3,x1+45,y2-12);
line(x1+45,y2-12,x1+55,y2-3);
line(x1+55,y2-3,x1+60,y2-10);
line(x1+60,y2-10,x1+70,y2-3);
line(x1+70,y2-3,x1+74,y2-8);
line(x1+74,y2-8,x1+70,y2);
line(x1,y2,x1+70,y2);
floodfill(x1+30,y2-1,col);
line(x1-5,y1+3,x1,y1);
line(x1-5,y1+5,x1,y1+5);
line(x1-5,y1+3,x1-5,y1+5);
line(x1,y1+5,x1+5,y1+3);
line(x1+5,y1+3,x1+10,y1+15);
line(x1+10,y1+15,x1+20,y1+3);
line(x1+20,y1+3,x1+30,y1+10);
line(x1+30,y1+10,x1+35,y1+3);
line(x1+35,y1+3,x1+45,y1+12);
line(x1+45,y1+12,x1+55,y1+3);
line(x1+55,y1+3,x1+60,y1+10);
line(x1+60,y1+10,x1+70,y1+3);
line(x1+70,y1+3,x1+74,y1+8);
line(x1+74,y1+8,x1+70,y1);
line(x1,y1,x1+70,y1);
floodfill(x1+30,y1+1,col);
}
};


class obstacle
{
private:
int x,y,col;
public:
obstacle():x(0),y(0),col(0)
{}
obstacle(int a,int b,int c):x(a),y(b),col(c)
{}
void get(int a,int b,int c)
{
x=a;
y=b;
col=c;
}
void draw()
{
setcolor(col);
setfillstyle(1,col);
circle(x,y,20);
floodfill(x,y,col);
}
};


class timer
{
private:
int sec,min,ms,flag;
public:
timer():min(0),sec(0),ms(0),flag(0)
{}
timer(int a,int b,int c,int d):min(a),sec(b),ms(c),flag(d)
{}
void start()
{
min=sec=ms=flag=0;
}
void get()
{
settextstyle(1,0,1);
char* minn;
if (min>9)
{
int minnn=min/10;
if (minnn==0)
minn="0";
if (minnn==1)
minn="1";
if (minnn==2)
minn="2";
if (minnn==3)
minn="3";
if (minnn==4)
minn="4";
if (minnn==5)
minn="5";
if (minnn==6)
minn="6";
if (minnn==7)
minn="7";
if (minnn==8)
minn="8";
if (minnn==9)
minn="9";
setcolor(15);
outtextxy(20,100,minn);
setcolor(0);
outtextxy(20,100,minn);
}
if (min>9)
{
int minnn=min%10;
if (minnn==0)
minn="0";
if (minnn==1)
minn="1";
if (minnn==2)
minn="2";
if (minnn==3)
minn="3";
if (minnn==4)
minn="4";
if (minnn==5)
minn="5";
if (minnn==6)
minn="6";
if (minnn==7)
minn="7";
if (minnn==8)
minn="8";
if (minnn==9)
minn="9";
setcolor(15);
outtextxy(30,100,minn);
setcolor(0);
outtextxy(30,100,minn);
}
if (min<=9)
{
int minnn=min;
if (minnn==0)
minn="0";
if (minnn==1)
minn="1";
if (minnn==2)
minn="2";
if (minnn==3)
minn="3";
if (minnn==4)
minn="4";
if (minnn==5)
minn="5";
if (minnn==6)
minn="6";
if (minnn==7)
minn="7";
if (minnn==8)
minn="8";
if (minnn==9)
minn="9";
setcolor(15);
outtextxy(20,100,minn);
setcolor(0);
outtextxy(20,100,minn);
}
setcolor(15);
outtextxy(40,100,":");
if (sec>9)
{
int minnn=sec/10;
if (minnn==0)
minn="0";
if (minnn==1)
minn="1";
if (minnn==2)
minn="2";
if (minnn==3)
minn="3";
if (minnn==4)
minn="4";
if (minnn==5)
minn="5";
if (minnn==6)
minn="6";
if (minnn==7)
minn="7";
if (minnn==8)
minn="8";
if (minnn==9)
minn="9";
setcolor(15);
outtextxy(50,100,minn);
setcolor(0);
outtextxy(50,100,minn);
}
if (sec>9)
{
int minnn=sec%10;
if (minnn==0)
minn="0";
if (minnn==1)
minn="1";
if (minnn==2)
minn="2";
if (minnn==3)
minn="3";
if (minnn==4)
minn="4";
if (minnn==5)
minn="5";
if (minnn==6)
minn="6";
if (minnn==7)
minn="7";
if (minnn==8)
minn="8";
if (minnn==9)
minn="9";
setcolor(15);
outtextxy(60,100,minn);
setcolor(0);
outtextxy(60,100,minn);
}
if (sec<=9)
{
int minnn=sec;
if (minnn==0)
minn="0";
if (minnn==1)
minn="1";
if (minnn==2)
minn="2";
if (minnn==3)
minn="3";
if (minnn==4)
minn="4";
if (minnn==5)
minn="5";
if (minnn==6)
minn="6";
if (minnn==7)
minn="7";
if (minnn==8)
minn="8";
if (minnn==9)
minn="9";
setcolor(15);
outtextxy(50,100,minn);
setcolor(0);
outtextxy(50,100,minn);
}
setcolor(15);
outtextxy(70,100,":");
if (ms>9)
{
int minnn=ms/10;
if (minnn==0)
minn="0";
if (minnn==1)
minn="1";
if (minnn==2)
minn="2";
if (minnn==3)
minn="3";
if (minnn==4)
minn="4";
if (minnn==5)
minn="5";
if (minnn==6)
minn="6";
if (minnn==7)
minn="7";
if (minnn==8)
minn="8";
if (minnn==9)
minn="9";
setcolor(15);
outtextxy(80,100,minn);
setcolor(0);
outtextxy(80,100,minn);
}
if (ms>9)
{
int minnn=ms%10;
if (minnn==0)
minn="0";
if (minnn==1)
minn="1";
if (minnn==2)
minn="2";
if (minnn==3)
minn="3";
if (minnn==4)
minn="4";
if (minnn==5)
minn="5";
if (minnn==6)
minn="6";
if (minnn==7)
minn="7";
if (minnn==8)
minn="8";
if (minnn==9)
minn="9";
setcolor(15);
outtextxy(90,100,minn);
setcolor(0);
outtextxy(90,100,minn);
}
if (ms<=9)
{
int minnn=ms;
if (minnn==0)
minn="0";
if (minnn==1)
minn="1";
if (minnn==2)
minn="2";
if (minnn==3)
minn="3";
if (minnn==4)
minn="4";
if (minnn==5)
minn="5";
if (minnn==6)
minn="6";
if (minnn==7)
minn="7";
if (minnn==8)
minn="8";
if (minnn==9)
minn="9";
setcolor(15);
outtextxy(80,100,minn);
setcolor(0);
outtextxy(80,100,minn);
}
}
void time()
{
ms++;
if (ms==100)
{
ms=0;
sec++;
}
if (sec==60)
{
sec=0;
min++;
}
}
int minutes()
{
return min;
}
void timego()
{
ms=0;
sec+=30;
if (sec>60)
{
sec=0;
min++;
}
}
};
void grass()
{
setcolor(10);
setfillstyle(1,10);
rectangle(0,0,180,400);
floodfill(10,100,10);
rectangle(430,0,600,400);
floodfill(480,100,10);
setcolor(5);
settextstyle(8,0,3);
outtextxy(440,50,"RACE CRAZE");
setcolor(0);
setfillstyle(1,0);
settextstyle(7,0,2);
outtextxy(20,60,"TIMER");
rectangle(20,100,150,130);
floodfill(60,120,0);
settextstyle(7,0,2);
outtextxy(20,260,"MILES");
rectangle(20,300,150,330);
floodfill(60,320,0);
}
void track(int n,int coll)
{
setcolor(coll);
setfillstyle(1,coll);
rectangle(300,n,310,50+n);
floodfill(302,10+n,coll);
rectangle(300,100+n,310,150+n);
floodfill(302,110+n,coll);
rectangle(300,200+n,310,250+n);
floodfill(302,210+n,coll);
rectangle(300,300+n,310,350+n);
floodfill(302,310+n,coll);
rectangle(300,400+n,310,450+n);
floodfill(302,410+n,coll);
rectangle(300,500+n,310,550+n);
floodfill(302,510+n,coll);
rectangle(300,600+n,310,650+n);
floodfill(302,610+n,coll);
rectangle(300,700+n,310,750+n);
floodfill(302,710+n,coll);
}
void main()
{
int driver,mode;
driver=EGA;
mode=EGAHI;
initgraph(&driver,&mode,"c:\\turboc3\\bgi");
car c,c1;
obstacle o;
timer T;
int i,j=200,k=200;
int t=-200,flg=0;
time_t tt,ttt;
c.get(k,j+100,k+70,j,4,3,8);
c.draw();
grass();
track(t,15);
randomize();
int r=0,r1,l=50;
int miles=0,mil=0;
int stage=10;
getch();
do
{
T.get();
i=0;
if (kbhit())
i=getch();
T.time();
char* minn;
settextstyle(1,0,1);
if (miles>99)
{
int minnn=miles/100;
if (minnn==0)
minn="0";
if (minnn==1)
minn="1";
if (minnn==2)
minn="2";
if (minnn==3)
minn="3";
if (minnn==4)
minn="4";
if (minnn==5)
minn="5";
if (minnn==6)
minn="6";
if (minnn==7)
minn="7";
if (minnn==8)
minn="8";
if (minnn==9)
minn="9";
setcolor(15);
outtextxy(30,310,minn);
setcolor(0);
outtextxy(30,310,minn);
}
if (miles>99)
{
int minnn=miles%100;
if (minnn==0)
minn="0";
if (minnn==1)
minn="1";
if (minnn==2)
minn="2";
if (minnn==3)
minn="3";
if (minnn==4)
minn="4";
if (minnn==5)
minn="5";
if (minnn==6)
minn="6";
if (minnn==7)
minn="7";
if (minnn==8)
minn="8";
if (minnn==9)
minn="9";
setcolor(15);
outtextxy(40,310,minn);
setcolor(0);
outtextxy(40,310,minn);
}
if (miles>9)
{
int minnn=miles/10;
if (minnn==0)
minn="0";
if (minnn==1)
minn="1";
if (minnn==2)
minn="2";
if (minnn==3)
minn="3";
if (minnn==4)
minn="4";
if (minnn==5)
minn="5";
if (minnn==6)
minn="6";
if (minnn==7)
minn="7";
if (minnn==8)
minn="8";
if (minnn==9)
minn="9";
setcolor(15);
outtextxy(40,310,minn);
setcolor(0);
outtextxy(40,310,minn);
}
if (miles>9)
{
int minnn=miles%10;
if (minnn==0)
minn="0";
if (minnn==1)
minn="1";
if (minnn==2)
minn="2";
if (minnn==3)
minn="3";
if (minnn==4)
minn="4";
if (minnn==5)
minn="5";
if (minnn==6)
minn="6";
if (minnn==7)
minn="7";
if (minnn==8)
minn="8";
if (minnn==9)
minn="9";
setcolor(15);
outtextxy(50,310,minn);
setcolor(0);
outtextxy(50,310,minn);
}
if (miles<=9)
{
int minnn=miles;
if (minnn==0)
minn="0";
if (minnn==1)
minn="1";
if (minnn==2)
minn="2";
if (minnn==3)
minn="3";
if (minnn==4)
minn="4";
if (minnn==5)
minn="5";
if (minnn==6)
minn="6";
if (minnn==7)
minn="7";
if (minnn==8)
minn="8";
if (minnn==9)
minn="9";
setcolor(15);
outtextxy(40,310,minn);
setcolor(0);
outtextxy(40,310,minn);
}
if (flg==0)
{
randomize();
srand((unsigned) time(&ttt));
r=rand()%3;
if (r==2)
{
randomize();
r1=random(10)%2;
l=100;

   
(r1==0)?c1.get(200,l+stage,270,l+stage-100,5,6,7):
c1.get(335,l+stage,405,l+stage-100,5,6,7);

c1.draw();
flg=2;
}
}
sound(miles+100);
if (i==75)
{
c.get(k,j+100,k+70,j,0,0,0);
c.draw();
k=200;
c.get(k,j+100,k+70,j,4,3,8);
if (flg==1)
{
c1.collide(14);
c.collide(14);
delay(500);
c1.collide(0);
c.collide(0);
flg=3;
T.timego();
}
c.draw();
}
if (i==155)
{
c.get(k,j+100,k+70,j,0,0,0);
c.draw();
k=200;
c.get(k,j+100,k+70,j,4,3,8);
if (flg==1)
{
c1.collide(14);
c.collide(14);
delay(500);
c1.collide(0);
c.collide(0);
flg=3;
T.timego();
}
c.draw();
}
if (i==77)
{
c.get(k,j+100,k+70,j,0,0,0);
c.draw();
k=335;
c.get(k,j+100,k+70,j,4,3,8);
if (flg==1)
{
c1.collide(14);
c.collide(14);
delay(500);
c1.collide(0);
c.collide(0);
flg=3;
T.timego();
}
c.draw();
}
if (i==157)
{
c.get(k,j+100,k+70,j,0,0,0);
c.draw();
k=335;
c.get(k,j+100,k+70,j,4,3,8);
if (flg==1)
{
c1.collide(14);
c.collide(14);
delay(500);
c1.collide(0);
c.collide(0);
T.timego();
flg=3;
}
c.draw();
}
if (i==72)
{
mil+=1;
track(t,0);
(t>70)?t=-200:t+=5;
track(t,15);
if ((l+stage)>=200 && (l+stage)<=300)
{
if (r1==0 && k==200)
{
flg=1;
   
(r1==0)?c1.get(200,l+stage,270,l+stage-100,0,0,0):
c1.get(335,l+stage,405,l+stage-100,0,0,0);

c1.draw();
}
else if (r1==1 && k==335)
{
flg=1;
    
(r1==0)?c1.get(200,l+stage,270,l+stage-100,0,0,0):
c1.get(335,l+stage,405,l+stage-100,0,0,0);

c1.draw();
}
else
flg=2;
}
if (flg==1)
{
c.collide(14);
c1.collide(14);
flg=0;
delay(1000);
c.collide(0);
c1.collide(0);
c.get(k,j+100,k+70,j,4,3,8);
c.draw();
T.timego();
}
if (flg==2)
{
(r1==0)?c1.get(200,l+stage,270,l+stage-100,0,0,0):
c1.get(335,l+stage,405,l+stage-100,0,0,0);

c1.draw();
l=l+5;
    
(r1==0)?c1.get(200,l+stage,270,l+stage-100,5,6,7)
:c1.get(335,l+stage,405,l+stage-100,5,6,7);

c1.draw();
if (l+stage>300)
flg=3;
}
}
if (i==152)
{
mil+=2;
track(t,0);
(t>70)?t=-200:t+=20;
track(t,15);
if (l+stage>=200 && l+stage<=300)
{
if (r1==0 && k==200)
{
flg=1;
    
(r1==0)?c1.get(200,l+stage,270,l+stage-100,0,0,0):
c1.get(335,l+stage,405,l+stage-100,0,0,0);

c1.draw();
}
else if (r1==1 && k==335)
{
flg=1;

(r1==0)?c1.get(200,l+stage,270,l+stage-100,0,0,0):
c1.get(335,l+stage,405,l+stage-100,0,0,0);

c1.draw();
}
else
flg=2;
}
if (flg==1)
{
c.collide(14);
c1.collide(14);
flg=0;
delay(1000);
c.collide(0);
c1.collide(0);
c.get(k,j+100,k+70,j,4,3,8);
c.draw();
T.timego();
}
if (flg==2)
{

(r1==0)?c1.get(200,l+stage,270,l+stage-100,0,0,0)
:c1.get(335,l+stage,405,l+stage-100,0,0,0);

c1.draw();
l+=10;

    
(r1==0)?c1.get(200,l+stage,270,l+stage-100,5,6,7)
:c1.get(335,l+stage,405,l+stage-100,5,6,7);

c1.draw();
if (l+stage>300)
flg=3;
}
}
if (i==80)
{
mil-=1;
track(t,0);
(t<-370)?t=-200:t-=5;
track(t,15);
if (l+stage>=200 && l+stage<=300)
{
if (r1==0 && k==200)
{
flg=1;

(r1==0)?c1.get(200,l+stage,270,l+stage-100,0,0,0)
:c1.get(335,l+stage,405,l+stage-100,0,0,0);

c1.draw();
}
else if (r1==1 && k==335)
{
flg=1;

    
(r1==0)?c1.get(200,l+stage,270,l+stage-100,0,0,0)
:c1.get(335,l+stage,405,l+stage-100,0,0,0);

c1.draw();
}
else
flg=2;
}
if (flg==1)
{
c.collide(14);
c1.collide(14);
flg=0;
delay(1000);
c.collide(0);
c1.collide(0);
c.draw();
T.timego();
}
if (flg==2)
{

(r1==0)?c1.get(200,l+stage,270,l+stage-100,0,0,0)
:c1.get(335,l+stage,405,l+stage-100,0,0,0);

c1.draw();
l=l-5;

(r1==0)?c1.get(200,l+stage,270,l+stage-100,5,6,7)
:c1.get(335,l+stage,405,l+stage-100,5,6,7);

c1.draw();
if (l+stage>300)
flg=3;
}
}
if (i==160)
{
mil-=2;
track(t,0);
(t<-370)?t=-200:t-=20;
track(t,15);
if (l+stage>=200 && l+stage<=300)
{
if (r1==0 && k==200)
{
flg=1;

(r1==0)?c1.get(200,l+stage,270,l+stage-100,0,0,0)
:c1.get(335,l+stage,405,l+stage-100,0,0,0);

c1.draw();
}
else if (r1==1 && k==335)
{
flg=1;

(r1==0)?c1.get(200,l+stage,270,l+stage-100,0,0,0)
:c1.get(335,l+stage,405,l+stage-100,0,0,0);

c1.draw();
}
else
flg=2;
}
if (flg==1)
{
c.collide(14);
c1.collide(14);
flg=0;
delay(1000);
c.collide(0);
c1.collide(0);
c.draw();
T.timego();
}
if (flg==2)
{

(r1==0)?c1.get(200,l+stage,270,l+stage-100,0,0,0)
:c1.get(335,l+stage,405,l+stage-100,0,0,0);

c1.draw();
l=l-10;

(r1==0)?c1.get(200,l+stage,270,l+stage-100,5,6,7)
:c1.get(335,l+stage,405,l+stage-100,5,6,7);

c1.draw();
if (l+stage>300)
flg=3;
}
}
if (flg==3)
{
    
(r1==0)?c1.get(200,l+stage,270,l+stage-100,0,0,0)
:c1.get(335,l+stage,405,l+stage-100,0,0,0);

c1.draw();
flg=0;
}
if (i==32)
{
sound(2000);
delay(200);
}
nosound();
if (mil>4)
{
miles+=1;
mil=0;
}
if (mil<-4)
{
miles-=1;
mil=0;
}
if (miles>=1000)
break;
}while(i!='\r');
if (miles>=1000)
{
sound(3000);
clearviewport();
settextstyle(8,0,1);
int i=T.minutes();
if (i<8)
outtextxy(50,100,"CONGRATULATIONS! \
You have won the competetion");
else
outtextxy(50,100,"SORRY! You fell \
out of time");
delay(1000);
getch();
nosound();
}

}