C语言-指针、数组、结构体、分支、循环混合使用

时间:2023-03-10 00:39:14
C语言-指针、数组、结构体、分支、循环混合使用

1、写一个程序,输出如下内容:

 //#############################################################
//### name number math english computer ###
//### zhanghua ,9901, 80.5, 87.0, 80.0 ###
//### lina ,9902, 70.0, 80.0, 90.0 ###
//### wanggang ,9903, 87.0, 76.0, 78.0 ###
//#############################################################

程序代码:

 struct score{
       char *name;
      int number;
      float math;
       float english;
       float computer;
       }; struct score sc[] = {
{"zhanghua", , 80.5, , },
{"lina", , , , },
{"wanggang", , , , },
};
printf("name number math english computer\n"); for (int i=; i<; i++) {
printf("%-9s,%d,%10.1f,%10.1f,%10.1f\n",sc[i].name, sc[i].number,sc[i].math,sc[i].english,sc[i].computer);
}

回车后输出:

 name      number     math       english    computer
zhanghua ,, 80.5, 87.0, 80.0
lina ,, 70.0, 80.0, 90.0
wanggang ,, 87.0, 76.0, 78.0
Program ended with exit code:

2,计算2+4+6+8+。。。+100

     int sum = ;
for (int i=; i<=; i+=) {
sum+=i;
}
printf("2+4+6+8+...+100=%d.\n",sum);

回车后输出:

 ++++...+=.
Program ended with exit code:

3、计算1到100之间的奇数和与偶数和

     int jsum = ;
int osum = ; for (int i= ;i<= ; i++) {
if (i%) {
jsum+=i;
}else{
osum+=i;
}
} printf("jsum=%d,\tosum=%d\n", jsum, osum);

回车后输出:

 jsum=,    osum=
Program ended with exit code:

4、求1到100的非素数之和

     int sum = ;
int j= ;
for (int i=; i<=; i++) {
for (j=; j<i; j++) {
if (i%j==) {
break;
}
}
if (j!=i) {
sum=sum+i;
printf("%d\t",i);
}
}
printf("\n%d\n",sum);

回车后输出:

 jsum=,    osum=
Program ended with exit code:

5、调用子函数实现1到100的非素数和,其中子函数判断数字是否非素数,如果非素数,则返回

主函数:

     int sum = ;
for (int i = ; i<=; i++) {
sum += sushu(i);
}
printf("%d\n", sum);

子函数:

 int sushu(int n){
int i;
for (i=; i<n; i++) {
if (n%i==) {
break;
}
}
if (n!=i) {
return ;
}else{
return n;
}
}

输出:

 Program ended with exit code: 

6、有一个四位正整数,组成着四个正整数的四个数字各不相同,如果把它们的首尾互换,第二位与第三位数互换,组成一个新的四位数,原来四位数刚好是新四位数的4倍,求这样的四位数:

 int a = ;
int b = ;
for (int i=; i<; i++) {
for (int j=; j<; j++) {
for (int k=; k<; k++) {
for (int l=; l<; l++) {
a=*i+*j+*k+l;
b=*l+*k+*j+i;
if (a==*b && i!=j &&j!=k && k!=l) {
printf("%d\t",a);
}
}
}
}
}
printf("\n");

输出:

  Program ended with exit code: 

7、两个乒乓球队进行比赛,各处三个人,甲队为A,B,C三人,乙队为X,Y,Z三人,其中A不和X比,C不和X,Z比,请编程找出三对赛手的名单:

 //设A=1,B=2,C=3.

     int x,y,z;
for (x=; x<; x++) {
for (y=; y<; y++) {
for (z=; z<; z++) {
if ((x+y+z)== && (x!=) && (x!=) && (z!=) &&(x!=y) && (y!=z)) {
printf("x=%d\ty=%d\tz=%d", x, y, z);
}
}
}
}

输出:

x=    y=    z=
Program ended with exit code:

8、对一个3*3的二维数组进行转置,即行列互换

    int a[][] = {, , , , , , , , };
int tmp = ; for (int i=; i<; i++) {
for (int j=i+; j<; j++) {
tmp = a[i][j];
a[i][j] = a[j][i];
a[j][i] = tmp;
}
} for (int i=; i<; i++) {
for (int j=; j<; j++) {
printf("%d\t",a[i][j]);
}
printf("\n");
}

