为了账号安全,请及时绑定邮箱和手机立即绑定

走过路过,不要错过

#include <stdio.h>
int main(){         
    int sum = 0;  //定义计算结果变量sum    
    int i = 1;    //定义循环数字变量i    
    //使用while循环    
     while(i<=100){        
         if(i%2==0){            
         sum -= i;
         }else{
             sum +=i;
         }        
         i++;
         }    
    return 0;
 }

请问,我的这种算法在时间复杂度上和老师给的例题一样吗?

正在回答

3 回答

#include <stdio.h>

int main()

{

    /* 小伙伴们:

           选择你们认为最合理的循环结构完成功能吧 */

    int sum = 0;  //定义计算结果变量sum

    int i = 1;    //定义循环数字变量i

    int flag = 1; //定义符号状态变量flag

    

    //使用while循环

    while(i<=100)

    {

        if(flag % 2 != 0)

        {

            sum += i;

        }

        else if( flag % 2 == 0 )

        {

            sum -= i;

        }

        i++;

        flag++;

    }

    printf("sum=%d\n",sum); 

    

    i = 1;  //重新初始化变量i

    sum = 0;

    flag =1;

    //do-while循环

    do{


        if(flag % 2 != 0)

        {

            sum += i;

        }

        else if( flag % 2 == 0 )

        {

            sum -= i;

        }

        i++;

        flag++;

    }while(i<=100);

    printf("sum=%d\n",sum); 

    

    i = 1;  //重新初始化变量i

    sum = 0;

    flag =1;

    

    //使用for循环

    for(i=1;i<=100;i++)

    {


        if(flag % 2 != 0)

        {

            sum += i;

        }

        else if( flag % 2 == 0 )

        {

            sum -= i;

        }

        flag++;

    }  

    printf("sum=%d\n",sum); 

    

    return 0;    

}


0 回复 有任何疑惑可以回复我~

嗯 都是O(n)

0 回复 有任何疑惑可以回复我~

不太清楚

0 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消
C语言入门
  • 参与学习       926299    人
  • 解答问题       20799    个

C语言入门视频教程,带你进入编程世界的必修课-C语言

进入课程

走过路过,不要错过

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信