C language problem

Usually, you can try to write some practical small programs, such as simulating a "calculator" or reading more classic programs.

Attachment: Classic Program 30

Program 1

Title: There are 1, 2, 3, 4 numbers. How many different three digits can you make up? How much are they altogether?

1. Program analysis: The numbers that can be filled in in hundreds, tens and units are all 1, 2, 3 and 4. Make all the arrangements before you leave.

Delete unqualified arrangements.

2. The program source code:

Master ()

{

int i,j,k;

printf(" \ n ");

for(I = 1; I<5; I++)/* The following is a triple cycle */

for(j = 1; j & lt5; j++)

for(k = 1; k & lt5; k++)

{

If (me! = k & me! = j & amp& ampj! =k) /* Make sure that I, J and K are different from each other */

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

}

}

==============================================================

Program 2

Title: Bonuses paid by enterprises are based on profits. When the profit (i) is less than or equal to 6,543,800 yuan, the bonus can be increased by 654.38+ 00%; High profit

When it is 654.38+ 10,000 yuan, if it is less than 200,000 yuan, the commission of 654.38+ 00% will be paid for the part below 654.38+ 10,000 yuan, and the part above 654.38+10,000 yuan can be withdrawn.

7.5%; Between 200,000 yuan and 400,000 yuan, 5% can be deducted for the part above 200,000 yuan; Between 400 thousand and 600 thousand is higher than

The part of 400,000 yuan can be deducted by 3%; Between 600,000 yuan and 6,543,800 yuan, the part above 600,000 yuan can be deducted by 654.38+0.5%, which is higher than.

1 ten thousand yuan, the part exceeding 1 ten thousand yuan will be deducted 1%. Enter the profit I of the current month from the keyboard and ask for the total bonus.

1. Program analysis: Please calibrate and locate with several axes. Note that the bonus should be defined as an increasing integer.

2. The program source code:

Master ()

{

long int I;

int bonus 1,bonus2,bonus4,bonus6,bonus 10,bonus;

scanf("%ld ",& ampI);

bonus 1 = 100000 * 0. 1; bonus 2 = bonus 1+ 100000 * 0.75;

bonus 4 = bonus 2+200000 * 0.5;

bonus 6 = bonus 4+200000 * 0.3;

bonus 10 = bonus 6+400000 * 0. 15;

If (I < =100000)

Bonus = I * 0.1;

else if(I & lt; =200000)

bonus = bonus 1+(I- 100000)* 0.075;

else if(I & lt; =400000)

bonus = bonus 2+(I-200000)* 0.05;

else if(I & lt; =600000)

bonus = bonus 4+(I-400000)* 0.03;

else if(I & lt; = 1000000)

bonus = bonus 6+(I-600000)* 0.0 15;

other

bonus = bonus 10+(I- 1000000)* 0.0 1;

Printf ("bonus =%d", bonus);

}

==============================================================

Program 3

Title: An integer, after adding 100, is a complete square number, and after adding 168, is a complete square number. What is the number?

1. Scheme analysis: If it is judged to be within 65438+ million, add 100 to this number before prescribing, and add 268 to this number before prescribing again. If it is stipulated,

The result is the result if the following conditions are met. Please see the specific analysis:

2. The program source code:

# contains "math.h"

Master ()

{

long int i,x,y,z;

for(I = 1; I< 100000; i++)

{ x = sqrt(I+ 100); /*x is the result of adding 100 to the prescription */

y = sqrt(I+268); /*y is the result of adding 168 */

if(x * x = = I+ 100 & amp; & ampY*y==i+268)/* If the square of the square root of a number is equal to the number, it means that the number is completely squared */

printf("\n%ld\n ",I);

}

}

==============================================================

Procedure 4

Title: Enter a day of a year to decide which day of the year it is.

1. Scheme analysis: Take March 5th as an example, first add up the first two months, and then add five days, which is the day of this year, which is quite special.

If it is a leap year, if the input month is greater than 3, you should consider adding one more day.

2. The program source code:

Master ()

{

Int day, month, year, harmony and leap;

Printf ("\ nPlease enter year, month and day \ n");

Scanf("%d, %d, %d ",& year & month & day);

Switch(month)/* Calculate the total number of days in the month before a month */

{

Case1:sum = 0; Break;

Case 2: sum = 31; Break;

Case 3: sum = 59 broken;

Case 4: sum = 90 is broken;

Scenario 5: sum =120; Break;

Case 6: sum =151; Break;

Case 7: sum =181; Break;

Case 8: sum = 212; Break;

Case 9: sum = 243; Break;

Case10: sum = 273; Break;

Case11:sum = 304; Break;

Case12: sum = 334; Break;

Default value: printf ("data error"); Break;

}

Sum = sum+days; /* plus the number of days in a day */

if(year % 400 = = 0 | |(year % 4 = = 0 & amp; & amp Year% 100! =0))/* Judge whether it is a leap year */

leap = 1;

other

Leap = 0;

if(leap = = 1 & amp; & Month & gt2)/* If it is a leap year, if the month is greater than 2, the total number of days will be added by one day */

sum++;

Printf ("Today is the %dth day." ,sum); }

