-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path100math.c
749 lines (619 loc) · 17.1 KB
/
100math.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
经典的100个c算法
语言的学习基础,100个经典的算法
C语言的学习要从基础开始,这里是100个经典的算法-1C语言的学习要从基础开始,这里是100个经典的
算法
题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔
子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数
为多少?
__________________________________________________________________
程序分析:兔子的规律为数列1,1,2,3,5,8,13,21....
___________________________________________________________________
程序源代码:
main()
{
long f1,f2;
int i;
f1=f2=1;
for(i=1;i<=20;i++)
{
printf("%12ld %12ld",f1,f2);
if(i%2==0) printf("\n");/*控制输出,每行四个*/
f1=f1+f2;/*前两个月加起来赋值给第三个月*/
f2=f1+f2;/*前两个月加起来赋值给第三个月*/
}
}
上题还可用一维数组处理,you try!
题目:判断101-200之间有多少个素数,并输出所有素数。
__________________________________________________________________
程序分析:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整
除,则表明此数不是素数,反之是素数。
___________________________________________________________________
程序源代码:
#include "math.h"
main()
{
int m,i,k,h=0,leap=1;
printf("\n");
for(m=101;m<=200;m++)
{
leap=1;
k=sqrt(m+1);
for(i=2;i<=k;i++) {
if(m%i==0) {
leap=0;
break;
}
}
if(leap) {
h++;
printf("%-4d",m);
if(h%10==0)
printf("\n");
}
}
printf("\nThe total is %d",h);
}
题目:打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位
数字立方和等于该数本身。例如:153是一个“水仙花数”,因为153=1的三次方
+5的三次方+3的三次方。
__________________________________________________________________
程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。
___________________________________________________________________
程序源代码:
main()
{
int i,j,k,n;
printf("'water flower'number is:");
for(n=100;n<1000;n++)
{
i=n/100;/*分解出百位*/
j=n/10%10;/*分解出十位*/
k=n%10;/*分解出个位*/
if(i*100+j*10+k==i*i*i+j*j*j+k*k*k)
{
printf("%-5d",n);
}
}
printf("\n");
}
题目:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。
__________________________________________________________________
程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完
成:
(1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。
(2)如果n>k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正
整数你n,重复执行第一步。
(3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。
___________________________________________________________________
程序源代码:
/* zheng int is divided yinshu*/
main()
{
int n,i;
printf("\nplease input a number:\n");
scanf("%d",&n);
for(i=2;i<=n;i++)
{
while(n!=i)
{
if(n%i==0)
{
printf("%d*",i);
n=n/i;
}
else
break;
}
}
printf("%d",n);
}
题目:利用条件运算符的嵌套来完成此题:学习成绩>=90分的同学用A表示,60
-89分之间的用B表示,60分以下的用C表示。
__________________________________________________________________
程序分析:(a>b)?a:b这是条件运算符的基本例子。
___________________________________________________________________
程序源代码:
main()
{
int score;
char grade;
printf("please input a score\n");
scanf("%d",&score);
grade = ((score>=90) ?'A': (score >= 60 ?'B':'C'));
printf("%d belongs to %c",score,grade);
}
题目:输入两个正整数m和n,求其最大公约数和最小公倍数。
__________________________________________________________________
程序分析:利用辗除法。
___________________________________________________________________
程序源代码:
main()
{
int a,b,num1,num2,temp;
printf("please input two numbers:\n");
scanf("%d,%d",&num1,&num2);
if(num1 < num2) {
temp=num1;
num1=num2;
num2=temp;
}
a=num1;
b=num2;
while(b!=0)/*利用辗除法,直到b为0为止*/
{
temp=a%b;
a=b;
b=temp;
}
printf("gongyueshu:%d\n",a);
printf("gongbeishu:%d\n",num1*num2/a);
}
题目:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。
__________________________________________________________________
程序分析:利用while语句,条件为输入的字符不为'\n'.
___________________________________________________________________
程序源代码:
#include "stdio.h"
main()
{
char c;
int letters=0,space=0,digit=0,others=0;
printf("please input some characters\n");
while((c=getchar())!='\n')
{
if(c>='a'&&c<='z'||c>='A'&&c<='Z')
letters++;
else if(c==' ')
space++;
else if(c>='0'&&c<='9')
digit++;
else
others++;
}
printf("all in all:char=%d space=%d digit=%d others=%
d\n",letters,space,digit,others);
}
题目:求s=a+aa+aaa+aaaa+aa...a的值,其中a是一个数字。例如
2+22+222+2222+22222(此时共有5个数相加),几个数相加有键盘控制。
__________________________________________________________________
程序分析:关键是计算出每一项的值。
___________________________________________________________________
程序源代码:
main()
{
int a,n,count=1;
long int sn=0,tn=0;
printf("please input a and n\n");
scanf("%d,%d",&a,&n);
printf("a=%d,n=%d\n",a,n);
while(count<=n)
{
tn=tn+a;
sn=sn+tn;
a=a*10;
++count;
}
printf("a+aa+...=%ld\n",sn);
}
题目:一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2
+3.编程找出1000以内的所有完数。
___________________________________________________________________
程序源代码:
#include<stdio.h>
int main()
{
int i, j, s, n; /*变量i控制选定数范围,j控制除数范围,s记录累加因子之和*/
printf("请输入所选范围上限:");
scanf("%d", &n); /* n的值由键盘输入*/
for( i=2; i<=n; i++ )
{
s=0; /*保证每次循环时s的初值为0*/
for( j=1; j<i; j++ )
{
if(i%j == 0) /*判断j是否为i的因子*/
s += j;
}
if(s == i) /*判断因子这和是否和原数相等*/
printf("It's a perfect number:%d\n", i);
}
return 0;
}
题目:一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,
求它在第10次落地时,共经过多少米?第10次反弹多高?
___________________________________________________________________
程序源代码:
main()
{
float sn=100.0,hn=sn/2;
int n;
for(n=2;n<=10;n++)
{
sn=sn+2*hn;/*第n次落地时共经过的米数*/
hn=hn/2; /*第n次反跳高度*/
}
printf("the total of road is %f\n",sn);
printf("the tenth is %f meter\n",hn);
}
题目:一只猴子摘了N个桃子第一天吃了一半又多吃了一个,第二天又吃了余下的
一半又多吃了一个,到第十天的时候发现还有一个(没吃).
___________________________________________________________________
程序源代码:
/* 猴子吃桃问题 */
main()
{
int i,s,n=1;
for(i=1;i<10;i++)
{
s=(n+1)*2
n=s;
}
printf("第一天共摘了%d个桃\n",s);
}
迭代法求方程根
___________________________________________________________________
/* 牛顿迭代法求一个数的平方根 */
//X2 = (X1 + a / X1) / 2;
#include <math.h>
#include <stdio.h>
int main(void)
{
float a, x1, check;
scanf("%f", &a);
x1 = 1;
do {
x1 = (x1 + a / x1) / 2;
check = x1 * x1 - a;
} while((check ? check : 0 - check) > 1.0E-5); //精确到3个小数点
printf("%f\n", x1);
return 0;
}
用牛顿迭代法 求方程 2*x*x*x-4*x*x+3*x-6 的根
/* 牛顿迭代法 */
#define Epsilon 1.0E-6 /*控制解的精度*/
#include<math.h>
main()
{
float x1,x0=1.5;
x1=x0-(2*x0*x0*x0-4*x0*x0+3*x0-6)/(6*x0*x0-8*x0+3);
while(fabs(x1-x0>=Epsilon)) {
x0=x1;
x1=x0-(2*x0*x0*x0-4*x0*x0+3*x0-6)/(6*x0*x0-8*x0+3);
}
printf("方程的根为%f\n",x1);
}
用二分法求上题
/* 二分法 */
#define Epsilon 1.0E-5 /*控制解的精度*/
#include<math.h>
main()
{
folat x1,x2,x0,f1,f2,f0;
x0=(x1+x2)/2;
f0=2*x0*x0*x0-4*x0*x0+3*x0-6; /* 求中点的函数值 */
while(fabs(f0)>=Epsilon)
{
if(f0*f1<0)
{ x2=x0;
f2=2*x2*x2*x2-4*x2*x2+3*x2-6;
}
if(f0*f2<0)
{ x1=x0;
f1=2*x1*x1*x1-4*x1*x1+3*x1-6;
}
x0=(x1+x2)/2;
f0=2*x0*x0*x0-4*x0*x0+3*x0-6;
}
printf("用二分法求得方程的根:%f\n",x0);
}
题目:打印出如下图案(菱形)
*
***
******
********
******
***
*
___________________________________________________________________
程序分析:先把图形分成两部分来看待,前四行一个规律,后三行一个规律,利
用双重for循环,第一层控制行,第二层控制列。
___________________________________________________________________
程序源代码:
main()
{
int i,j,k;
for(i=0;i<=3;i++)
{
for(j=0;j<=2-i;j++)
printf(" ");
for(k=0;k<=2*i;k++)
printf("*");
printf("\n");
}
for(i=0;i<=2;i++)
{
for(j=0;j<=i;j++)
printf(" ");
for(k=0;k<=4-2*i;k++)
printf("*");
printf("\n");
}
}
题目:一个5位数,判断它是不是回文数。即12321是回文数,个位与万位相同,
十位与千位相同。
___________________________________________________________________
程序分析:同29例
___________________________________________________________________
程序源代码:
main( )
{
long ge,shi,qian,wan,x;
scanf("%ld",&x);
wan=x/10000;
qian=x%10000/1000;
shi=x%100/10;
ge=x%10;
if (ge==wan&&shi==qian)/*个位等于万位并且十位等于千位*/
printf("this number is a huiwen\n");
else
printf("this number is not a huiwen\n");
}
题目:请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,
则继续判断第二个字母。
___________________________________________________________________
程序分析:用情况语句比较好,如果第一个字母一样,则判断用情况语句或if语
句判断第二个字母。
___________________________________________________________________
程序源代码:
#include <stdio.h>
void main()
{
char letter;
printf("please input the first letter of someday\n");
while ((letter=getch())!='Y') /*当所按字母为Y时才结束*/
{
switch (letter)
{
case 'S':printf("please input second letter\n");
if((letter=getch())=='a')
printf("saturday\n");
else if ((letter=getch())=='u')
printf("sunday\n");
else printf("data error\n");
break;
case 'F':printf("friday\n");break;
case 'M':printf("monday\n");break;
case 'T':printf("please input second letter\n");
if((letter=getch())=='u')
printf("tuesday\n");
else if ((letter=getch())=='h')
printf("thursday\n");
else
printf("data error\n");
break;
case 'W':printf("wednesday\n");break;
default: printf("data error\n");
}
}
}
题目:求100之内的素数(质数)
___________________________________________________________________
程序源代码:
#include <stdio.h>
int main()
{
int i, j, match;
for (i = 2; i <= 100; i++) {
match = 1;
for (j = 2; j < i; j++) {
if (i % j == 0) {
match = 0;
break;
}
}
if (match) {
printf("%d\n", i);
}
}
return 0;
}
题目:对10个数进行排序
___________________________________________________________________
程序分析:可以利用选择法,即从后9个比较过程中,选择一个最小的与第一个
元素交换,下次类推,即用第二个元素与后8个进行比较,并进行交换。
解法一,选择排序法:
程序源代码:
#include <stdio.h>
int main(void)
{
int buf[10];
int i, j, temp;
for(i = 0; i < 10; i++) {
scanf("%d", &buf[i]);
}
for (i = 0; i < 9; i++) {
for(j = i + 1; j < 10; j++) {
if (buf[i] > buf[j]) {
temp = buf[i];
buf[i] = buf[j];
buf[j] = temp;
}
}
}
for (i = 0; i < 10; i++) {
printf("%d ", buf[i]);
}
return 0;
}
解法二,冒泡排序法
#include <stdio.h>
int main(void)
{
int buf[10];
int i, j, temp;
for (i = 0; i < 10; i++) {
scanf("%d", &buf[i]);
}
for (i = 0; i < 9; i++) {
for (j = 0; j < 10 - 1 - i; j++) {
if (buf[j] > buf[j+1]) {
temp = buf[j];
buf[j] = buf[j+1];
buf[j+1] = temp;
}
}
}
for (i = 0; i < 10; i++) {
printf("%d ", buf[i]);
}
return 0;
}
题目:求一个3*3矩阵对角线元素之和
___________________________________________________________________
程序分析:利用双重for循环控制输入二维数组,再将a累加后输出。
___________________________________________________________________
程序源代码:
#include <stdio.h>
int main()
{
int a[3][3],i,t;
for(i=0;i<3;i++)
for(t=0;t<3;t++)
scanf("%d",&a[i][t]);
printf("%d %d",a[0][0]+a[1][1]+a[2][2],a[0][2]+a[1][1]+a[2][0]);
return 0;
}
题目:有一个已经排好序的数组。现输入一个数,要求按原来的规律将它插入数
组中。
___________________________________________________________________
程序分析:首先判断此数是否大于最后一个数,然后再考虑插入中间的数的情况
,插入后此元素之后的数,依次后移一个位置。
___________________________________________________________________
程序源代码:
#include <stdio.h>
int main()
{
int a[11]={1,4,6,9,13,16,19,28,40,100};
int number,i,j;
printf("original array is:\n");
for(i=0;i<10;i++)
printf("%5d",a[i]);
printf("\n");
printf("insert a new number:");
scanf("%d",&number);
for(i = 0; i < 10; i++) {
if(a[i] > number) {
for(j = 9; j >= i; j--) {
a[j + 1] = a[j];
}
a[i] = number;
break;
}
}
for(i = 0; i < 11; i++)
printf("%6d",a[i]);
return 0;
}
题目:将一个数组逆序输出。
___________________________________________________________________
程序分析:用第一个与最后一个交换。
___________________________________________________________________
程序源代码:
#include <stdio.h>
int main(void)
{
int buf[1024];
int reverse[1024];
int count = 0, i;
while(scanf("%d", &buf[count]) != EOF) {
count++;
if (count >= 1024) {
printf("buffer full\n");
break;
}
}
for (i = 0; i < count; i++) {
reverse[i] = buf[count - 1 - i];
}
for (i = 0; i < count; i++) {
printf("%d ", reverse[i]);
}
printf("\n");
return 0;
}
题目:学习使用按位与 & 。
___________________________________________________________________
程序分析:0&0=0; 0&1=0; 1&0=0; 1&1=1
___________________________________________________________________
程序源代码:
#include "stdio.h"
main()
{
int a,b;
a=077;
b=a&3;
printf("\40: The a & b(decimal) is %d \n",b);
b&=7;
printf("\40: The a & b(decimal) is %d \n",b);
}
题目:学习使用按位或 | 。
___________________________________________________________________
程序分析:0|0=0; 0|1=1; 1|0=1; 1|1=1
___________________________________________________________________
程序源代码:
#include "stdio.h"
main()
{
int a,b;
a=077;
b=a|3;
printf("\40: The a & b(decimal) is %d \n",b);
b|=7;
printf("\40: The a & b(decimal) is %d \n",b);
}
题目:学习使用按位异或 ^ 。
___________________________________________________________________
程序分析:0^0=0; 0^1=1; 1^0=1; 1^1=0
___________________________________________________________________
程序源代码:
#include "stdio.h"
main()
{
int a,b;
a=077;
b=a^3;
printf("\40: The a & b(decimal) is %d \n",b);
b^=7;
printf("\40: The a & b(decimal) is %d \n",b);
}
题目:取一个整数a从右端开始的4~7位。
___________________________________________________________________
程序分析:可以这样考虑:
(1)先使a右移4位。
(2)设置一个低4位全为1,其余全为0的数。可用~(~0<<4)
(3)将上面二者进行&运算。
___________________________________________________________________
程序源代码:
main()
{
unsigned a,b,c,d;
scanf("%o",&a);
b=a>>4;
c=~((~0)<<4);
d=b&c;
printf("%o\n%o\n",a,d);
}
题目:学习使用按位取反~。
___________________________________________________________________
程序分析:~0=1; ~1=0;
___________________________________________________________________
程序源代码:
#include "stdio.h"
main()
{
int a,b;
a=234;
b=~a;
printf("\40: The a's 1 complement(decimal) is %d \n",b);
a=~a;
printf("\40: The a's 1 complement(hexidecimal) is %x \n",a);
}