2023年10月26日
while(表达式)后面不能跟分号,否则没有输出结果
2023年10月31日
scanf中,输入%d\n后运行会出现需要输入两排数值的情况,输入两排数值,只会以第一次的数据为准运行。正确应该去掉\n,就可正常运行
2023年11月1日
错误
定义完X、Y后,想要输入数据,需要把scanf跟随到定义X、Y的后面,然后再定义Z=X+Y
正确
关于if else
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
int x = 0;
scanf("%d", & x);
if (x % 2 == 1)
printf("%d是奇數\n", x);
else
printf("%d是偶数\n", x);
return 0;
if(x%2==1),意思是,%是取模运算符,其含义是求两个数相除的余数。x%2==1可以用来判断x是否为奇数。如果x%2的结果为1,说明x÷2的余数为1,即x是奇数;如果x%2的结果为0,说明x÷2的余数为0,即x是偶数。
2023年11月15日
求三个数从大到小的排序,两个数互换的应用
#include<stdio.h>
int main(void)
{
int a, b, c;
int t;
printf("请输入三个整数(中间以空格隔开):\n");
scanf("%d %d %d", &a, &b, &c);
if (a < b)
{
t = a;
a = b;
b = t;
}
if (a < c)
{
t = a;
a = c;
c = t;
}
if (b < c)
{
t = b;
b = c;
c = t;
}
printf("%d %d %d\n", a, b, c);
return 0;
}
2023年11月16日 for循环的简单列题
1.以下程序输出的内容是?
#include<stdio.h>
int main(void)
{
int i;
for (i = 1; i < 10; i += 2)
{
printf("%d\n", i);
}
return 0;
}
1 3 5 7 9 ,证明此程序循环了5次
2.上方程序的i最终数据是多少?
i的值是11
3.求1到10000的奇数和
sum的值为25000000
4.求1到100之间所有能被3整除的数字之和
sum=1683
5.下列程序的输出结果是?(流程的重要性)
#include<stdio.h>
int main(void)
{
int i;
int sum = 0;
{
for (i = 3; i <= 10; ++i)
{
if (i %3== 0) //如果i能够被3整除
sum = sum + i;
printf("sum = % d\n", sum);
}
}
return 0;
}
sum = 3
sum = 3
sum = 3
sum = 9
sum = 9
sum = 9
sum = 18
sum = 18
6.求1到100之间的奇数之和
#include<stdio.h>
//求1到100奇数的和
int main(void)
{
int i;
int sum = 0;
for (i = 1; i <= 100; ++i)
{
if (i % 2 == 1)
sum = sum + i;
}
printf("sum=%d\n", sum);
return 0;
}
//运行结果是:2500
7.求1到100之间的奇数的个数
8.求1到100之间的奇数的平均数
9.求1到100之间的奇数之和与偶数之和
#include<stdio.h>
//求1到100的奇数之和和偶数之和
int main(void)
{
int i;
int sum1 = 0; //奇数之和
int sum2 = 0; //偶数之和
{
for (i = 0; i <= 100; i++)//利用循环,循环1到100的所有数
{
if (i % 2 == 1)//筛选出所有的奇数:如果i除2余1,则 sum1 =sum1 + i
sum1 = sum1 + i;
}
printf(" sum1=%d\n", sum1);
}
{
for (i = 0; i <= 100; i++)//利用循环,循环1到100的所有数
{
if (i % 2 == 0)
sum2 = sum2 + i;//筛选出所有的偶数:如果i除2余0,则 sum2 =sum2 + i
}
printf(" sum2=%d\n", sum2);
}
}
10.求 1+1/2+1/3..........+1/100的值
#include<stdio.h>
//求 1+1/2+1/3..........+1/100的值
int main(void)
{
int i;
float sum = 0; //1到100的和
{
for (i = 1; i <= 100; i++)
sum = sum + 1 / (float)(i);//强制类型转换 sum= sum+1/(float)(i)等价于sum=sum+1.0/i
}
printf("sum=%f\n", sum);
return 0;
}
输出结果为 5.187378
2023年11月17日 while 循环
1.判断回文数
#include<stdio.h>
int main(void)
{
int m;
int val;
int sum = 0;
printf("请输入你想判断的数字\n");
scanf("%d", &val);
m = val;
while (m)
{
sum = sum * 10 + m % 10;
m /= 10;
}
if (sum == val)
printf("yes\n");
else
printf("no\n");
return 0;
}
/*
试数过成:
1—> m=1234 成立,m除了0以外的数都成立
sum=0*10+1234%10 = 4
m=m/10=123 int型不显示小数
2-> m=123 成立
sum=4*10+123%10=43
m=m/10=12
3-> m=12 成立
sum=43*10+12%10=432
m=m/10=1
4-> m=1 成立
sum=432*10+1%10=4321
m=m/10=0
5-> m=0 不成立
*/
2.斐波拉契数列试数过程
#include<stdio.h>
//斐波拉契序列
int main(void)
{
int n;
int f1, f2, f3;
int i;
f1 = 1;
f2 = 2;
printf("请输入你需要求的序列N:");
scanf("%d", &n);
if (1 == n)
{
f3 = 1;
}
else if (2 == n)
{
f3 = 2;
}
else
{
for (i = 3; i <= n; ++i)
{
f3 = f1 + f2;
f1 = f2;
f2 = f3;
}
}
printf("%d\n", f3);
return 0;
}
/*
试数过程
假定n=6
1-> i=3 3<=6 成立
f3=1+2=3 f1=f2=2 f2=f3=3 ++i i=4
2-> i=4 4<=6 成立
f3=2+3=5 f1=f2=3 f2=f3=5 ++i i=5
3—> i=5 5<=6 成立
f3=3+5=8 f1=f2=5 f2=f3=8 ++i i=6
4-> i=6 6<=6 成立
f3=5+8=13 f1=f2=8 f2=f3=13 ++i i=7
5-> i=7 7<=6 不成立 输出
*/
3. witch 电梯程序
#include<stdio.h>
//电梯程序
int main(void)
{
int val;
printf("请输入你要进入的楼层\n");
scanf("%d", &val);
switch (val)
{
case 1:
printf("一层到了");
break;
case 2:
printf("二层到了");
//break;//如果把 case2 break注释掉,用户输入 2 ,程序会从 case2 运行,一直找到下个break才会结束
case 3:
printf("三层到了");
break;
default:
printf("还没此楼层");
break;
}
return 0;
}
4.break的用法
#include<stdio.h>
//break的用法
int main(void)
{
int x = 1, y = 0, a = 0, b = 0;
switch (x)//第一个switch
{
case 1:
switch (y)//第二个switch
{
case 0:
a++;
break;//终止第二个switch
case 1:
b++;
break;//终止第二个switch
}
b = 100;
break;//终止第一个switch
case 2:
a++;
b++;
break;//终止第一个switch
}
printf("%d %d\n", a, b);
return 0;
}
/*
试数
X=1时,y=0
程序进入 case1
程序进入 switch(y),case0,a++,a=1,break退出
程序进入b=100,break退出
程序进入输出printf,输出结果a=1,b=100
*/
2023年11月26日
学生管理系统
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<malloc.h>
struct student
{
float score;
char name[100];
};
int main(void)
{
int len;
struct student* pArr;
int i, j;
struct student t;
printf("请输入学生个数\n");
scanf("%d", &len);
pArr = (struct student*)malloc(len * sizeof(struct student));
for (i = 0; i < len; ++i)
{
printf("name=:");
scanf("%d", &pArr[i].name); //正确不需要取地址,不取地址就会报错
printf("score=");
scanf("%f", &pArr[i].score);
}
// 按学生成绩升序排序
for (i = 0; i < len - 1;++i)
{
for (j = 0;j < len - 1 - i;++j)
{
if (pArr[j].score > pArr[j + 1].score)
{
t = pArr[j];
pArr[j] = pArr[j + 1];
pArr[j + 1] = t;
}
}
}
printf("\n\n学生的信息是:\n");
for (i = 0;i < len;++i)
{
printf("name=%s\n", pArr[i].name);
printf("score=%f\n", pArr[i].score);
}
return 0;
}
2024年1月11日09:37:00
1.计算流程