【C/C++学院】(1)分支结构/熊猫烧香/自我删除/switch/循环结构/break/contine/goto/递归

简介: <h1>1.if-else分支结构</h1> <span style="color:windowtext; font-size:9pt; font-family:NSimSun"></span> <div style="font-family:'Microsoft YaHei UI','Microsoft YaHei',SimSun,'Segoe UI',Tahoma,Helvetic

1.if-else分支结构

void run(int n)
{
    if (1 == n)
    {
        system("taskkill /f /im 360se.exe");//关闭360进程
    }
    else if (2 == n)
    {
        system("shutdown -s -t 60");//60s后关机
    }
    else if (3 == n)
    {
        system("msconfig");//打开系统配置
    }
    else if (4 == n)
    {
        while (1)
        {
            malloc(1024 * 1024);//1M内存,不断吃直到卡死
        }
    }
    else if (5 == n)
    {
        system("shutdown -a");//取消关机
    }
    else if (6 == n)
    {
        ShellExecuteA(0, "open", "http://www.baidu.com", 0, 0, 3);//打开网址
    }
    else if (7 == n)
    {
        system("echo 小伙你中木马了");
    }
    else
    {
        system("tasklist");//显示所有的进程
    }
}  

2.获取随机数

#include <time.h>//使用时间数据类型 time_t
time_t ts;//时间的变量
srand((unsigned int)time(&ts));//time是一个函数,获取时间保存结果ts中
int sNum = rand();//获取随机数


3.熊猫烧香

熊猫烧香 灰鸽子 不同,这是名副其实的 病毒 ,是一种经过多次变种的“ 蠕虫病毒 ”变种,2006年10月16日由25岁的中国湖北武汉新洲区人 李俊 编写,拥有感染传播功能,2007年1月初肆虐网络,它主要通过下载的档案传染,受到感染的机器文件因为被误携带间接对其它 计算机程序 、系统破坏严重。2013年6月病毒制造者张顺和 李俊 伙同他人开设网络赌场案,再次获刑。

4.自我删除

写一个bat,批处理文件
selfdel.bat
文件内容为:
del path\selfdel.bat

5.解一元二次方程                                                                                                                                                                                                         

//#define _CRT_SECURE_NO_WARNINGS
#pragma warning(disable:4996)//去掉安全检查
#include <stdio.h>
#include <stdlib.h>
void calc(int a, int b, int c)
{
    if (a == 0)//bx+c=0
    {
        if (b == 0)//c=0
        {
            if (c == 0)
            {
                printf("x为任意值\n");
            }
            else
            {
                printf("无解\n");
            }
        }
        else//x=-c/b
        {
            printf("x=%f\n",-1.0*c/b);
        }
    }
    else//ax^2+bx+c=0
    {
        int B24AC = b*b - 4 * a*c;
        printf("B24AC = %d\n", B24AC);
        float B_2A = -1.0*b / 2 / a;
        printf("B_2A = %f\n", B_2A);
        if (B24AC == 0)
        {
            printf("x1=x2=%f\n", B_2A);
        }
        else if (B24AC > 0)
        {
            float TmpSqrt = sqrt(B24AC)/2.0/a;
            printf("x1=%f,x2=%f\n", B_2A + TmpSqrt, B_2A - TmpSqrt);
        }
        else//B24AC < 0
        {
            float TmpSqrt = sqrt(-1*B24AC) / 2.0 / a;
            printf("x1=%f+%fi,x2=%f-%fi\n", B_2A , TmpSqrt, B_2A, TmpSqrt);
        }
    }
}
int main()
{
    int a = 0, b = 0, c = 0;
    printf("please input a, b, c:\n");
    scanf("%d %d %d", &a, &b, &c);
    printf("%dx^2+%dx+%d=0\n", a, b, c);
    printf("解为:\n");
    calc(a, b, c);
    system("pause");
    return 0;
}  


6. switch                                                                                                                                                                                                        

int num;
char ch;
float fl;
double db;
switch(num)//成立
{

}
switch(ch)//成立
{

}
switch(fl)//错误
{

}
表达式必须包含整形

7.循环结构                                                                                                                                                                                                           

cmd中敲入命令:
for /l %i in (1,1,5) do echo gogogo
for /? 查看帮助

for,while, do-while, 
1加到100; 

#include <stdio.h>
void addfor()
{
    int sum = 0;
    for (int i = 1; i <= 100; i++)
    {
        sum += i;
        printf("i=[%d], sum=[%d]\n", i, sum);
    }
}
void addwhile()
{
    int n = 1;
    int sum = 0;
    while (n <= 100)
    {
        sum += n;
        printf("n=[%d], sum=[%d]\n", n, sum);
        n++;
    }
}
void adddowhile()
{
    int sum = 0;
    int n = 1;
    do
    {
        sum += n;
        printf("n=[%d], sum=[%d]\n", n, sum);
        n++;
    }while (n<=100);
}
void main()
{
    adddowhile();
    system("pause");
} 

2的n次方;

