ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

【PAT乙级】1101 B是A的多少倍 (15 分) C语言实现

2022-05-26 09:32:08  阅读:133  来源: 互联网

标签:10 arr 15 target int double len C语言 1101


题目:

1101 B是A的多少倍

代码实现:

  1. 解法一
#include <stdio.h>
#include <string.h>

int main() {
    char arr[11];
    int d;
    if (scanf("%s %d", arr, &d) == 2) {
        // 数组的长度
        int len = strlen(arr);

        // 将 arr 转为整数 a
        int a = 0;
        for (int i = 0; i < len; i++) {
            a = a * 10 + (arr[i] - '0');
        }

        // 根据给定的数目,翻转数组
        char target[11];
        int j = 0;
        for (int i = len - d; i < len; i++) {
            target[j++] = arr[i];
            arr[i] = '\0';
        }
        target[j] = '\0';

        // 连接两个数组,组成目标数组
        strcat(target, arr);

        // 将 target 转为整数 b
        int b = 0;
        for (int i = 0; i < len; i++) {
            b = b * 10 + (target[i] - '0');
        }

        double f = (double) b / a;
        printf("%.2f\n", f);
    }

    return 0;
}

/*
    字符串转整数:
    使用 stdlib.h 库中的 atoi 函数:
    C 库函数 int atoi(const char *str) 把参数 str 所指向的字符串转换为一个整数(类型为 int 型)。

    // 将 arr 转为整数 a
    int a = atoi(arr);
*/
  1. 解法二
#include <stdio.h>

int main() {
    int a, d;
    if (scanf("%d %d", &a, &d) == 2) {
        // 获取 a 里面中 d 位的数
        int n = 1;
        for (int i = 0; i < d; i++) {
            n = n * 10;
        }
        int b = a % n;
        int a1 = a / n;

        // 生成新的数 b
        int t = a1;
        while (t != 0) {
            t = t / 10;
            b = b * 10;
        }
        b = b + a1;

        // double f = (double) b / a;
        double f = b * 1.0 / a;
        printf("%.2f\n", f);
    }

    return 0;
}

标签:10,arr,15,target,int,double,len,C语言,1101
来源: https://www.cnblogs.com/wanghuizhao/p/16312229.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有