==============================================================

Plan 5

Title: Enter three integers X, Y, z Y, Z, please output these three numbers from small to large.

1. program analysis: we try to put the smallest number on x, and compare x and y first. If X >;; Exchange the values of x and y,

Then compare x and z, if x >;; Z exchange the values of x and z to minimize x.

2. The program source code:

Master ()

{

int x,y,z,t;

scanf("%d%d%d ",& ampx & amp; y & amp; z);

if(x & gt; y)

{ t = x; x = y; y = t; }/* Exchange the values of x and y */

if(x & gt; z)

{ t = z; z = x; x = t; }/* Exchange the values of x and z */

If (y>z)

{ t = y; y = z; z = t; }/* Exchange the values of z and y */

Printf ("from small to large: %d %d %d\n", x, y, z);

}

==============================================================

Program 6

Title: Use * to output the pattern of letter C.

1. program analysis: you can write the letter c on paper with' *' first, and then output it line by line.

2. The program source code:

# contains "stdio.h"

Master ()

{

Printf ("Hello C-world! \ n ");

printf(" * * * * \ n ");

printf(" * \ n ");

printf(" * \ n ");

printf(" * * * * \ n ");

}

==============================================================

Procedure 7

Topic: output special patterns, please run it in C environment, it is very beautiful!

1. Program analysis: there are 256 characters * * *. Different roles, different graphics.

2. The program source code:

# contains "stdio.h"

Master ()

{

char a= 176,b = 2 19;

printf("%c%c%c%c%c\n ",b,a,a,a,b);

printf("%c%c%c%c%c\n ",a,b,a,b,a);

printf("%c%c%c%c%c\n ",a,a,b,a,a);

printf("%c%c%c%c%c\n ",a,b,a,b,a);

printf("%c%c%c%c%c\n ",b,a,a,a,b); }

==============================================================

Program 8

Title: Output 9*9 formula.

1. Program analysis: branch columns are considered, ***9 rows and 9 columns, I control row and J control column.

2. The program source code:

# contains "stdio.h"

Master ()

{

int i,j,result

printf(" \ n ");

for(I = 1; I< 10; i++)

{ for(j = 1; j & lt 10; j++)

{

Result = I * j;;

printf("%d*%d=%-3d ",I,j,result); /*-3d means left alignment, accounting for 3 digits */

}

printf(" \ n "); /* Line breaks after each line */

}

}

==============================================================

Program 9

Title: output chessboard is required.

1. Program analysis: use I to control rows, use J to control columns, and control whether to output black squares or white squares according to the change of the sum of I+J.

2. The program source code:

# contains "stdio.h"

Master ()

{

int i,j;

for(I = 0; I<8; i++)

{

for(j = 0; j & lt8; j++)

If ((i+j)%2==0)

printf("%c%c ",2 19,2 19);

other

printf(" ");

printf(" \ n ");

}

}

==============================================================

Program 10

Title: Print the stairs and print two smiling faces at the top of the stairs at the same time.

1. Program analysis: I control row, J control column, and J control the number of output black squares according to the change of I.

2. The program source code:

# contains "stdio.h"

Master ()

{

int i,j;

printf(" \ 1 \ 1 \ n "); /* Output two smiling faces */

for(I = 1; I< 1 1; i++)

{

for(j = 1; j & lt= I; j++)

printf("%c%c ",2 19,2 19);

printf(" \ n ");

}

}

Program 1 1

Title: Classic question: There are a pair of rabbits. They have a pair of rabbits every month from the third month after birth, and the rabbits grow to the third month.

After that, a pair of rabbits were born every month. If rabbits don't die, what is the total number of rabbits per month?

1. Program analysis: the rabbit's rule is the sequence of 1, 1, 2,3,5,8,13,21. ....

2. The program source code:

Master ()

{

long f 1,F2;

int I;

f 1 = F2 = 1;

for(I = 1; I & lt=20; i++)

{ printf(" % 12ld % 12ld ",f 1,F2);

if(I % 2 = = 0)printf(" \ n "); /* Control output, four per line */

f 1 = f 1+F2; /* Add the first two months and allocate them to the third month */

F2 = f 1+F2; /* Add the first two months and allocate them to the third month */

}

}