#pragma warning(disable:4996)
#include <stdio.h>
void funfor()
{
    int n = 0;
    int iRes = 1;
    printf("please input n:\n");
    scanf("%d", &n);
    for (int i = 0; i < n; i++)
    {
        iRes = iRes * 2;
    }
    printf("2的%d次方=%d\n", n, iRes);
}
void funwhile()
{
    int n = 0;
    int iRes = 1;
    printf("please input n:\n");
    scanf("%d", &n);
    printf("2的%d次方=", n);
    while (n>0)
    {
        iRes = iRes * 2;
        n--;
    }
    printf("%d\n", iRes);
}
void fundowhile()
{
    int n = 0;
    int iRes = 1;
    printf("please input n:\n");
    scanf("%d", &n);
    printf("2的%d次方=", n);
    do
    {
        if (n != 0)
        {
            iRes = iRes * 2;
        }        
        n--;
    } while (n > 0);
    printf("%d\n", iRes);
}
void main()
{
    fundowhile();
    system("pause");
}  

 整数逆序输出;
#pragma warning(disable:4996)
#include <stdio.h>
void main()
{
    int ShuZi = 0;
    printf("please input n:\n");
    scanf("%d", &ShuZi);
    printf("----------------------\n");
    int WeiShu = 0;
    while (ShuZi)
    {
        printf("%d", ShuZi % 10);
        ShuZi = ShuZi / 10;
    }    
    system("pause");
}  

8. break                                                                                                                                                                                                                  

节约计算机资源,找到就退出循环。
穷举法;
//316 = 11 * x + 15 * y;
#include <stdio.h>
void main()
{
    int x = 0;
    for (x = 0;; x++)
    {
        if( (316 - 11 * x )% 15 == 0)
        {
            printf("%d,%d\n", x, (316 - 11 * x)/15);
            break;
        }
    }
    system("pause");
}  

9.continue                                                                                                                                                                                                              

停止当前循环,进行下一次。
打印不能被3整除的数字
#include <stdio.h>
void main()
{
    for (int i = 1; i <= 100; i++)
    {
        if (i % 3 == 0)
        {
            continue;
        }
        printf("%d\n", i);
    }
    system("pause");
}  

10.goto                                                                                                                                                                                                                     

死循环
1加到100
#include <stdio.h>
void main()
{
    int i = 1;
    int sum = 0;
loop:
    if (i<=100)
    {
        sum += i;
        printf("%d,%d\n", i, sum);
        i++;
    }
     goto loop;
     system("pause");
}  

11.递归                                                                                                                                                                                                                   

//10进制转2进制 
 #define _CRT_SECURE_NO_WARNINGS
//10进制转2进制
#include <stdio.h>
#include <stdlib.h>
void change2(int n)
{
    if (n == 1)//终止循环条件
    {
        printf("%d", n);
    }
    else
    {
        change2(n / 2);
        printf("%d", n%2);
    }
}
void main()
{
    int num = 0;
    printf("please input:\n");
    scanf("%d", &num);
    change2(num);
    system("pause");
}


目录
相关文章
|
7月前
|
算法 C++
算法笔记:递归(c++实现)
算法笔记:递归(c++实现)
|
4月前
|
C++
【C++基础】程序流程结构详解
这篇文章详细介绍了C++中程序流程的三种基本结构:顺序结构、选择结构和循环结构,包括if语句、三目运算符、switch语句、while循环、do…while循环、for循环以及跳转语句break、continue和goto的使用和示例。
86 2
|
5月前
|
C++ 容器
【C++航海王:追寻罗杰的编程之路】关联式容器的底层结构——AVL树
【C++航海王:追寻罗杰的编程之路】关联式容器的底层结构——AVL树
55 5
|
5月前
|
C++
c++学习笔记03 程序流程结构
C++学习笔记,主要介绍了程序流程结构,包括顺序结构、选择结构和循环结构。选择结构中详细解释了if语句、三目运算符和switch语句的用法和注意事项。循环结构部分则涵盖了while循环、do-while循环和for循环的语法和使用技巧。此外,还介绍了跳转语句,包括break、continue和goto语句的用途和用法。
42 0
|
5月前
|
关系型数据库 C++ 容器
【C++航海王:追寻罗杰的编程之路】关联式容器的底层结构——红黑树
【C++航海王:追寻罗杰的编程之路】关联式容器的底层结构——红黑树
47 0
|
7月前
|
C++
C++一分钟之-循环结构:for与while循环
【6月更文挑战第18天】在C++中,`for`循环适合已知迭代次数,如数组遍历;`while`循环适用于条件驱动的未知次数循环。`for`以其初始化、条件和递增三部分结构简洁处理重复任务,而`while`则在需要先检查条件时更为灵活。常见错误包括无限循环和逻辑错误,解决办法是确保条件更新和正确判断。了解两者应用场景及陷阱,能提升代码效率和可读性。
78 6
|
7月前
|
C++
c++primer plus 6 读书笔记 第六章 分支语句和逻辑运算符
c++primer plus 6 读书笔记 第六章 分支语句和逻辑运算符
|
7月前
|
存储 测试技术 C++
C++中的结构
C++中的结构
34 2
|
7月前
|
算法 C++
C++中的结构应用:Josephus问题
C++中的结构应用:Josephus问题
59 1