#include <stdio.h>
#include <malloc.h>
struct Student
{
int age;
char name[100];
};
int main(void)
{
int len;
int i;
int j;
struct Student *parr;
struct Student t;
printf("请输入长度:");
scanf("%d",&len);
parr =(struct Student*)malloc(len * sizeof(struct Student*));
//输出
for(i=0;i<len;i++)
{
printf("第%d学生的信息是:\n",i+1); //scanf不要加\n
printf("他的名字是:");
scanf("%s",parr[i].name);
printf("他的年龄是:");
scanf("%d",&parr[i].age);
}
//排序
for(i=0;i<len-1;i++)
{
for(j=0;j<len-1-i;j++)
{
if( parr[j].age > parr[j+1].age ) //if要加花括号才可放下三个语句,要加.age说明是按年龄排序,下面不用是一整个结构体变位置
{
t = parr[j];
parr[j] = parr[j+1];
parr[j+1] = t;
}
}
}
//输出
printf("\n学生信息为\n");
for(i=0;i<len;i++)
{
printf("他的姓名是%d\n",parr[i].age);
printf("他的年龄是%s\n",parr[i].name);
}
return 0;
}
![](https://i-blog.csdnimg.cn/blog_migrate/39eaf5766b730380072ae79b698907a6.jpeg)
打卡学习c语言每一天,已经学到指针和结构体啦,模仿老师写了一个管理系统,其中有些小错误,比如scanf后面不要加\n,for多个语句加{},虽然听的时候知道勒,写程序还是会出现这些简单的问题,还是要多敲哈哈。还有%s是字符串,%c是字符!!
以下是一些学习小心得,方便我们理解得
冒泡排序
首先排序n-1次比如4个数字
第一次i执行完,执行j,排序3次把最大的排后面,剩3个数字要排,那么j就是
第二次i执行完,执行j,j排序2次
剩2个数字要排,那么j就是
第二次i执行完,执行j,j排序1次
j就是j小于长度-1次再-i次
还有一个是因为动态数组可以指定放几个元素
用mallol
struct student *parr
p[0]有点类似与str1相当于一个变量名,所以可以这么写p[i].age,scanf里面得画就要&p[i].age,而name不加得原因是他是一个数组,本身变量名就是一个首地址,所以不加,然后有个疑问就是那如果他是地址,为什么后面printf还可以写 printf("他的年龄是%s\n",parr[i].name);哈哈哈,有哪个大佬回答一下吗
如果不用数组
char name得话
可以这么写吧
strcpy(parr->age,“谁”)
有错欢迎大佬指出。。小白一枚
进制总结
十进制转n进制
除商取余
n进制转10进制
乘法
十六进制转二进制
四位为一组
八进制转二进制
3位为一组
从右向左,不够补0