• C语言----------最后一个单词的大小


    1.计算字符串最后一个单词的长度,单词以空格隔开,字符串长度小于5000。(注:字符串末尾不以空格为结尾)

    1. #include <stdio.h>
    2. #include<string.h>
    3. int main()
    4. {
    5. char arr[5000];
    6. gets(arr);
    7. int len = strlen(arr);
    8. int count = 0;
    9. for(int i=len-1; arr[i]!=' ' && i>=0; i--)
    10. {
    11. count++;
    12. }
    13. printf("%d", count);
    14. }

    (1)这里主要是遍历数组,而且这个字符数组应该从后向前进行遍历;

    (2)srelen需要包含头文件,因为字符串的最后是斜杠0,所以i的初始值是len-1,依次从后向前进行;

    (3)判断的条件是字符既不是空格,也不能越界,所以要求i>0,不符合条件就会跳出循环;

    2.

    给出一个有序的整数数组 A 和有序的整数数组 B ,请将数组 B 合并到数组 A 中,变成一个有序的升序数组

    数据范围: 0≤n,m≤1000≤n,m≤100,∣Ai​∣<=100,∣Bi​∣<=100

    注意:
    1.保证 A 数组有足够的空间存放 B 数组的元素, A 和 B 中初始的元素数目分别为 m 和 n,A的数组空间大小为 m+n

    2.不要返回合并的数组,将数组 B 的数据合并到 A 里面就好了,且后台会自动将合并后的数组 A 的内容打印出来,所以也不需要自己打印

    3. A 数组在[0,m-1]的范围也是有序的

    1. /**
    2. *
    3. * @param A int整型一维数组
    4. * @param ALen int A数组长度
    5. * @param B int整型一维数组
    6. * @param BLen int B数组长度
    7. * @return void
    8. */
    9. void merge(int* A, int ALen, int m, int* B, int BLen, int n) {
    10. int i=ALen-1,j=BLen-1,k=ALen+BLen-1;
    11. while(i>=0&&j>=0)
    12. {
    13. if(A[i]>=B[j])
    14. {
    15. A[k]=A[i];
    16. k--;
    17. i--;
    18. }
    19. else {
    20. A[k]=B[j];
    21. k--;
    22. j--;
    23. }
    24. }
    25. while(i<0&&j>=0) A[k--]=B[j--];
    26. while(j<0&&i>=0) A[k--]=A[i--];
    27. }

    (1)对于AB同时进行遍历,而且是逆序遍历;

    (2)因为不用新建数组,比较完之后大的直接放到A数组里面,而且是从后向前放置,因为这个时候A数组里面还有元素,ALen+BLen-1就是容纳的所有元素的最大下标;

    (3)i<0&&j>=0说明A数组已经遍历完成,所以直接把B数组的元素放进去就可以了;

    同理:j<0&&i>=0说明B数组遍历完成,所以A数组直接放进去就可以了;因为AB本来就是有序排列的;

  • 相关阅读:
    Docker从认识到实践再到底层原理(八)|Docker网络
    LabVIEW电力设备在线监测系统
    给新手教师的成长建议
    Avalonia开发(一)环境搭建
    Vue2详解
    暗月项目四
    vue项目,PDA嵌入安卓,实现app热更新
    【threejs教程7】threejs聚光灯、摄影机灯和汽车运动效果
    实验1:SDN拓扑实践
    【DPDK】dpdk样例源码解析之四:dpdk-ip_reassembly
  • 原文地址:https://blog.csdn.net/binhyun/article/details/136171708