c语言:输入一个字符串(字符串长度不超过80),对其作如下处理;

2019-12-24  本文已影响0人  小小小蚍蜉
#include <stdio.h>
    #include <math.h>
    #include <string.h>
    #define strMax 80
    #define LENGTH(s) (sizeof(s) / sizeof(int))

int main(int argc, char *argv[]) {
    
    char str1[strMax] = {0};//存储输入的字符串
    
    for(int i=0; i<strMax;i++){
        scanf("%s",str1);
        if (getchar() == '\n') {
            break;
        }
    }
    
    printf("输入---的字符串是%s\n",str1);
    
    int m = 0; //记录输入的符合要求的有效字符数量
    long decimal = 0; //十进制
    int octal[strMax] = {0}; //八进制
    
    char str2[strMax] = {0}; //存储新的字符串
    
    for(int j=0;j<strlen(str1);j++) //遍历string
    {
        //    c语言 ASCII码中,A~Z:65-90, a~z:97-122(分别一一对应)
        //    这个地方尽量用某字符串是否包含方式去过滤   某字符串是"0123456789abcdef"  包含的string函数忘了 自己查下
        
        switch(str1[j])
        {
            case '0':
            case '1':
            case '2':
            case '3':
            case '4':
            case '5':
            case '6':
            case '7':
            case '8':
            case '9':
            case 'a':
            case 'b':
            case 'c':
            case 'd':
            case 'e':
            case 'f':
                
                str2[m] = str1[j];
                m += 1;
                
                break;
            default: break;
        }
    }
    
    printf("过滤后的字符串是%s\n", str2);
    
    //    采用倒序遍历,从末位开始读取字符计算
    for(int i = strlen(str2)-1; i >= 0; i--) {
        
        int temp0X = 0;
        switch(str2[i]) {
            case '0':
                temp0X = 0;
                
                break;
            case '1':
                temp0X = 1;
                
                break;
            case '2':
                temp0X = 2;
                
                break;
            case '3':
                temp0X = 3;
                
                break;
            case '4':
                temp0X = 4;
                
                break;
            case '5':
                temp0X = 5;
                
                break;
            case '6':
                temp0X = 6;
                
                break;
            case '7':
                temp0X = 7;
                
                break;
            case '8':
                temp0X = 8;
                
                break;
            case '9':
                temp0X = 9;
                
                break;
                
            case 'a':
                temp0X = 10;
                break;
            case 'b':
                temp0X = 11;
                break;
                
            case 'c':
                temp0X = 12;
                break;
                
            case 'd':
                temp0X = 13;
                break;
            case 'e':
                temp0X = 14;
                break;
            case 'f':
                temp0X = 15;
                break;
            default://也可以不用这个default 因为此字符串都是已经过滤好的必须是上述case对应字符中的一个,加上较好,也可不加
                break;
        }
        
        // 【strlen(str2)-1 -i】 表示16的次幂数 十六进制0xa123用十进制表示为 3 + 2 * 16 + 1 * 16 * 16 = 3 * pow(16,0) + 2 * pow(16,1) + 3 * pow(16, 2) + 10 * pow(16,3)
        decimal += temp0X * pow(16.0, strlen(str2)-1 -i);
    }
    
    printf("十进制%ld \n", decimal);
    //    以8进制计算 用十进制数decimal每次取余的数放在octal整型数组上作为八进制形式某位数字,用decimal接收decimal除以8的结果,循环相除,循环结束的结果整型数组octal即是我们求取的倒序的八进制形式
    int n  = 0;
    while(decimal % 8 != 0) {
        
        octal[n] = decimal % 8;
        printf("第%d个数:%d\n", n, octal[n]);
        decimal = decimal / 8;
        n++;
    }
    //    创建一个数组,数组长度是octal数组的长度strlen(octal)  也可用strMax表示 对于测试内存开销不影响
    char octalStr[strMax] = {0};
    octalStr[0] = 0;
   //八进制必须以数字0开头
    //    对上面的倒序的八进制形式数组octal 进行高低位翻转
    
    printf("八进制0");

    for(int x = n+1; x >= 0; x--) {
        printf("%d", octal[x]);
    }
    printf("\n");
    
    
    printf("\n打印结束\n");
    return 1;
}

欢迎和谢谢指正细节!

上一篇 下一篇

猜你喜欢

热点阅读