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/;
}
}
C语言-指针、数组、结构体、分支、循环混合使用的更多相关文章
- c语言指针与结构体
#include <stdio.h> #include <stdlib.h> struct mydata { int num; ]; }; void main1() { /*i ...
- C语言基础知识点整理(函数/变量/常量/指针/数组/结构体)
函数 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ...
- c语言指针与结构体之内存动态分配
struct dangdangtest { ]; ]; ]; int num; int bugnum; ]; ]; double RMB; }; void main2() { //struct dan ...
- 数据结构复习之C语言指针与结构体
数据结构指针复习: #include <stdio.h> void main() { ] = {, , , , }; // a[3] == *(3+a) printf(+a)); // a ...
- [todo0211]c语言指针,结构体的疑问
#include <stdio.h> #include <mm_malloc.h> struct ListNode { int val; struct ListNode *ne ...
- C语言--- 高级指针2(结构体指针,数组作为函数参数)
一.结构体指针 1. 什么是结构体指针?指向结构体变量的指针 结构体: typedef struct stu{ char name[ ...
- 嵌入式-C语言基础:通过结构体指针访问结构体数组
#include<stdio.h> #include<string.h> struct Student { char name[32]; int age; int height ...
- C语言中的结构体,结构体数组
C语言中的结构体是一个小难点,下面我们详细来讲一下:至于什么是结构体,结构体为什么会产生,我就不说了,原因很简单,但是要注意到是结构体也是连续存储的,但要注意的是结构体里面类型各异,所以必然会产生内存 ...
- Android For JNI(五)——C语言多级指针,结构体,联合体,枚举,自定义类型
Android For JNI(五)--C语言多级指针,结构体,联合体,枚举,自定义类型 我们的C已经渐渐的步入正轨了,基础过去之后,就是我们的NDK和JNI实战了 一.多级指针 指针的概念我们在前面 ...
- C++ 利用指针和数组以及指针和结构体实现一个函数返回多个值
C++ 利用指针和数组实现一个函数返回多个值demo1 #include <iostream> using namespace std; int* test(int,int,int); i ...
随机推荐
- IDL 遍历 XML文档示例
IDL解析XML文档同样也有2种方法:DOM和SAX方式:两种方法在IDL自带的帮助里面有详细介绍,可以去查看. IDL 源码PRO sample_recurse, oNode, indent COM ...
- java设计原则:16种原则
一 类的设计原则 1 依赖倒置原则-Dependency Inversion Principle (DIP) 2 里氏替换原则-Liskov Substitution Principle (L ...
- java工程开发之图形化界面之(第二课)
上一节主要是讨论小的应用程序,在这里我们将采用一种全新的方式来重新编写它. 在这里我们注重关注JFrame和JOptionPane.这些类提供了在JAVA应用程序使用图形的方法以及在JAVA程序中对I ...
- HTTP状态码 - HTTP Status Code
HTTP Status Code 常见的状态码: HTTP: Status 200 – 服务器成功返回网页HTTP: Status 404 – 请求的网页不存在HTTP: Status 503 – 服 ...
- Servlet程序开发--WEB开发模式(Mode I, Mode II)
Mode I: 就是在开发中,将显示层,控制层,数据层的操作统一交给JSP或JavaBean来进行处理. 客户端通过访问JSP,调用里面的JavaBean,而通过JavaBean调用数据库,在Java ...
- 这丫头也的还真清楚,但是跑不通呢,换3.0.3的mybatis也不行
http://java.dzone.com/articles/ibatis-mybatis-handling-joins http://mybatis.github.io/spring/mappers ...
- FZU Problem 2221 RunningMan(贪心)
一开始就跑偏了,耽误了很长时间,我和队友都想到博弈上去了...我严重怀疑自己被前几个博弈题给洗脑了...贪心的做法其实就是我们分两种情况,因为A先出,所以B在第一组可以选择是赢或输,如果要输,那直接不 ...
- Swift 开发中Alamofire的使用
Swift 开发中Alamofire的使用 Alamofire需要解决的6个问题 1.Json解析 2.下载和上传 4.全局401错误 5.网络图片
- js 中调用 Object.prototype.toString()来检测对象的类型
1.使用toString()方法来检测对象类型 可以通过toString() 来获取每个对象的类型.为了每个对象都能通过 Object.prototype.toString() 来检测,需要以 Fun ...
- ASer Python学习笔记
最近又开始学习python了,希望自己能坚持下去. 我看的书是thinkingpython,是在豆瓣的python学习组看到的. 连续看了3,4天左右,然后尝试着写了个小程序,复制文件的,代码如下: ...