-
Program 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 2
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 3
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 ");
}
==============================================================
Procedure 4
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); }
==============================================================
Plan 5
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 6
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);
}
==============================================================
Procedure 7
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 8
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);
}
==============================================================
Program 9
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]);
}
}
}
==============================================================
Program 10
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);
}
Program 1 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 12
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 13
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);
}
}
==============================================================
Program 14
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); }
==============================================================
Program 15
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 16
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 ");
}
==============================================================
Program 17
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 18
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 */
}
}
==============================================================
Plan 19
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 ");
}
}
==============================================================
Plan 20
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 ");
}
}
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);
}
}
}
}