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/;
}
}

C语言-指针、数组、结构体、分支、循环混合使用的更多相关文章

  1. c语言指针与结构体

    #include <stdio.h> #include <stdlib.h> struct mydata { int num; ]; }; void main1() { /*i ...

  2. C语言基础知识点整理(函数/变量/常量/指针/数组/结构体)

    函数 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ...

  3. c语言指针与结构体之内存动态分配

    struct dangdangtest { ]; ]; ]; int num; int bugnum; ]; ]; double RMB; }; void main2() { //struct dan ...

  4. 数据结构复习之C语言指针与结构体

    数据结构指针复习: #include <stdio.h> void main() { ] = {, , , , }; // a[3] == *(3+a) printf(+a)); // a ...

  5. [todo0211]c语言指针,结构体的疑问

    #include <stdio.h> #include <mm_malloc.h> struct ListNode { int val; struct ListNode *ne ...

  6. C语言--- 高级指针2(结构体指针,数组作为函数参数)

    一.结构体指针 1. 什么是结构体指针?指向结构体变量的指针     结构体:     typedef  struct stu{                          char name[ ...

  7. 嵌入式-C语言基础:通过结构体指针访问结构体数组

    #include<stdio.h> #include<string.h> struct Student { char name[32]; int age; int height ...

  8. C语言中的结构体,结构体数组

    C语言中的结构体是一个小难点,下面我们详细来讲一下:至于什么是结构体,结构体为什么会产生,我就不说了,原因很简单,但是要注意到是结构体也是连续存储的,但要注意的是结构体里面类型各异,所以必然会产生内存 ...

  9. Android For JNI(五)——C语言多级指针,结构体,联合体,枚举,自定义类型

    Android For JNI(五)--C语言多级指针,结构体,联合体,枚举,自定义类型 我们的C已经渐渐的步入正轨了,基础过去之后,就是我们的NDK和JNI实战了 一.多级指针 指针的概念我们在前面 ...

  10. C++ 利用指针和数组以及指针和结构体实现一个函数返回多个值

    C++ 利用指针和数组实现一个函数返回多个值demo1 #include <iostream> using namespace std; int* test(int,int,int); i ...

随机推荐

  1. 修改6S Fortran77 代码,建立查找表

      逐像元大气校正,常预先计算查找表(LUT,LookUp Tabel),6S大气辐射传输模式也可以用来计算LUT.但6S源程序输出信息多,且浮点数输出精度低,不利于提取关键信息生成LUT,本文描述了 ...

  2. L7,too late

    words: parcel,包裹 detective,侦探 expect,期待 airfield,飞机起落的场地 guard,警戒,守卫,n precious,adj,珍贵的 stone,石头 exp ...

  3. MySQL架构优化:定时计划任务与表分区

    转自: MySQL架构优化实战系列3:定时计划任务与表分区 - 今日头条(TouTiao.com)http://toutiao.com/a6304736482361049345/?tt_from=mo ...

  4. input text设置字体

    控件里设置: style="font-family:Arial" html里设置 <font face="Arial">

  5. HDU 1934 树状数组 也可以用线段树

    http://acm.hdu.edu.cn/showproblem.php?pid=1394 或者是我自己挂的专题http://acm.hust.edu.cn/vjudge/contest/view. ...

  6. android UI中添加一张图片如何将这张图片中某一部分设为透明的

    可以利用canvas画布类,这个类的具体方法可以参看官方api.http://developer.android.com/reference/android/graphics/Canvas.html ...

  7. ARM汇编指令的一些总结-转

    ARM汇编指令的一些总结ARM汇编指令很多,但是真正常用的不是很多,而且需要认真琢磨的又更少了.比较有用的是MOV B BL LDR STR还是通过具体汇编代码来学习吧.@ disable watch ...

  8. 转:C#生成唯一值的方法汇总

    这篇文章主要介绍了C#生成唯一值的方法汇总,有需要的朋友可以参考一下 生成唯一值的方法很多,下面就不同环境下生成的唯一标识方法一一介绍,作为工作中的一次总结,有兴趣的可以自行测试: 一.在 .NET ...

  9. java中单例设计模式

    在java中创建单例的方式主要有三种:饿汉式.懒汉式.登记式.以下内容均是摘抄自 http://blog.csdn.net/jason0539/article/details/23297037/ 一. ...

  10. 深入浅出Ajax(五)

    function initPage() { alert("3+3");//3+3 alert(eval("3+3")); //6 //eval()函数可以解析. ...