#include <stdio.h>
const int N=3;
int main() {
int a[N] = {1, 2, 3};
int i;
printf("通过数组名和下标直接访问数组元素:\n");
for(i=0; i<N; i++)
printf("%d: %d\n", &a[i], a[i]);
printf("通过地址间接访问数组元素:\n");
for(i=0; i<N; i++)
printf("%d: %d\n", a+i, *(a+i));
return 0;
}
#include <stdio.h>
const int LINE = 2;
const int COL = 3;
int main() {
int a[LINE][COL] = {1,2,3,4,5,6};
int i,j;
printf("通过数组名和下标直接访问数组元素:\n");
for(i=0; i<LINE; i++)
for(j=0; j<COL; j++)
printf("%d: %d\n", &a[i][j], a[i][j]);
printf("通过地址间接访问数组元素:\n");
for(i=0; i<LINE; i++)
for(j=0; j<COL; j++)
printf("%d: %d\n", a[i]+j, *(a[i]+j));
printf("二维地址中a+i表示的地址:\n");
for(i=0; i<LINE; i++)
printf("a + %d: %d\n", i, a+i);
return 0;
}
// 使用指针变量间接访问一维数组
#include <stdio.h>
#include <stdlib.h>
const int N=3;
int main() {
int a[N];
int *p,i;
// 通过指针变量p,完成数组元素输入
for(p=a; p<a+N; p++)
scanf("%d", p);
// 过指针变量p,完成数组元素输出
for(p=a; p<a+N; p++)
printf("%d ", *p);
printf("\n");
p = a;
//通过指针变量p,完成数组元素输入
for(i=0; i<N; i++)
scanf("%d", p+i);
// 通过指针变量p,完成数组元素输出
for(i=0; i<N; i++)
printf("%d ", *(p+i));
printf("\n");
return 0;
}
// 使用指针变量间接访问二维数组
#include <stdio.h>
int main() {
int a[2][3] = {1,2,3,4,5,6};
int i,j;
int *p; // p是指针变量,存放int型数据的地址
int (*q)[3]; // q是指针变量,存放包含有3个元素的一维数组的地址
// 通过指针变量p间接访问,输出二维数组a的元素值
for(p=a[0]; p<a[0]+6; p++)
printf("%d ", *p);
printf("\n");
// 通过行指针变量q间接访问,输出二维数组a的元素值
for(q=a; q<a+2; q++)
for(j=0; j<3; j++)
printf("%d ", *(*q+j));
printf("\n");
return 0;
}
在这个 程序的运行过程中,我学到了冒泡排序的用法,通过冒泡排序来降序输出学生的信息,以及在对结构体初始化时需要一个一个来进行初始化,而不能整体进行赋值形式,用if
else if语句来进行分类从而分类出不及格的人
#include <stdio.h>
const int N=5;
// 定义结构体类型struct student,并定义STU为其别名
typedef struct student {
long no;
char name[20];
int score;
}STU;
// 函数声明
void input(STU s[], int n);
int findMinlist(STU s[], STU t[], int n);
void output(STU s[], int n);
int main() {
STU stu[N], minlist[N];
int count;
printf("录入%d个学生信息\n", N);
input(stu, N);
printf("\n统计最低分人数和学生信息...\n");
count = findMinlist(stu, minlist, N);
printf("\n一共有%d个最低分,信息如下:\n", count);
output(minlist, count);
return 0;
}
// 输入n个学生信息,存放在结构体数组s中
void input(STU s[], int n) {
int i;
for(i=0; i<n; i++)
scanf("%ld %s %d", &s[i].no, s[i].name, &s[i].score);
}
// 输出结构体s中n个元素信息
void output(STU s[], int n) {
int i;
for(i=0; i<n; i++)
printf("%ld %s %d\n", s[i].no, s[i].name, s[i].score);
}
// 在结构体数组s中,查找最低分学生的记录,将其存入结构体数组t中
// 形参n是结构体数组s中元素个数
// 函数返回最低分的学生人数
int findMinlist(STU s[], STU t[], int n) {
int i,min,j,k=0;
min=s[0].score;
for(i=0;i<n;i++)
if(min>s[i].score)
min=s[i].score;
for(j=0;j<n;j++)
if(s[j].score==min)
t[k++]=s[j];
return k;
}
#include <stdio.h>
#include <string.h>
const int N = 10;
// 定义结构体类型struct student,并定义其别名为STU
typedef struct student {
long int id;
char name[20];
float objective; /*客观题得分*/
float subjective; /*操作题得分*/
float sum;
char level[10];
}STU;
// 函数声明
void input(STU s[], int n);
void output(STU s[], int n);
void process(STU s[], int n);
int main() {
STU stu[N];
printf("录入%d个考生信息: 准考证号,姓名,客观题得分(<=40),操作题得分(<=60)\n", N);
input(stu, N);
printf("\n对考生信息进行处理: 计算总分,确定等级\n");
process(stu, N);
printf("\n打印考生完整信息: 准考证号,姓名,客观题得分,操作题得分,总分,等级\n");
output(stu, N);
return 0;
}
// 录入考生信息:准考证号,姓名,客观题得分,操作题得分
void input(STU s[], int n) {
// 补足代码
// ×××
int i;
for(i=0;i<n;++i)
scanf("%ld %s %f %f",&s[i].id,s[i].name,&s[i].objective,&s[i].subjective);
}
//输出考生完整信息: 准考证号,姓名,客观题得分,操作题得分,总分,等级
void output(STU s[], int n) {
// 补足代码
// ×××
int i;
for(i=0;i<n;++i)
printf("%20ld %10s %5.1f %5.1f %5.1f %10s\n",s[i].id,s[i].name,s[i].objective,s[i].subjective,s[i].sum,s[i].level);
}
// 对考生信息进行处理:计算总分,排序,确定等级
void process(STU s[], int n) {
// 补足代码
// ×××
int i,j,k;
STU temp;
for(k=0;k<n;k++)
s[k].sum=s[k].objective+s[k].subjective;
for(i=0;i<n-1;i++)
for(j=0;j<n-i-1;j++)
if(s[j].sum<s[j+1].sum){
temp=s[j];
s[j]=s[j+1];
s[j+1]=temp;
}
for(k=0;k<n;k++){
if(k<=(n-1)*0.1)
strcpy(s[k].level,"优秀");
else if(k>(n-1)*0.1&&k<=(n-1)*0.5)
strcpy(s[k].level,"合格");
else
strcpy(s[k].level,"不合格");
}
}