问题

来源:互联网 发布:算法的复杂性分为 编辑:程序博客网 时间:2024/05/20 15:10

//3. (****)有一段文本,将文本中的所有单词,存放到一个字符串数组中。 (要求占用内存最少)

    

    char *array ="There are 5 sb in my class, one of them is yy!";//定义一个字符串数组,写一段文本

   printf("%s\n", array);//打印数组测试后面结果

   char *temp = array;//定义一个指针用来后面的循环遍历操作

    int sum1 =0;//定义两个累加器 sum1array的长度

    int sum2 =0;//sum2dest的长度

    //循环得出array长度

   while (*temp != '\0') {

            sum1++;

            temp++;

    }

   printf("%d\n", sum1);

    temp = array;

    //循环得出dest长度

   while (*temp != '\0') {

       if (((*temp >= 'A') && (*temp <='Z')) || ((*temp >= 'a') && (*temp <= 'z'))) {

            sum2++;

            

        }

        temp++;

    }

   printf("%d\n", sum2);

    //定义一个dest字符串数组存储所有单词

    

   int sum3 = 0;//jdest的下标

    

    temp = array;

   while (*temp != '\0') {

       if (((*temp < 'A') || ((*temp >'Z') && (*temp < 'a')) || (*temp >'z')) && (((*(temp + 1) >= 'A') && (*(temp + 1) <= 'Z')) || ((*(temp + 1) >= 'a') && (*(temp + 1) <= 'z')))) {

            sum3++;

        }

        temp++;

    }

   int sum4 = sum3 + 1;

   printf("%d\n", sum4);

    sum3 =0;

   int sum5 = 0;

   char **dest = malloc(sizeof(char) * sum2 + sum4);

    

   for (int i =0; i < sum1; i++) {

       if (((array[i] < 'A') || ((array[i] >'Z') && (array[i] < 'a')) || (array[i] > 'z')) && (((array[i +1] >= 'A') && (array[i +1] <= 'Z')) || ((array[i +1] >= 'a') && (array[i +1] <= 'z')))) {

            sum3++;

            sum5 =0;

        }elseif((((array[i] >= 'A') && (array[i] <= 'Z')) || ((array[i] >='a') && (array[i] <= 'z')))){

        

            dest[sum3][sum5] = array[i];

            sum5++;

        }

    }


0 0
原创粉丝点击