码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 2.求循环小数


    题目

    对于任意的真分数 N/M ( 0 < N < M ),均可以求出对应的小数。如果采用链表表示各个小数,对于循环节采用循环链表表示,则所有分数均可以表示为如下链表形式。

    输入: N M

    输出: 转换后的小数(不超过 50 )

    要求: 仅编写将分数转换为小数的函数 change( int n, int m, NODE * head ) 。


    C完整代码

    1. #include
    2. #include
    3. typedef struct node
    4. {
    5. int data;
    6. struct node* next;
    7. } NODE;
    8. void change(int n, int m, NODE* head)
    9. {
    10. NODE* current = head; // 当前节点指针,初始指向头节点
    11. for (int i = 1; i <= 50; i++) // 循环50次,最多插入50个节点
    12. {
    13. if (n == 0) // 如果被除数为0,则退出循环
    14. {
    15. break;
    16. }
    17. else
    18. {
    19. n = n * 10; // 将被除数乘以10,以便获取下一个商
    20. int quotient = n / m; // 计算商
    21. n = n % m; // 计算余数
    22. NODE* newNode = (NODE*)malloc(sizeof(NODE)); // 创建新节点
    23. newNode->data = quotient; // 将商存储在新节点的数据域中
    24. current->next = newNode; // 将新节点连接到当前节点的后面
    25. current = newNode; // 将当前节点指针移动到新节点
    26. }
    27. }
    28. current->next = NULL; // 将最后一个节点的next指针置为NULL,表示链表结束
    29. }
    30. void output(NODE* head)
    31. {
    32. int k = 0;
    33. printf("0.");
    34. while (head->next != NULL && k < 50)
    35. {
    36. printf("%d", head->next->data);
    37. head = head->next;
    38. k++;
    39. }
    40. printf("\n");
    41. }
    42. int main()
    43. {
    44. int n, m;
    45. NODE* head;
    46. scanf("%d%d", &n, &m);
    47. head = (NODE*)malloc(sizeof(NODE));
    48. head->next = NULL;
    49. head->data = -1;
    50. change(n, m, head);
    51. output(head);
    52. // 释放动态分配的内存空间
    53. NODE* current = head;
    54. while (current != NULL) {
    55. NODE* temp = current;
    56. current = current->next;
    57. free(temp);
    58. }
    59. return 0;
    60. }

  • 相关阅读:
    Redis中的BigKey如何发现和处理
    云原生之容器化:Docker三剑客之Docker Compose
    访问Apache Tomcat的manager页面
    多御安全浏览器宝藏功能全新升级,建议低调使用
    docker下快速部署openldap与self-service-password
    HTTP协议初相识:了解HTTP协议
    分割集合list成为多个子list
    手把手教你定位线上MySQL慢查询问题,包教包会
    Elasticsearch-Rest风格
    小程序使用echarts(超详细教程)
  • 原文地址:https://blog.csdn.net/m0_74200772/article/details/132995056
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号