• C语言 牛客网习题 10.20 day2


    1.求最小公倍数
    正整数A和正整数B 的最小公倍数是指 能被A和B整除的最小的正整数值,设计一个算法,求输入A和B的最小公倍数。
    1≤a, b≤100000
    输入描述:
    输入两个正整数A和B。
    输出描述:
    输出A和B的最小公倍数。

    1. #include
    2. int main() {
    3. int a, b;
    4. while (scanf("%d %d", &a, &b) != EOF) { // 注意 while 处理多个 case
    5. // 64 位输出请用 printf("%lld") to
    6. int i = 0;
    7. int min = 0;
    8. min = a > b ? b : a;
    9. for (i = min; i <= a * b; i++)
    10. {
    11. if (i % a == 0 && i % b == 0)
    12. {
    13. printf("%d\n", i);
    14. break;
    15. }
    16. }
    17. }
    18. return 0;
    19. }

    2.求解立方根
    计算一个浮点数的立方根,不使用库函数。
    保留一位小数。
    输入描述:
    待求解参数,为double类型(一个实数)
    输出描述:
    输出参数的立方根。保留一位小数。

    1. #include
    2. int main()
    3. {
    4. double n, m;
    5. double i = 0;
    6. scanf("%lf", &n);
    7. if (n > 0)
    8. {
    9. while (i * i * i < n)
    10. {
    11. i = i + 0.01;
    12. }
    13. printf("%.1lf", i);
    14. }
    15. else
    16. {
    17. m = -n;
    18. while (i * i * i < m)
    19. {
    20. i = i + 0.01;
    21. }
    22. printf("%.1lf", -i);
    23. }
    24. }

    3.字符逆序
    将一个字符串str的内容颠倒过来,并输出。
    数据范围:
    1~10000
    1≤len(str)≤10000
    输入描述:
    输入一个字符串,可以有空格
    输出描述:
    输出逆序的字符串

    1. #include
    2. #include
    3. int main()
    4. {
    5. char str[10001];
    6. gets(str); //得到一个字符串 scanf遇到空格会跳过
    7. for (int i = strlen(str) - 1; i >= 0; i--) {//strlen函数求字符串长度 头文件string.h
    8. printf("%c", str[i]);
    9. }
    10. return 0;
    11. }

    4.删除公共字符
    输入两个字符串,从第一字符串中删除第二个字符串中所有的字符。例如,输入”They are students.”和”aeiou”,
    则删除之后的第一个字符串变成”Thy r stdnts.”输入描述\n输入包含2个字符串。输出描述\n输出删除后的字符串。

    输入:They are students.

    输出:Thy r stdnts.

    1. int judge(char ch, char arr[])
    2. {
    3. int i = 0;
    4. while (arr[i])
    5. {
    6. if (ch == arr[i])
    7. {
    8. return 1;
    9. }
    10. i++;
    11. }
    12. return 0;
    13. }
    14. int main()
    15. {
    16. char arr1[101] = { 0 };
    17. gets(arr1);//取字符串包括空格
    18. char arr2[101] = { 0 };
    19. gets(arr2);
    20. int i = 0;
    21. while (arr1[i])
    22. {
    23. if (judge(arr1[i], arr2) == 0)
    24. {
    25. printf("%c", arr1[i]);
    26. }
    27. i++;
    28. }
    29. return 0;
    30. }

    5.添加逗号
    对于一个较大的整数N(1<=N<=2,000,000,000)比如980364535,
    我们常需要一位一位数这个数字是几位数,但是如果在这个数字每三位加一个逗号,他会变得更加易于朗读
    因此,这个数字加上逗号称以下模样:980,364,535请写一个程序帮她完成这件事

    输入描述:一行一个整数N

    输出描述:一行一个字符串表示添加完逗号的结果

    方法:取模得一个数,除去掉一个数

    1. int main()
    2. {
    3. char arr[14] = { 0 };
    4. int N = 0;
    5. scanf("%d", &N);
    6. int k = 0;
    7. int i = 0;
    8. while (N)
    9. {
    10. if (k != 0 && k % 3 == 0)
    11. {
    12. arr[i++] = ',';
    13. }
    14. arr[i++] = N % 10 + '0';
    15. N /= 10;
    16. k++;
    17. }
    18. for (i = i - 1; i >= 0; i--)
    19. {
    20. printf("%c", arr[i]);
    21. }
    22. return 0;
    23. }
  • 相关阅读:
    Python 基础(二):搭建 Python 开发环境
    算法设计(动态规划应用实验报告)实现基于贪婪技术思想的Prim算法、Dijkstra算法
    PHP连接外部服务器的MySQL参考教程
    Day981.OAuth 2.0的工作流程与安全问题 -OAuth 2.0
    诞生在 KFC 的《开源之迷》:作者如何在嘈杂而开放的环境中进行创作
    软考-信息安全工程师-2
    2022年DCMM认证全国各地补贴政策汇总
    OceanBase基础架构
    VueRouter与expres/koa中间件的关联
    [附源码]Python计算机毕业设计二手书交易软件设计与实现
  • 原文地址:https://blog.csdn.net/m0_73983707/article/details/133939280