一些C语言知识

C语言的内置类型:

char

short

int

long

float

double

C99中引入了bool类型,用来表示真假的变量类型,包含true,false。

这个代码的执行结果是什么?好好想想哦,坑挺多的。

cpp 复制代码
#include <stdio.h>

int main()
{
	int i = 0;
	for(i = 0;i < 10;i++)
	{
		if(i = 5)
			printf("%d ",i);
	}
	return 0;
}

你做对了吗?结果是死循环打印5。= 是赋值操作符,== 是判断相等操作符,循环变量 i 在循环内部也进行了修改。

VS选中语句,按 Tab 键可以一起往后缩进,按 Shift + Tab 键可以一起往前缩进。

switch语句中case后的表达式只能是整型常量表达式,char 也是属于整型家族的,因为字符存储的时候,存储的是ASCII码。

VS调试快捷键,F10进入调试,进入调试后按F10一条语句一条语句执行,按F11可以进入函数内部,然后再按F10一条语句一条语句执行,调试起来后,还可以调出监视窗口和内存窗口,帮助监视运行过程中变量的值的变化,还可以看变量在内存中的存储情况。

注意:只有进入调试之后才能调出这两个窗口。

三个整数从大到小输出

cpp 复制代码
#include <stdio.h>

//三个整数从大到小输出
int main()
{
	int a = 0;
	int b = 0;
	int c = 0;
	int t = 0;
	scanf("%d %d %d",&a,&b,&c);
	if(a < b)
	{
		t = a;
		a = b;
		b = t;
	}
	if(a < c)
	{
		t = a;
		c = a;
		a = t;
	}
	if(b < c)
	{
		t = b;
		b = c;
		c = t;
	}
	printf("%d %d %d",a,b,c);		
	return 0;
}

如上代码,可以看出交换两个数在代码中重复出现,这时可以把交换两个数这个功能封装成函数,这样就可以避免重复代码。

cpp 复制代码
#include <stdio.h>

//交换两个整数
void swap(int* a,int* b){
	int t = 0;
	t = *a;
	*a = *b;
	*b = t;
}

//三个整数从大到小输出
int main()
{
	int a = 0;
	int b = 0;
	int c = 0;
	//int t = 0;
	scanf("%d %d %d",&a,&b,&c);
	if(a < b)
	{
		swap(&a,&b);
		/*t = a;
		a = b;
		b = t;*/
	}
	if(a < c)
	{
		swap(&a,&c);
		/*t = a;
		c = a;
		a = t;*/
	}
	if(b < c)
	{
		swap(&c,&b);
		/*t = b;
		b = c;
		c = t;*/
	}
	printf("%d %d %d",a,b,c);		
	return 0;
}

求两个数的最大公约数

暴力求解,先求两个数中较小的即为m,然后用两个数分别除以 i ,i 从m开始,i -- ,重复这个相除和 -- 的过程,当两个数分别除以m都为0时,停止循环,这时的 i 就为两个数的最大公约数。

cpp 复制代码
#include <stdio.h>

//求两个数的最大公约数
int main()
{
	int a = 0;
	int b = 0;
	int i = 0;
	int m = 0;
	scanf("%d %d",&a,&b);
	if(a > b)
		m = b;
	else
		m = a;
	for(i = m;i >= 1;i--)
	{
		if(a % i == 0 && b % i == 0)
			break;
	}
	printf("%d\n",i);
	return 0;
}

辗转相除法求两个数的最大公约数

cpp 复制代码
#include <stdio.h>

//辗转相除法求两个数的最大公约数
//void swap(int* a,int* b){
//	int t = 0;
//	t = *a;
//	*a = *b;
//	*b = t;
//}
int main()
{
	int a = 0;
	int b = 0;
	int i = 0;
	int m = 0;
	scanf("%d %d",&a,&b);
	/*if(a < b)
			swap(&a,&b);*/
	//其实也不用事先求谁更大,如果是小的在前面,a % b 会= a;然后就是b % a,还是还会变成大的 % 小的
	while(a % b != 0)
	{
		m = a % b;
		a = b;
		b = m;
	}
	printf("%d\n",b);
	return 0;
}

计算1 - 1 / 2 + 1 / 3 - 1 / 4 + ... + 1 / 99 - 1 / 100

cpp 复制代码
#include <stdio.h>

//计算1 - 1 / 2 + 1 / 3 - 1 / 4 + ... + 1 / 99 - 1 / 100
int main()
{
	int i = 0;
	double sum = 1;
	for(i = 2;i <= 100;i++)
	{
		if(i % 2 == 0)
		{
			sum = sum - 1.0 / i;
		}
		else
		{
			sum = sum + 1.0 / i;
		}
	}
	printf("%lf\n",sum);
	return 0;
}
相关推荐
wjs20244 分钟前
DOM CDATA
开发语言
Tingjct5 分钟前
【初阶数据结构-二叉树】
c语言·开发语言·数据结构·算法
猷咪32 分钟前
C++基础
开发语言·c++
IT·小灰灰33 分钟前
30行PHP,利用硅基流动API,网页客服瞬间上线
开发语言·人工智能·aigc·php
快点好好学习吧35 分钟前
phpize 依赖 php-config 获取 PHP 信息的庖丁解牛
android·开发语言·php
秦老师Q35 分钟前
php入门教程(超详细,一篇就够了!!!)
开发语言·mysql·php·db
烟锁池塘柳035 分钟前
解决Google Scholar “We‘re sorry... but your computer or network may be sending automated queries.”的问题
开发语言
是誰萆微了承諾36 分钟前
php 对接deepseek
android·开发语言·php
2601_9498683639 分钟前
Flutter for OpenHarmony 电子合同签署App实战 - 已签合同实现
java·开发语言·flutter
飞机和胖和黄1 小时前
考研之王道C语言第三周
c语言·数据结构·考研