(C语言的正确打开方式)c语言基础


目录

 

包括scanf的深入讲解*抑制符以及散列映射在结构体中的使用,还有特殊图形的打印,旋转摆花的两种写法


文章目录

C生万物,C语言博大精深,我们要有空杯心态



前言

博主将最近所学的分享给大家!希望大家多多支持。


提示:以下是本篇文章正文内容,下面案例可供参考


一、 scanf的深入讲解*抑制符

示例:

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
//再谈scanf
int main()
{
	int x, y;
//一般来说,scanf在遇到空格时会停止读入,在第一个%d之间加一个抑制符*时
//此时scanf会自动跳过输入的前一个数,读入空格后面的数
	scanf("%*d%d", &x);
	printf("%d ", x);

	return 0;
}

 用scanf模仿gets的作用

int main()
{
	int x, y;
	char a[1000] = "";
	scanf("%[A-Z,a-z]", a);
	//此时凡是在小写a到大写的Z之内的数都读得进,其他的读不进
	//gets(a);
	//printf("%d\n", x);
	puts(a);
	return 0;
}

 scanf完美模仿gets的代码形式为

scanf("%[^\n]%*c",a);

 代码解释为读入在遇到\n才停止读入


二、散列映射在结构体中的使用

 通过散列映射,不改变数组的内容而对数组内的元素进行排序等操作

int main()
{
	int a[10] = { 6,21,1 };
	int x, y, z, t;
	x = 0; y = 1; z = 2;
	if (a[x] > a[y])
	{
		t = x;
		x = y;
		y = t;
	}
	if (a[x]>a[z])
	{
		t = x;
		x = z;
		z = t;
	}
	if (a[y] > a[z])
	{
		t = y;
		y = z;
		z = t;
	}
	printf("%d %d %d", a[x], a[y], a[z]);
	return 0;
}
//从大到小排列数组内的数

 散列映射在结构体中的使用

代码实现

#include<stdio.h>
struct student
{
	char s[6];
	char name[10];
	float a, b, c, aver;
};
//定义一个结构体数组
int main()
{
	struct student arr[3];
	int i = 0;
//结构体输入
	for (i = 0; i < 3; i++)
	{
		scanf("%s%s%f%f%f", &arr[i].s, &arr[i].name, &arr[i].a, &arr[i].b, &arr[i].c);
	}
	for (i = 0; i < 3; i++)
	{
		arr[i].aver = (arr[i].a) * 0.1 + (arr[i].b) * 0.2 + (arr[i].c) * 0.7;
	}
//利用冒泡排序思想将结构体数组中的元素按成绩由高到低排
	for (i = 0; i < 2; i++)
	{
		for (int j = 0; j < 3 - i - 1; j++)
		{
			if (arr[j].aver < arr[j + 1].aver)
			{
				struct student tmp = arr[j];
				arr[j] = arr[j + 1];
				arr[j + 1] = tmp;
			}
		}
	}
	for (i = 0; i < 3; i++)
	{
		printf("%s %s %.1f\n", arr[i].s, arr[i].name, arr[i].aver);
	}
	return 0;
}

 三.特殊图形的打印,旋转摆花的两种写法

1打印特殊的正方形

 

#include<stdio.h>
int main()
{
    int n, i, j, k;
 //   scanf("%d", &n);
    n = 5;
    for (k = 0; k < 2 * n - 1; k++)//总共有2*n-1行
    {
        if (k < n) i = k; else i = 2 * (n - 1) - k;//利用if语句,将i定义,i从0开始,使其能够打印上下部分,当k=5时i = 3
        for (j = 0; j < i; j++)
        {
            printf("%c", 'Z' - j % 26);
        }
        for (j = 0; j < 2 * (n - 1 - i); j++)
        {
            printf("%c", 'Z' - i% 26);
        }
        for (j = i; j > 0; j--)
        {
            printf("%c", 'Z' - (j - 1) % 26);
        }
        printf("\n");
    }




    return 0;

}


2打印旋转摆花(方向数组)


#include<stdio.h>
char a[1000][1000] = { 0 };//当定义的数组内容过大时需放在main函数外面
int main()
{
	int n, i, j, k, d, n2,p,q;
	//设置一个方向数组
	int dr[4] = { 0,1,0,-1 };
	int dl[4] = { -1,0,1,0 };
	n = 5;
	n2 = n * n;
	i = 0; j = n - 1; d = 0;
	for (k = 0; k < n2; k++)
	{
		a[i][j] = 'A' + k % 26;
		p = i + dr[d];
		q = j + dl[d];
		if (p < 0 || p == n || q < 0 || q == n || a[p][q] != 0) d = (d + 1) % 4;//方向数组对4取余,使其循环
			i += dr[d];
			j += dl[d];
	}
	for (i = 0; i < n; i++)
	{
		for (j = 0; j < n; j++)
			printf(" %c", a[i][j]);
		printf("\n");
	}


	return 0;
}

 


总结

提示:这里对文章进行总结:
文章深度分析了scanf与散列映射以及特殊图形打印,希望对大家有所帮助!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

披星戴月的贾维斯

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值