C++数据结构和算法分享专题

7_循环语句

2018-03-02  本文已影响0人  编程半岛

关键词:循环语句分析、do...while循环、while循环、for循环

1. 循环语句分析

2. do...while循环

do...while循环

3. while循环

while循环

4. for循环

for循环

5. 三种循环的使用对比

#include <stdio.h>

int f1(int n)
{
    int ret = 0;
    
    if( n > 0 )
    {
        do
        {
            ret += n;
            n--;
        }
        while(n>0);
    }
    return ret;
}

int f2(int n)
{
    int ret = 0;
    
    while( n > 0 )
    {
        ret += n;
        n--;
    }
    
    return ret;
}

int f3(int n)
{
    int ret = 0;
    
    for(int i=1; i<=n; i++)
    {
        ret += i;
    }
    
    return ret;
}

int main()
{
    printf("%d\n", f1(100));
    printf("%d\n", f2(100));
    printf("%d\n", f3(100));
    
    return 0;
}

6. breakcontinue的区别

#include <stdio.h>

void f1(int n)
{
    int i = 0;
    
    for(i=1; i<=n; i++)
    {
        if( (i % 2) == 0 )
        {
            break;
        }
        
        printf("%d ", i);
    }

    printf("\n");
}

void f2(int n)
{
    int i = 0;
    
    for(i=1; i<=n; i++)
    {
        if( (i % 2) == 0 )
        {
            continue;
        }

        printf("%d ", i);
    }

    printf("\n");
}

int main()
{
    f1(10);
    f2(10);

    return 0;
}

输出结果:

1 
1 3 5 7 9

7. dobreak的妙用

一般写法:

#include <stdio.h>
#include <malloc.h>

int func(int n)
{
    int ret = 0;
    int* p = (int*)malloc(sizeof(int) * n);
    
    if(NULL == p)
    {
        return ret;
    }
    
    if(n < 5)
    {
        return ret;
    }
    
    if(n > 100) 
    {
        return ret;
    }
    
    for(int i=0; i<n; i++)
    {
        p[i] = i;
        printf("%d\n", p[i]);
    }
    
    ret = 1;
    
    printf("free(p)");
    
    free(p);    
    
    return ret;
}

int main()
{
    if( func(4) )
    {
        printf("OK\n");
    }
    else
    {
        printf("ERROR\n");
    }

    return 0;
}

输出结果:

ERROR

总结:这种写法当满足if条件时,函数直接return,而没有free(p),因此会导致内存泄漏。可以使用dobreak结合使用。修改代码如下:

#include <stdio.h>
#include <malloc.h>

int func(int n)
{
    int ret = 0;
    int* p = (int*)malloc(sizeof(int) * n);
    
    // 使用 do 和 break,保证free(p)一定可以执行
    do
    {
        if(NULL == p) break;
    
        if(n < 5) break;
    
        if(n > 100) break;
    
        for(int i=0; i<n; i++)
        {
            p[i] = i;
            printf("%d\n", p[i]);
        }
    
        ret = 1;
    }while(0);
    
    printf("free(p)\n");
    
    free(p);    
    
    return ret;
}

int main()
{
    if( func(4) )
    {
        printf("OK\n");
    }
    else
    {
        printf("ERROR\n");
    }

    return 0;
}

输出结果:

free(p)
ERROR

8. 小结

声明:此文章为本人在学习狄泰软件学院《C语言深度解析》所做的笔记,文章中包含狄泰软件资料内容一切版权归狄泰软件所有!

上一篇下一篇

猜你喜欢

热点阅读