【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");
}


目录
相关文章
C4.
|
1月前
|
算法 程序员 C++
C++标准头文件结构
C++标准头文件结构
C4.
24 0
|
1月前
|
C++
c++循环结构讲解
c++循环结构讲解
24 0
|
1天前
|
存储 搜索推荐 C++
【C++高阶(二)】熟悉STL中的map和set --了解KV模型和pair结构
【C++高阶(二)】熟悉STL中的map和set --了解KV模型和pair结构
|
29天前
|
存储 算法 C语言
【C/C++ 链表结构】探索链表迭代器:C++实现的深入分析与优化策略
【C/C++ 链表结构】探索链表迭代器:C++实现的深入分析与优化策略
37 0
|
30天前
|
存储 算法 C++
【C++ map结构 】std::map 和 std::unordered_map 在使用上的差异
【C++ map结构 】std::map 和 std::unordered_map 在使用上的差异
21 0
|
1月前
|
存储 算法 C++
【C++ 包装器类 map】C++ 标准库(std)中的map结构 哈希表(unordered_map)和黑红树(map)教程
【C++ 包装器类 map】C++ 标准库(std)中的map结构 哈希表(unordered_map)和黑红树(map)教程
83 1
|
1月前
|
C++ 容器
C++循环结构
C++循环结构
|
1月前
|
C++
C++控制结构
C++控制结构
|
1月前
|
存储 安全 Linux
C++文件格式深度解析:从底层结构到关键特性
C++文件格式深度解析:从底层结构到关键特性
250 3
C++文件格式深度解析:从底层结构到关键特性
|
1月前
|
C++
C++循环结构实现的猜数字游戏
C++循环结构实现的猜数字游戏
38 1

热门文章

最新文章