C语言-数组练习题(附答案)

 

目录

1.输入10名学生的成绩,计算总分和平均分,输出平均分。

2.输入10个学生的成绩,输出高于平均分的学生成绩。

3.打印图片

4.杨辉三角 

5.输入一个以回车符为结束标志的字符串(少于10个字符),提取其中的所有数字字符,将其转换为一个十进制整数,再将十进制整数转化为二进制数输出。

 6.判断回文

7.输入3个字符串,要求找出其中最大的。

8.编一个程序,将两个字符串连接起来,不用strcat函数。

9.编写一个程序,将字符数组S2中的全部字符复制到字符数组S1中。不用strcpy函数。复制时,‘\0’也要复制过去。‘\0’后面的字符不复制。

10.输入一行字符,统计其中有多少个单词,单词之间用空格分隔开。


1.输入10名学生的成绩,计算总分和平均分,输出平均分。

#include<stdio.h>
#define N 10
int main()
{
	float score[N],s=0;
	int i;
	for(i=1;i<N;i++)
	{
		scanf("%f",&score[i]);
		s=s+score[i];
	}
	printf("avervage=%.lf\n",s/N);
return 0;}

2.输入10个学生的成绩,输出高于平均分的学生成绩。

#include<stdio.h>
int main()
{
	int a[9],s=0,i;
	float ave;
	for(i=0;i<=9;i++)
	{
		scanf("%d",&a[i]);
		s=s+a[i];}
	ave=s/10;

		for(i=1;i<10;i++)
		{	if(a[i]>ave)
		printf("%d",a[i]);}
	return 0;}

3.打印图片

#include<stdio.h>
int main()
{int i,j;
int a[10][10];
for(i=0;i<10;i++)
{a[i][0]=1;
    a[i][i]=1;
for(j=1;j<i;j++)
a[i][j]=a[i-1][j-1]+a[i-1][j];}
for(i=0;i<10;i++)
{for(j=0;j<=i;j++)
printf("%3d",a[i][j]);
printf("\n");}
return 0;}

4.杨辉三角 

 

#include<stdio.h>
int main()
{
int i,j,k;
int a[10][10];
for(i=0;i<10;i++)
{a[i][0]=1;
    a[i][i]=1;
for(j=1;j<i;j++)
a[i][j]=a[i-1][j-1]+a[i-1][j];}
for(i=0;i<10;i++)
{for(k=1;k<10-i;k++)
printf("  ");
for(j=0;j<=i;j++)
printf("%4d",a[i][j]);
printf("\n");}
return 0;}
在C语言中,数组是一个连续的内存区域,用于存储同种数据类型的元素集合。通过数组练习,可以巩固基础的数据结构知识和理解数组操作。下面是一些常见的数组练习题目示例: 1. 定义并初始化一个整数数组,计算并输出数组元素的总和、平均值和最大值、最小值。 ```c int array[5] = {1, 2, 3, 4, 5}; int sum = 0; for(int i = 0; i < sizeof(array)/sizeof(array[0]); i++) { sum += array[i]; } double average = (double)sum / sizeof(array); printf("Sum: %d, Average: %.2f\n", sum, average); int max = *max_element(array, array + sizeof(array)); int min = *min_element(array, array + sizeof(array)); printf("Max: %d, Min: %d\n", max, min); ``` 2. 实现动态数组,即动态分配大小并能添加、删除元素的功能。 ```c #include <stdlib.h> typedef struct { int* elements; size_t size; } DynamicArray; void dynamic_array_init(DynamicArray* arr) { arr->elements = malloc(sizeof(int)); arr->size = 0; } // 添加元素 void dynamic_array_push_back(DynamicArray* arr, int value) { arr->elements = realloc(arr->elements, (arr->size+1)*sizeof(int)); arr->elements[arr->size++] = value; } // 删除最后一个元素 void dynamic_array_pop_back(DynamicArray* arr) { if(arr->size > 0) arr->size--; else free(arr->elements); arr->elements = realloc(arr->elements, arr->size*sizeof(int)); } // 输出动态数组内容 void dynamic_array_print(DynamicArray* arr) { for(size_t i = 0; i < arr->size; i++) printf("%d ", arr->elements[i]); printf("\n"); } ```
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值