输出:


 Program ended with exit code: 

9、输入20个正整数,判断是否素数,如果是则排序。

主函数:

 int a[] = {};
int b[] = {}; printf("请输入20个正整数\n"); for (int i=; i<; i++) {
scanf("%d",&a[i]);
b[i] = sushu(a[i]);
} rank(b, ); for (int i=; i<; i++) {
if (b[i]>) {
printf("%d\t",b[i]);
}
} printf("\n");

rank()子函数(使用选择法排序):

 void rank(int *p, int n){
int max = ;
int tmp = ;
for (int i=; i<n-; i++) {
max=i;
for (int j=i+; j<n;j++) {
if (*(p+max)<*(p+j)) {
max = j;
}
} if (i!=max) {
tmp = *(p+max);
*(p+max) = *(p+i);
*(p+i) = tmp;
}
}
}

10、输入10个整数,将其中最小的数与第一个数对换,把最大的数与最后一个数对换。写三个函数:①输入10个数;②进行处理;③输出10个数。

主函数:

     int a[] = {};
printf("请输入十个数:\n");
inputnum(a);
deal(a, );
output(a, );

输入、输出、处理子函数:

 // 输入十个数子函数
void inputnum(int *a){ for (int i=;i< ; i++) {
scanf("%d",&a[i]);
} } // 处理函数:将其中最小的数与第一个数对换,把最大的数与最后一个数对换
void deal(int *p, int n){
int max=,min=;
int tmp=,i=,j=;
max=i;
for (i=; i<n;i++) {
if (*(p+max)<*(p+i)) {
max=i;
} }
tmp = *(p+max);
*(p+max) = *(p+);
*(p+) = tmp; min=j;
for (j=; j<n;j++) {
if (*(p+min)>*(p+j)) {
min=j;
}
} tmp = *(p+min);
*(p+min) = *(p+n-);
*(p+n-) = tmp;
} // 输出函数
void output(int *p, int n){
for (int i=; i<n; i++) {
printf("%d\t",p[i]);
}
printf("\n");
}

11、使用子函数对数列排序:

主函数:

     int main() {

     int a[] = {, , , , ,};

     rank(a,);

     for (int i=; i<; i++) {
printf("%d\t", a[i]);
} printf("\n"); return ;
}

子函数:

 void rank(int * p, int n){

     int max = ;
int tmp = ; for (int i=; i<n-; i++) {
max=i;
for (int j=i+; j<n; j++) {
if (*(p+max)<*(p+j)) {
max=j;
}
}
if (i!=max) {
tmp = *(p+i);
*(p+i) = *(p+max);
*(p+max) =tmp;
}
}
}

12、有n个学生,每个学生的数据包括学号(num),姓名(name[20]),性别(sex),年龄(age),

三门课的成绩(score[3])。要求在main函数中输入这n个学生的数据,  然后调用一个函数count,在该函数中计算出每个学生的总分和平均分, 然后打印出所有各项数据(包括原有的和新求出的)。

     int i;
float s0,s1,s2; struct student a[]; for(i=;i<;i++) {
scanf("%d%s %c%d%f%f%f",&a[i].num, a[i].name, &a[i].sex,&a[i].age, &s0, &s1, &s2);
a[i].score[]=s0;a[i].score[]=s1;a[i].score[]=s2;
printf("%d %s %c %d %4.1f %4.1f %4.1f\n",a[i].num,a[i].name, a[i].sex,a[i].age,a[i].score[],a[i].score[],a[i].score[]);
}
count(a,);
printf("=============================================\n");
printf("NO name sex age score[0] score[1] score[2] total ave\n"); for(i=;i<;i++)
printf("%d  %s  %c  %d  %5.1f  %5.1f %5.1f %5.1f %5.1f\n", a[i].num,a[i].name,a[i].sex,a[i].age,a[i].score[], a[i].score[],a[i].score[],a[i].total,a[i].ave); return ;

结构体定义:

 struct student
{
int num;
char name[];
char sex;
int age;
float score[];
float total;
float ave;
};

count()子函数:

 void count(struct student * b,int n) {
int i,j;
for(i=;i<n;i++) {
for(j=;j<;j++)
b[i].total+= b[i].score[j];
b[i].ave=b[i].total/;
}
}