栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

C语言学习笔记——P6

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

C语言学习笔记——P6

前言:

 ●由于作者水平有限,文章难免存在谬误之处,敬请读者斧正,俚语成篇,恳望指教!

getchar()、putchar()等函数的功能.(参见MSDN)

getchar
getchar读取失败的时候返回EOF
int main()
{
	scanf()
	int ch = getchar();//'a' - 97

	printf("%cn", ch);
	putchar(ch);

	return 0;
}

int main()
{
	int ch = 0;
	while ((ch = getchar()) != EOF)
	{
		putchar(ch);
	}
	return 0;
}

 scanf()的读取及位置
int main()
{
	char input[20] = {0};

	printf("请输入密码:>");
	scanf("%s", input);//abcdef
	
	//getchar();//拿走n

	//清理缓冲区
	int tmp = 0;
	while ((tmp = getchar()) != 'n')
	{
		;//空语句
	}

	printf("请确认密码(Y/N):>");
	int ch = getchar();
	if (ch == 'Y')
	{
		printf("确认成功n");
	}
	else
	{
		printf("确认失败n");
	}

	return 0;
}

 

#include 
int main()
{
	int ch = 0;
	while ((ch = getchar()) != EOF)
	{
		if (ch < '0' || ch>'9')
			continue;

		putchar(ch);
	}

	return 0;
}
 //这个代码的作用是:只打印数字字符,跳过其他字符的

break作用:
#include 
int main()
{
	int i = 0;

	for (i = 1; i <= 10; i++)
	{
		
		if (5 == i)
		{
			break;
		}
		printf("%d ", i);
	}

	return 0;
}

continue作用:
#include 
int main()
{
	int i = 0;
	for (i = 1; i <= 10; i++)
	{
	if (5 == i)
	{
		continue;
	}
		printf("%d ", i);
	}
	return 0;
}

for循环:
#include 
int main() 
int i = 0;
    int j = 0;
    //这里打印多少个hehe?
    for (i = 0; i < 10; i++)
    {
        for (j = 0; j < 10; j++)
        {
            printf("hehen");
        }
    }
    return 0;
}

 

for循环体省略示例及测试输出:
    //代码2
#include 
int main()
{
    int i = 0;
    int j = 0;
    //这里打印多少个hehe?
    for (i = 0; i < 10; i++)
    {
        for (j = 0; j < 10; j++)
        {
            printf("hehen");
        }
    }
}

 易错题提要:
#include 

int main()
{
    //请问循环要循环多少次?

   
    
        int i = 0;
        int k = 0;
        for (i = 0, k = 0; k = 0; i++, k++)
            k++;
        return 0;
 
}

题目求解n(n有范围,尽量不要太大)的阶乘:
#include 
int main()
{
    int n= 0;
    scanf("%d", &n);
    int ret = 1;
    int i = 0;
    for (i=1; i <= n; i++)
    {
        ret = ret * i;
    }
    printf("%dn", ret);
    return 0;
}

题目-阶乘相加:
#include 
int main()
{
    int n = 0;    
    //scanf("%d", &n);    // 计算 1!+ 2!+ 3!+ …… + 10!
    
    int i = 0;

    int ret = 1;
    int sum = 0;
    for (n = 1; n <= 10; n++)
    {
        ret = 1;
        for (i = 1; i <= n; i++)
        {
            ret = ret * i;
        }
        sum += ret;
    }
    
    printf("%dn", sum);
    return 0;
}

//优化// 计算 1!+ 2!+ 3!+ …… + 10!
#include 
int main()
{
    int n = 0;
    int i = 0;
    int ret = 1;
    int sum = 0;
    for (n = 1; n <= 10; n++)
    {
       
        ret = ret * n;
        sum += ret;
    }

    printf("%dn", sum);
    return 0;
}
题目-二分法查找数组中的数: 
#include 
int main()      //在一个有序数组中查找具体的某个数字n。(讲解二分查找)

{
    int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
    //0~9
    int k = 7;
    int i = 0;
    for (i = 0; i < 10; i++)
    {
        if (arr[i] == k)
        {
            printf("找到目标,下标为%dn", i);
            break;
        }
    }
    if (i == 10)
    {
        printf("未找到目标n");
    }
    return 0;
}


代码优化——二分法
#include 
int main()      //在一个有序数组中查找具体的某个数字n。(讲解二分查找)

{
    int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
    //0~9
    int sz = sizeof(arr) / sizeof(arr[0]);
        //40             /4   =10
    int k = 17;
    int left = 0;
    int right = sz - 1;

    while (left <=right)
    {
        int mid = (left + right) / 2;
        if(arr[mid] < k)
        {
            left = mid + 1;
        }
        else if (arr[mid] > k)
        {
        right = mid - 1;

        }
        else
        {
        printf("找到目标,下标为:%dn", mid);
        break;
        }
    }
        if (left > right)
        {
           printf("未找到目标n");
        }

    
    return 0;
}
 题目:数字塔输出:
#include 
void pyramid(int n)
{
    int i;//行数
    int j;//列数

    for (i = 1; i <= n; i++)
    {
        for (j = 1; j <= n - i; j++) //输出空格
        {
            printf(" n");
        }
        for (j = 1; j <= i; j++)
        {
            printf("%d ", i);
        }
        putchar('n');
    }
}

int main()
{
    int n;
    void pyramid(int n);
    printf("Enter n:");
    scanf("%d", &n);
    pyramid(n);
    return 0;
}

题目-动态演示字符汇聚("Hello,World!")
#include 
#include 
#include 

int main()
{
    char arr[] = "abc";
    //[a b c ]
    // 0 1 2
    char arr1[] = "Hello World!!!!!!!!";
    char arr2[] = "###################";
    //            "H##############!";
    int left = 0;
    int right = strlen(arr1) - 1;

    while (left <= right)
    {
        arr2[left] = arr1[left];
        arr2[right] = arr1[right];
        printf("%sn", arr2);
        Sleep(1000);//睡眠函数-单位是毫秒
        //system("cls");//执行系统命令的清空屏幕  使用次语句会值显示一行动态变化
        left++;
        right--;
    }
    printf("%sn", arr2);
    printf("Hello,World!");

    return 0;
}
 视频动态演示测试字符汇聚输出(“Hello,World!”)

https://live.csdn.net/v/179391

总结:

通过动态演示,可以直观清晰地理解程序运行步骤,仍需多加努力,才能熟练掌握!

 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/384816.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号