C语言循环结构实验报告

C语言循环结构实验报告


姓名:胡熙国 实验地点:一教524 实验时间:2021-5-6


一、实验目的与要求

  1. 熟练掌握使用while、do...while、和for语句实现循环的方法。
  2. 了解三种循环语句的区别和转换、各自的适应性、嵌套循环的使用。
  3. 掌握在循环语句中使用break和continue语句改变程序流程的方法。
  4. 能在程序设计中使用循环的方法实现各种算法。

二、实验内容

实验一

1.问题描述

  • 求出1,1+2,1+2+3,...数列中第i项的值,i的值由键盘输入。

2.试验代码

#include <stdio.h>
int main(void)
{
	int n,k,s=0;
	printf("请输入一个数字");
	scanf("%d",&n);
	for(k=1;k<=n;k++)
	{
		s=s+k;
		printf("%d\n",s);	
	}	
} 

3.效果截图

image

实验二

1.问题描述

  • 求出数列1,-3!,5!,-7!...前n项的值,n的值由键盘输入。

2.试验代码

#include <stdio.h>
int main(void)
{
	int n,i,j,sign=1;
	float fac,sum;
	printf("请输入n的值");
	scanf("%d",&n);
	sum=0.0;
	for(i=1;i<=n;i++)
	{
		fac=1.0;
		for(j=1;j<=2*i-1;j++)
		{
			fac=fac*j;
		}
		fac=fac*sign;
		sum=sum+fac;
		sign=-sign;
	}
	printf("sum=%.0f\n",sum);
}

3.效果截图

image

4.问题分析

  • 注意内层循环的条件是j<=2*i-1

实验三

1.问题描述

  • 从键盘输入若干学生成绩,统计最高和最低成绩,当输入负数时结束输入。

2.试验代码

#include <stdio.h>
int main(void)
{
	float x,max,min;
	printf("请输入学生成绩");
	scanf("%f",&x);
	max=min=x;
	while(x>=0)
	{
		if(x>max)
		{
			max=x;
		}
		if(x<min)
		{
			min=x;
		}
		scanf("%f",&x);
	}
	printf("max=%f\nmin=%f\n",max,min);
}

3.效果截图

image

4.问题分析

  • 注意内层循环的条件是j<=2*i-1

实验四

1.问题描述

  • 求所有的水仙花数。

2.试验代码

#include <stdio.h>
#include <math.h> 
int main(void)
{
	int x,y,z,k=100;
	while(k<=999)
	{
		x=k/100;
		y=(k/10)%10;
		z=k%10;
		if(k==pow(x,3)+pow(y,3)+pow(z,3))
		{
			printf("%d\n",k);
		}
		k++;
	}
}

3.效果截图

image

4.问题分析

  • 在写x的立方时,可以用到math.h头文件中的pow函数
  • pow(dobule x,dobule y)表示计算的是x^y

实验五

1.问题描述

  • 计算满足不等式的n的最小值。

2.试验代码

#include <stdio.h>
int main(void)
{
	float sum,value;
	int n;
	printf("请输入一个值");
	scanf("%f",&value);
	sum=0.0;
	n=0;
	do
	{
		++n;
		sum+=1.0/(float)n;	
	}while(sum>value);
	printf("n=%d",n);
		
} 

3.效果截图

image

实验六

1.问题描述

  • 输入4个字符型数字,将他转化为10进制整数后输出。

2.试验代码

#include <stdio.h>
int main(void)
{
	char c;
	int k,data;
	data=0;
	for(k=0;k<4;k++)
	{
		while(1)
		{
			c=getchar();
			if(c>='0'&&c<='9')
			{
				break;
			}
		}
		if(k==0)
		{
			data+=(c-'0')*1000;
		}
		if(k==1)
		{
			data+=(c-'0')*100;
		}
		if(k==2)
		{
			data+=(c-'0')*10;
		}
		if(k==3)
		{
			data+=(c-'0');
		}
	}
	printf("DATA=%d",data);
}

3.效果截图

image

实验七

1.问题描述

  • 百马百担问题。

2.试验代码

#include <stdio.h>
int main(void)
{
	int m,n,k;
	int sum=0;
	printf("有如下的分配方法\n");
	for(m=1;m<=100;m++)
	{
		for(n=1;n<=100-m;n++)
		{
				k=100-n-m;
				if((3*m+2*n+0.5*k==100)&&(k%2==0)&&(k!=0))
				{
					printf("大马%3d匹;中马%3d匹;小马%3d匹;\n",m,n,k);
					sum++	;
				}
		}	
	} 
	printf("共有%d种驮法",sum);
}

3.效果截图

image

4.问题分析

  • 在最终的判断条件里如果只有3*m+2*n+0.5*k==100的话虽然不会出错,但是如果加上k%2==0会更加严谨。

实验八

1.问题描述

  • 有一个正整数数列,前四项之和等于26,前四项之积为880,求前六项的和,和前六项分别是多少。

2.试验代码

#include <stdio.h>
int main(void)
{
	int a,b,c,d,i,sum;
	for(a=1;a<=26;a++)
	{
		for(d=1;d<=26;d++)
		{
			b=4*a+6*d;
			c=a*(a+d)*(a+2*d)*(a+3*d);
			if((b==26)&&(c==880))
			{
				printf("数列的首项a=%d,公差d=%d,\n",a,d);
				printf("数列前六项的值为");
				for(i=0;i<6;i++)
				{
					printf("%d  ",a+i*d);
					sum=sum+(a+i*d);
				} 
				printf("\n");
			}
		}
		
	}
	printf("数列前六项的和为%d\n",sum);
}

3.效果截图

image

实验九

1.问题描述

  • 30个学生一起买小吃,共花费50元,大学生每人3元,初中生每人2元,小学生每人1元,求共有多少种组合。

2.试验代码

#include <stdio.h>
main()
{
	int x,y,z,sum;
	sum=0;
	for(x=1;x<30;x++)
	{
		for(y=1;y<30;y++)
		{
			z=30-x-y;
			if((z!=0)&&(3*x+2*y+z==50))
			{
				printf("大学生%3d\t中学生%3d\t小学生%3d\n",x,y,z);
				sum=sum+1;
			}
			else
			    continue;
		}
	}
	printf("共有%d种不同的组合\n",sum);
 } 

3.效果截图

image

实验十

1.问题描述

  • 打印出九九乘法表。

2.试验代码

#include <stdio.h>
int main(void)
{	int i,j;
	for(i=1;i<=9;i++)
	{
		for(j=1;j<=i;j++)
		{
			printf("%d*%d=%d\t",j,i,i*j);
		}
		printf("\n");
	}	
} 

3.效果截图

image

posted @ 2021-05-10 21:19  huxiguo  阅读(613)  评论(1编辑  收藏  举报
https://blog-static.cnblogs.com/files/xiaokang01/js.js 这是添加的文件的链接 color="2, 215, 215" 粒子的颜色设置 opacity="10" 粒子的透明度 count="17500" 粒子的个数