==============================================================

Program 12

Topic: Judge how many prime numbers are between 10 1-200, and output all prime numbers.

1. program analysis: the method of judging the prime number: divide 2 by a number to sqrt (this number), if it can be divisible,

It means that this number is not prime, but prime.

2. The program source code:

# contains "math.h"

Master ()

{

int m,I,k,h=0,leap = 1;

printf(" \ n ");

for(m = 10 1; m & lt=200; m++)

{ k = sqrt(m+ 1);

for(I = 2; I<= k;; i++)

If (m%i==0)

{ leap = 0; Break; }

if(leap) {printf("%-4d ",m); h++;

if(h% 10==0)

printf(" \ n ");

}

leap = 1;

}

Printf ("\ nTotal is %d", h);

}

==============================================================

Program 13

Title: Print out all "Narcissus". The so-called "daffodil number" refers to a three-digit number, and the cubic sum of its digits is equal to this number.

In itself. For example, 153 is a "daffodil number" because 153= 1 cubic +5 cubic +3 cubic.

1. Program analysis: Use for loop to control the number of 100-999, and each number is decomposed into units, tens and hundreds.

2. The program source code:

Master ()

{

int i,j,k,n;

Printf ("Splash" is ");

for(n = 100; n & lt 1000; n++)

{

I = n/ 100; /* Break down into hundreds of */

j = n/ 10% 10; /* Break down into ten digits */

k = n % 10; /* Break down into bits */

if(I * 100+j * 10+k = = I * I * I+j * j * j+k * k * k)

{

printf("%-5d ",n);

}

}

printf(" \ n ");

}

==============================================================

Program 14

Topic: decompose a positive integer into prime factors. For example, enter 90 and print 90=2*3*3*5.

Program analysis: to decompose the prime factor of n, we must first find a minimum prime number k, and then complete it according to the following steps:

(1) If this prime number is just equal to n, it means that the process of decomposing the prime factor is over, just print it out.

(2) If n

Repeat the first step.

(3) If n is not divisible by k, use k+ 1 as the value of k and repeat the first step.

2. The program source code:

/* Zheng int was carved up */

Master ()

{

int n,I;

Printf ("\ nPlease enter a number: \ n");

scanf("%d ",& ampn);

printf("%d= ",n);

for(I = 2; I < = n; i++)

{

And (n! =i)

{

If (n%i==0)

{ printf("%d* ",I);

n = n/I;

}

other

Break;

}

}

printf("%d ",n); }

==============================================================

Program 15

Topic: use the nesting of conditional operators to complete this question: academic performance >; = Students with 90 points are represented by A, and students with 60-89 points are represented by B,

Those below 60 points are indicated by C.

1. program analysis: (a>b)? This is a basic example of a conditional operator.

2. The program source code:

Master ()

{

Int score;

Carbonization grade;

Printf ("Please enter a score \ n");

Scanf("%d ",& score);

Grade = score & gt=90? A': (Score & gt=60? b ':' C ');

Printf("%d belongs to %c ",score, grade);

}

==============================================================

Program 16

Title: Enter two positive integers M and N, and find their greatest common divisor and least common multiple.

1. Program analysis: using rolling division.

2. The program source code:

Master ()

