当前位置:   article > 正文

十一、作业

十一、作业
1.从大到小输出

写代码将三个整数数按从大到小输出。

  1. void Swap(int* px, int* py)
  2. {
  3. int tmp = *px;
  4. *px = *py;
  5. *py = tmp;
  6. }
  7. int main()
  8. {
  9. int a = 0;
  10. int b = 0;
  11. int c = 0;
  12. scanf("%d %d %d", &a, &b, &c);
  13. int n = 0;
  14. if (a<b)
  15. {
  16. Swap(&a, &b);
  17. }
  18. if (a < c)
  19. {
  20. Swap(&a, &c);
  21. }
  22. if (b < c)
  23. {
  24. Swap(&b, &c);
  25. }
  26. printf("%d %d %d\n", a, b, c);
  27. return 0;
  28. }
2.打印3的倍数的数

写一个代码打印1-100之间所有3的倍数的数字

  1. int main()
  2. {
  3. int i = 0;
  4. for ( i = 1; i <=100; i++)
  5. {
  6. if (i%3==0)
  7. {
  8. printf("%d ", i);
  9. }
  10. }
  11. return 0;
  12. }
  1. int main()
  2. {
  3. int i = 0;
  4. for (i = 3; i <= 100; i+=3)
  5. {
  6. printf("%d ", i);
  7. }
  8. return 0;
  9. }
3.最大公约数

给定两个数,求这两个数的最大公约数

  1. //暴力求解法
  2. int main()
  3. {
  4. int a = 0;
  5. int b = 0;
  6. scanf("%d %d", &a, &b);
  7. int min = (a < b) ? a : b;
  8. int m = min;
  9. while (1)
  10. {
  11. if (a%m==0 && b%m==0)
  12. {
  13. break;
  14. }
  15. m--;
  16. }
  17. printf("%d\n", m);
  18. return 0;
  19. }

  1. //辗转相除法
  2. int main()
  3. {
  4. int a = 0;
  5. int b = 0;
  6. int c = 0;
  7. scanf("%d %d", &a, &b);
  8. while (c=a%b)
  9. {
  10. a = b;
  11. b = c;
  12. }
  13. printf("%d\n", b);
  14. return 0;
  15. }

最小公倍数=a*b/最大公约数。

4.打印闰年

打印1000年到2000年之间的闰年

  1. int main()
  2. {
  3. int i = 0;
  4. for ( i = 1000; i <=2000; i++)
  5. {
  6. if ((i%4==0 && i%100 !=0) || (i%400==0))
  7. {
  8. printf("%d ", i);
  9. }
  10. }
  11. return 0;
  12. }
5.二分查找

编写代码在一个整形有序数组中查找具体的某个数

要求:找到了就打印数字所在的下标,找不到则输出:找不到。

  1. //二分查找
  2. //
  3. //编写代码在一个整形有序数组中查找具体的某个数
  4. //
  5. //要求:找到了就打印数字所在的下标,找不到则输出:找不到。
  6. int main()
  7. {
  8. int arr[10] = {1,2,3,4,5,6,7,8,9,10};
  9. int k = 7;
  10. int sz = sizeof(arr) / sizeof(arr[0]);
  11. int left =0;
  12. int right = sz-1;
  13. while (right>=left)
  14. {
  15. int mid = (right - left) / 2 + left;
  16. if (arr[mid]<k)
  17. {
  18. left = mid + 1;
  19. }
  20. else if (arr[mid] > k)
  21. {
  22. right = mid - 1;
  23. }
  24. else
  25. {
  26. printf("找到了下标为:%d\n", mid);
  27. break;
  28. }
  29. }
  30. if (right<left)
  31. {
  32. printf("找不到");
  33. }
  34. return 0;
  35. }
6.数9的个数

编写程序数一下 1到 100 的所有整数中出现多少个数字9

  1. int main()
  2. {
  3. int i = 0;
  4. int count = 0;//计数
  5. for ( i = 1; i <=100; i++)
  6. {
  7. //判断个位是不是9
  8. if (i % 10 == 9)
  9. count++;
  10. //判断十位是不是9
  11. //因为有99两个9需要判断两次,不能用else if
  12. if (i / 10 == 9)
  13. count++;
  14. }
  15. printf("%d\n", count);
  16. return 0;
  17. }
7.分数求和

计算1/1-1/2+1/3-1/4+1/5 …… + 1/99 - 1/100 的值,打印出结果

  1. int main()
  2. {
  3. int i = 0;
  4. double sum = 0;
  5. int flag = 1;
  6. for ( i = 1; i <=100; i++)
  7. {
  8. sum=sum+flag*(1.0 / i);
  9. flag = -flag;
  10. }
  11. printf("%lf\n", sum);
  12. return 0;
  13. }
8.求最大值

求10 个整数中最大值

  1. int main()
  2. {
  3. int arr[10] = {1,2,3,4,5,6,7,8,9,10};
  4. int i = 0;
  5. int max = arr[0];
  6. for ( i = 1; i <10; i++)
  7. {
  8. if (arr[i]>max)
  9. max = arr[i];
  10. }
  11. printf("最大的数值是:%d\n", max);
  12. return 0;
  13. }

  1. int main()
  2. {
  3. int arr[10] = {0};
  4. int i = 0;
  5. for ( i = 0; i < 10; i++)
  6. {
  7. scanf("%d", &arr[i]);
  8. }
  9. int max = arr[0];
  10. for ( i = 1; i <10; i++)
  11. {
  12. if (arr[i]>max)
  13. max = arr[i];
  14. }
  15. printf("最大的数值是:%d\n", max);
  16. return 0;
  17. }
9.乘法口诀表

在屏幕上输出9*9乘法口诀表

%2d - 右对齐

%-2d - 左对齐

/t - tab

  1. //乘法口诀表
  2. //
  3. //在屏幕上输出9 * 9乘法口诀表
  4. int main()
  5. {
  6. int i = 0;
  7. //打印9
  8. for ( i = 1; i <=9; i++)
  9. {
  10. //打印一行
  11. int j = 0;
  12. for ( j = 1; j<=i; j++)
  13. {
  14. printf("%d*%d=%-2d ", i, j, i * j);
  15. }
  16. printf("\n");
  17. }
  18. return 0;
  19. }
10.乘法口诀表(行列自己指定)
  1. //乘法口诀表
  2. //
  3. //行列自己指定
  4. void print_table(int n)
  5. {
  6. int i = 0;
  7. //打印9
  8. for ( i = 1; i <=n; i++)
  9. {
  10. //打印一行
  11. int j = 0;
  12. for ( j = 1; j<=i; j++)
  13. {
  14. printf("%d*%d=%-2d ", i, j, i * j);
  15. }
  16. printf("\n");
  17. }
  18. }
  19. int main()
  20. {
  21. int n = 0;
  22. scanf("%d", &n);
  23. print_table(n);
  24. return 0;
  25. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/799527
推荐阅读
相关标签
  

闽ICP备14008679号