{

int a,b,num 1,num2,temp

Printf ("Please enter two numbers: \ n");

scanf("%d,%d ",& ampnum 1。 num 2);

if(num 1 { temp = num 1;

num 1 = num 2;

num2 = temp

}

a = num 1; b = num2

And (b! =0)/* Use rolling division until b is 0 */

{

temp = a % b;

a = b;

B = temperature;

}

printf("gongyueshu:%d\n ",a);

Printf ("Gongbeishu: %d\n", num1* num 2/a);

}

==============================================================

Program 17

Title: Enter a line of characters and count the number of English letters, spaces, numbers and other characters.

1. Program Analysis: Use the while statement, provided that the input character is not' \n'.

2. The program source code:

# contains "stdio.h"

Master ()

{ char c;

Int letters =0, spaces =0, numbers =0, others = 0;

Printf ("Please enter some characters \ n");

while((c=getchar())! ='\n ')

{

if(c & gt; = ' a ' & amp& ampc & lt= ' z ' | | c & gt= ' A ' & amp& ampc & lt='Z ')

Letter++;

else if(c== ' ')

space++;

else if(c & gt; = ' 0 ' & amp& ampc & lt='9')

digit++;

other

Other++;

}

Printf ("all in all: char =% d space =% d digit =% d others =% d \ n", letters,

Spaces, numbers, others);

}

==============================================================

Program 18

Topic: Find the value of s=a+aa+aaa+aaaa+aa ... A, where A is a number. For example, 2+22+222+2222+22222 (at this time

* * * added five numbers), and the addition of several numbers is controlled by the keyboard.

1. Program analysis: The key is to calculate the value of each item.

2. The program source code:

Master ()

{

int a,n,count = 1;

long int sn=0,TN = 0;

Printf ("Please enter a and n \ n");

Scanf("%d, %d ",& i, & n);

printf("a=%d,n=%d\n ",a,n);

while(count & lt; =n)

{

TN = TN+a;

sn = sn+TN;

a = a * 10;

++counting;

}

Printf("a+aa+...=%ld\n ",serial number);

}

==============================================================

Plan 19

Title: If a number is exactly equal to the sum of its factors, it is called "perfect number". Such as 6 = 1+2+3. Programming; arrange

Find all perfect numbers within 1000.

1. Scheme analysis: please refer to the scheme.

2. The program source code:

Master ()

{

Static int k [10];

int i,j,n,s;

for(j = 2; j & lt 1000; j++)

{

n =- 1;

s = j;

for(I = 1; I {

If ((j%i)==0)

{ n++;

s = s-I;

k[n]= I;

}

}

If (s==0)

{

Printf("%d is a million trees ",j);

for(I = 0; i printf("%d ",k[I]);

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

}

}

}

==============================================================

Plan 20

Title: A ball falls freely from the height of 100 meters, and bounces back to half the original height after each landing; Fall again and ask it to be there.

* * * How many meters did the 10 landing pass? How high is the rebound of 10?

1. Program analysis: See the following note.

2. The program source code:

Master ()

{

float sn= 100.0,HN = sn/2;

int n;

for(n = 2; n & lt= 10; n++)

{

sn = sn+2 * HN; /* The number of meters passed by * * * when landing for the nth time */

HN = HN/2; /* The height of the nth rebound */

}

Printf ("Total roads are %f\n", sn);

Printf ("the tenth is %f meters \n", HN);

}

Procedure 2 1

Topic: Monkeys eat peaches: On the first day, monkeys picked many peaches and ate half of them at once. He's not addicted. He ate another one.

The next morning, I ate half the remaining peaches and another one. I eat leftovers from the day before every morning.

Half and one. 10 in the morning, when I wanted to eat again, I saw only one peach left. Ask how much you picked on your first day.

1. program analysis: adopt the method of reverse thinking and infer from back to front.

2. The program source code:

Master ()

{

int day,x 1,x2;

Day = 9;

x2 = 1;

while(day & gt; 0)

{ x 1 =(x2+ 1)* 2; /* The number of peaches on the first day is twice that on the second day plus 1 */

x2 = x 1;

Day-;

}

Printf ("Total %d\n", x1);

}

==============================================================

Plan 22

Title: Two table tennis teams compete, each with three players. Team A is made up of three people, A, B and C, and Team B is made up of three people, X, Y, Z, Y and Z. It has been decided by drawing lots.

Competition list. Someone asked the players about the list of matches. A says he won't compare with X, and C says he won't compare with X and Z. Please make a program to find out.

A list of the players from the third team.

1. program analysis: the method of judging the prime number: divide 2 by a number to sqrt (this number), if it can be divisible,

It means that this number is not prime, but prime.

2. The program source code:

Master ()

{

char i,j,k; /*i is the opponent of A, J is the opponent of B and K is the opponent of C */

for(I = ' x '); I<=' zi++)

for(j = ' x '); j & lt= ' zj++)

{

If (me! =j)

for(k = ' x '); k & lt= ' zk++)

{If (I! = k & amp& ampj! =k)

{If (I! = ' x ' & amp& ampk! = ' x ' & amp& ampk! ='z ')

Printf("order is a-%c\tb-%c\tc-%c\n ",I, J, K);

}

}

}

}

==============================================================

Plan 23

Title: Print out the following pattern (diamond)

*

***

******

********

******

***

*

1. program analysis: first divide the graph into two parts, the first four lines are a rule, and the last three lines are a rule, using double.

For loops, the first layer controls rows and the second layer controls columns.

2. The program source code:

Master ()

{

int i,j,k;

for(I = 0; I < = 3; i++)

{

for(j = 0; j & lt= 2-I; j++)

printf(" ");

for(k = 0; k & lt= 2 * I; k++)

printf(" * ");

printf(" \ n ");

}

for(I = 0; I < = 2; i++)

{

for(j = 0; j & lt= I; j++)

printf(" ");

for(k = 0; k & lt= 4-2 * I; k++)

printf(" * ");

printf(" \ n ");

}

}

==============================================================

Plan 24

Topic: There is a fractional sequence: 2/ 1, 3/2, 5/3, 8/5, 13/8, 2113 ... Find the sum of the top 20 items in this sequence.

1. Program analysis: Please master the changing law of numerator and denominator.

2. The program source code:

Master ()

{

int n,t,number = 20

Floating point numbers a=2, b= 1, s = 0;;

for(n = 1; N<= number; n++)

{

s = s+a/b;

t = a; a = a+b; b = t; /* This part is the key of the program. Please guess the function of T */

}

Printf("sum is %9.6f\n ",s);

}

==============================================================

Plan 25

Title: Find 1+2! +3! +...+20! total

1. Program analysis: This program just turns accumulation into multiplication.

2. The program source code:

Master ()

{

Floating point number n, s=0, t =1;

for(n = 1; n & lt=20; n++)

{

t * = n;

s+= t;

}

printf(" 1+2! +3! ...+20! =%e\n ",s);

}

==============================================================

Plan 26

Topic: Find 5 by recursive method! .

1. Program analysis: recursive formula: fn=fn_ 1*4!

2. The program source code:

# contains "stdio.h"

Master ()

{

int I;

int fact();

for(I = 0; I<5; i++)

printf("\40:%d! =%d\n ",I,fact(I));

}

Internal facts (j)

int j;

{

int sum

If (j==0)

sum = 1;

other

sum = j * fact(j- 1);

Returns the sum;

}

==============================================================

Plan 27

Title: Use recursive function call to print these five characters in reverse order.

1. program analysis:

2. The program source code:

# contains "stdio.h"

Master ()

{

int I = 5;

Void Palin (int n);

printf(" \ 40:");

Palin (me);

printf(" \ n ");

}

Void Palin (n)

int n;

{

char next

If (n<= 1)

{

next = getchar();

printf(" \ n \ 0:");

Putchar (next);

}

other

{

next = getchar();

Palin (n-1);

Putchar (next);

}

}

==============================================================

Plan 28

Topic: There are five people sitting together. How old is the fifth person? He said he was two years older than the fourth man. Asked the fourth person's age, he said he was older than the first one.

All three are two years older. Ask the third person, and he says he is two years older than the second person. Ask the second man and say that he is two years older than the first man. finally

Ask the first person, he said it was 10 years old. How old is the fifth person?

1. program analysis: using recursive method, recursion can be divided into two stages: backward push and recursion. To know the age of the fifth person, you need to know

The age of the fourth person, and so on, to the first person (10 years old), and then back.

2. The program source code:

age

int n;

{

int c;

if(n = = 1)c = 10;

Else c = age (n-1)+2;

Return? ;

}

Master ()

{printf("%d ",age (5));

}

==============================================================

Plan 29

Title: Give a positive integer not exceeding 5 digits. Requirements: 1. Find out how many digits it is; 2. Print out all the numbers in reverse order.

1. program analysis: learn to decompose each digit, as explained below: (here is a simple algorithm provided by Zhao Xin, Class 002, Teachers College)

2. The program source code:

Master ()

{

Long a, b, c, d, e, x;

scanf("%ld ",& ampx);

a = x/ 10000; /* Decompose ten thousand bits */

b = x % 10000/ 1000; /* Break down into thousands */

c = x % 1000/ 100; /* Break down into hundreds of */

d = x % 100/ 10; /* Break down into ten digits */

e = x % 10; /* Break down into bits */

If (a! =0) printf ("there are five,% LD% LD% LD \ n", e, d, c, b, a);

else if (b! =0) printf ("there are four,% LD% LD \ n", e, d, c, b);

else if (c! =0) printf ("There are three,% LD% LD \ n", e, d, c);

else if (d! =0) printf ("There are two, %ld %ld\n", e, d);

else if (e! =0) printf ("Yes 1, %ld\n", e);

}

==============================================================

Program 30

Title: A five-digit number, judging whether it is palindrome or not. That is, 1232 1 is a palindrome, with one digit equal to ten thousand digits and ten digits equal to one thousand digits.

1. Scheme analysis: same as 29 cases.

2. The program source code:

Master ()

{

Brother Long, Stone, Money, Wan, X;

scanf("%ld ",& ampx);

wan = x/ 10000;

Money = x%10000/1000;

Shi = x % 100/ 10;

ge = x % 10;

if(ge = = wan & amp; & Give = = Money)/* Bit equals ten thousand, and ten equals one thousand */

Printf ("This number is a Huiwen \ n");

other

Printf ("This number is not Huiwen \ n");

}