C语言 结构体 最后结果总是输出错误,不知道为啥。

题目要求:
1.读入一个英文文本文件,英文中有字母、数字、其它字符,无汉字,文件有多行。
2.编写函数实现:统计字母的出现频度,并显示结果。
3.编写函数实现:统计其中单词的个数,并显示结果。(单词个数以WORD统计为准)
找出最长的单词,并显示单词及其长度。
返回单词的统计结果。
4.统计出现的整数,存入一维数组,并显示结果。
注:学会利用字符型指针处理字符串。

    我写的代码如下:(是使用vc++编译的,最后结果有一些与实际答案不同)

#include
#include
#include
#define N 1000
void main()
{
int zi_mu(char *sp);
int statistics(char b[80][80],char a[N]);
void zheng_shu(char *sp);
int i=0,j=0;
char b[80][80],a[80]; //一个单词相当于一个一维数组。
printf("文章全文是:\n");
FILE*fp;//------1.读入一个英文文本文件,
char c;
if((fp=fopen("test.txt","r"))==NULL)
{
printf("无法打开此文件\n");
exit(0);
}
while((c=fgetc(fp))!=EOF)
{
a[i]=c;
i++;
}
a[i]='\0';
int n=strlen(a);
printf("%s",a);

zi_mu(a);
statistics(b,a);
zheng_shu(a);
}

int zi_mu(char *sp)//----------2.统计字母的出现频度,
{
int i,a[26];
for(i=0;i a[i]=0;
while((*sp)!='\0')
{
if(((*sp)>='a'&&(*sp)<='z')||((*sp)>='A'&&(*sp)<='Z'))
{
i=(*sp)-'a';
a[i]++;
}
sp++;
}
printf("\n\n单词出现的次数:\n");
for(i=0;i<26;i++)
printf(" %c:%d ",'a'+i,a[i]);
return 0;
}

int statistics(char b[80][80],char a[N]) //---3,显示单词。
{
int i,j,high,key=0,word=0,key1=0,max1=0,maxi=0;
char *p;
for(i=0;a[i]!='\0';i++)
{
if(a[i]==' ')
key=0;
else if(key==0&&(a[i]>='a'&&a[i]<='z'||a[i]>='A'&&a[i]<='Z'))
{
key=1;
word++;
}
}
printf("\n一共有%d个单词.\n",word);
i=0;
j=0;
p=a;
while((*p)!='\0')
{

if((*p>='a'&&*p<='z')||(*p>='A'&&*p<='Z'))
{
b[i][j]=*p;
j++;
}
else

{
b[i][j]='\0';
j=0;
i++;
}
p++;
}
b[i][j]='\0';

high=i+1;
for(i=0;i {
max1=0;j=0;
while((b[i][j]>='a'&&b[i][j]<='z')||(b[i][j]>='A'&&b[i][j]<='Z'))
{
max1++;

j++;

}
if(max1>key1)
key1=max1;

if(j==key1)
maxi=i;
}
b[maxi][key1]='\0';
printf("最长单词是:");
for(i=0;i<key1;i++)
printf("%c",b[maxi][i]);
printf(" 该单词长度为%d。",key1);
return 0;
}

void zheng_shu(char sp)//---------4.统计出现的整数,存入一维数组,并显示结果。
{
int a[20]={0},i=0,n=0;
while((*sp)!='\0')
{
if((*sp)>='0'&&(*sp)<='9')//若是数字字符
{

a[i]=a[i]*10+(*sp-'0');//*sp-'0' 数字字符转换成数字。
if((*sp)!='\0'&&(!(
(sp+1)>='0'&&*(sp+1)<='9')))//当前是数字字符下一个不是,准备处理下一个
i++;
}
sp++;
}
n=i;
printf("\n\n此文共有%d个数字: ",n);
for(i=0;i<n;i++)//------------------输出整数
{
printf(" %d ",a[i]);
}
printf("\n");
}

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
C语言结构体输出问题,输出不了结果

为什么输出不了计算出的结果,只能输出两行文字 代码如下: #include<stdio.h> #include<string.h> #define N 3 typedef struct { int id;//学号 char name[20];//姓名 char subject[20];//考试科目 float perf;//平时成绩 float mid;//期中成绩 float final;//期末成绩 float total;//总评 char level[10];//等级 }STU; void input(STU [],int);//输入学生信息 void clac(STU[],int);//计算总评和等级 int fail(STU[],STU[],int);//计算不及格学生人数 void sort(STU[],int);//排序 void show(STU[],STU[],int,int);//输出学生信息 void input(STU s[],int n){//输入学生信息 for(int i=0;i<n;i++){ printf("请输入学生信息:\n"); scanf("%d%s%s%f%f%f",&s[i].id,&s[i].name,&s[i].subject,&s[i].perf,&s[i].mid,&s[i].final); } } void clac(STU s[],int n){//计算总评和成绩 for(int i=0;i<n;i++){ s[i].total=0.2*s[i].perf+0.2*s[i].mid+0.6*s[i].final; if(s[i].total>=90){ strcpy(s[i].level,"优秀"); } else if(s[i].total>=80&&s[i].total<90){ strcpy(s[i].level,"良好"); } else if(s[i].total>=70&&s[i].total<80){ strcpy(s[i].level,"中等"); } else if(s[i].total>=60&&s[i].total<70){ strcpy(s[i].level,"及格"); } else{ strcpy(s[i].level,"不及格"); } } } int fail(STU s[],STU t[],int n){//计算不及格人数 int i,k=0; for(i=0;i<n;i++){ if(s[i].total<60){ t[k++]=s[i]; } } return k; } void sort(STU s[],int n){//排序 int i,j; STU temp; for(i=0;i<n-1;i++){ for(j=0;j<n-1-i;j++){ if(s[j].total<s[j+1].total){ temp=s[j+1]; s[j+1]=s[j]; s[j]=temp; } } } } void show(STU s[],STU t[],int n,int m){ int i; printf("学生成绩排名情况\n"); printf("------------------\n"); printf("姓名 学号 考试科目 平时成绩 期中成绩 期末成绩 总评 成绩等级\n"); for(i=0;i<n;i++){ printf("%10s%5d%20s%5.1f%5.1f%5.1f%5.1f%5.1f%10s\n",s[i].name,s[i].id,s[i].subject,s[i].perf,s[i].mid,s[i].final,s[i].total,s[i].level); } printf("不及格学生情况\n"); printf("------------------\n"); printf("姓名 学号 考试科目 平时成绩 期中成绩 期末成绩 总评 成绩等级\n"); for(i=0;i<m;i++){ printf("%10s%5d%20s%5.1f%5.1f%5.1f%5.1f%5.1f%10s\n",t[i].name,t[i].id,t[i].subject,t[i].perf,t[i].mid,t[i].final,t[i].total,t[i].level); } } int main(){ STU ccc[N],cwy[N]; int k; input(ccc,N); clac(ccc,N); k=fail(ccc,cwy,N); sort(ccc,N); show(ccc,cwy,N,k); return 0; }

C语言中结构体中的数组,不能直接赋值吗

设有定义:struct{char mark[12];intnum1;double num2;}t1,t2;若变量均已正确赋初值,则以下语句中错误的是(C) (A) t1=t2; (B) t2.num1=t1.num1; (C) t2.mark=t1.mark;//mark为结构体中的数组,不能直接赋值?? (D) t2.num2=t1.num2; ​====如题参考答案说为结构体中的数组,不能直接赋值,为什么呢?那应该怎么赋值呢?求大侠指教

c语言结构体中,一个非常奇怪的现象。求解答

运行环境 codeblock 运行过程中,输入0-10或者为负数的时候,子函数与主函数输出没有问题,然后输入11及其以上的数字,子函数正确,主函数输出为-1. 最开始我以为是内存空间溢出的问题,把MAX改小后依然存在问题。 然后我把结构体定义int n提到前面,输出就没有问题了。 下面是代码: ``` #include <stdio.h> #define MAX 10 typedef struct HashNode *HashTable; struct HashNode { char data[MAX][MAX]; int t[MAX]; int n; }; HashTable CreatTable(int Size); //创建一个散列表, data为-1代表没有元素 int main(void) { HashTable h; int x; scanf("%d",&x); h = CreatTable(x); printf("out n is %d\n",h->n); } HashTable CreatTable(int Size) //创建一个散列表, data为-1代表没有元素 { HashTable h; int i; h = (HashTable)malloc(sizeof(struct HashNode)); if(h == NULL) { printf("malloc error\n"); exit(-1); } h->n = Size; printf("in n is %d\n",h->n); for(i = 0; i < Size; i++) h->t[i] = -1; return h; } ``` 错误运行案列: ![图片说明](https://img-ask.csdn.net/upload/201905/22/1558531968_291811.jpg) int n提前后 ``` #include <stdio.h> #define MAX 10 typedef struct HashNode *HashTable; struct HashNode { int n; char data[MAX][MAX]; int t[MAX]; }; HashTable CreatTable(int Size); //创建一个散列表, data为-1代表没有元素 ``` 运行如下 ![图片说明](https://img-ask.csdn.net/upload/201905/22/1558532142_360769.jpg) 求解答,感激不尽。

C语言用其中一个结构的体元素从文件中查找到相同的结构体之后如何从文件中输出查找到的那个结构体

```工资管理。 功能要求: ① 职工基本信息的录入、增加、删除、修改; ② 按各种条件查询职工信息; ③ 应发工资计算; ④ 其它功能,如工资分布情况统计,代交税金计算,津贴发放,工资晋级等。 ``` ``` #include<stdio.h> #include<string.h> #include<stdlib.h> int n; void member_putin_info(); void member_seaech_info(struct member member[100],int n); void member_add_info(); void member_modify_info(); void member_delete_info(); char Readspecailline_info(int i); struct member{ char name[20]; char post[20]; int age,wages; int WorkingHours; }; void member_putin_info(){ int i; FILE *fp1,*fp2; struct member member[100]; printf("Input n:"); scanf("%d",&n); if((fp2=fopen("D:\\VC data\\salary1.txt","w"))==NULL) {printf("File open error!\n"); exit(0); } fprintf(fp2,"%d",n); if(fclose(fp2)){ printf("can not close the file!\n"); exit(0); } if((fp1=fopen("D:\\VC data\\salary.txt","w"))==NULL) {printf("File open error!\n"); exit(0); //*打开文件*// } for(i=0;i<n;i++){ //*职工信息录入功能*// printf("Input name:\n"); scanf("%s",&member[i].name); fprintf(fp1,"%s ",member[i].name); printf("Input post:\n"); scanf("%s",&member[i].post); fprintf(fp1,"%s ",member[i].post); printf("Input age:\n"); scanf("%d",&member[i].age); fprintf(fp1,"%d ",member[i].age); printf("Input wages:\n"); scanf("%d",&member[i].wages); fprintf(fp1,"%d ",member[i].wages); printf("Input WorkingHours:\n"); scanf("%d",&member[i].WorkingHours); fprintf(fp1,"%d ",member[i].WorkingHours); printf("\n"); fprintf(fp1,"\n"); } if(fclose(fp1)){ //*关闭文件*// printf("can not close the file!\n"); exit(0); } } void member_seaech_info() //*职工信息查询功能*// { struct member member[100]; FILE *fp1,*fp2,*fp3; if((fp2=fopen("D:\\Vc data\\salary.txt","r"))==NULL) {printf("File open error!\n"); exit(0); } fscanf(fp2,"%d",&n); if((fp1=fopen("D:\\Vc data\\salary.txt","r"))==NULL) {printf("File open error!\n"); exit(0); } int i; char Sname[20]; char Spost[20]; int choice; int age; char ch[2]; printf("[1]Select name\n"); printf("[2]Select post\n"); printf("[3]Select age\n"); printf("[4]Selcet wages\n"); printf("[5]Select WorkingHours\n"); printf("Enter choice:"); scanf("%d",&choice); if(choice<1||choice>5) printf("输入错误!\n"); if(choice==1){ printf("Enter the name:"); scanf("%s",&Sname); for(i=0;i++;i<n){ if(strcmp(Sname,member[i].name)==0){ break; } } } if(fclose(fp1)){ printf("can not close the file!\n"); exit(0); } if(fclose(fp2)){ printf("can not close the file!\n"); exit(0);} } int main(void) { int choice; printf("enter your choice:"); scanf("%d",&choice); switch(choice){ case 1:member_putin_info();break; case 2:member_seaech_info();break; } ``` return 0; } ``` 我就用名字进行对比,完了之后找到第几个结构有相同的名字,想输出这个结构体的所有元素,但是用scanf(fp1,"%s",member[i].name)这样的做法貌似永远只取值我文件中的第一行,求大神教教我方法!! 只要方法能行可靠就okk!! ```

结构体变量在全局定义

//在c语言中,全局定义一个结构体变量报如下错误,但是在c++中不会报错, //求解怎么解决?? E0059 常量表达式中不允许函数调用 ![图片说明](https://img-ask.csdn.net/upload/202002/14/1581676295_505365.png) 其他头文件已包含在myList.h中

C语言 结构体指针字符 二进制文件写入和读取 指针字符输出错误

typedef struct s{ char *name; }student; /*将结构体读出并显示*/ int IsUsed(char *str) { FILE *fp = fopen("test","rb"); student s; s.name = (char*) malloc(sizeof(char)*20); fread(&s,sizeof(student),1,fp); while(!feof(fp)){ printf("%s",s.name); //为什么这里出错?????????????????? if(strcmp(s.name,str)==0){ fclose(fp); return 1; //存在该字符串,则返回1 } fread(&s,sizeof(student),1,fp); } fclose(fp); return 0; //不存在该字符串,则返回0 } int main() { FILE *fp = fopen("test","rb+"); /*先将结构体P存入二进制文件中*/ student p; p.name = (char*) malloc(sizeof(char)*20); scanf("%s",p.name); while(IsUsed(p.name)){ //检查员工号是否唯一 printf("该字符串已经存在,请更换一个:"); scanf("%s",p.name); } fwrite(&p,sizeof(student),1,fp); } 在printf哪里显示程序停止工作!!!!!!!!!求解啊

c语言链表,输入输出正确但是删除操作报错

#include<stdio.h> #include<stdlib.h> #define len sizeof(struct student) struct student {int num; float score; struct student *next; }; struct student *creat(void) // 建立 {struct student *p1,*p2,*head; int n=0; p1=p2=(struct student *)malloc(len); scanf("%d %f",&p1->num,&p1->score); head=NULL; while(p1->num!=0) {n=n+1; if(n==1) head=p1; else p2->next=p1; p2=p1; p1=(struct student *)malloc(len); scanf("%d %f",&p1->num,&p1->score); } p2->next=NULL; return(head); } void print(struct student *head) // 输出 {struct student *p; p=head; if(head!=NULL) for(;p!=NULL;) {printf("%d %f\n",p->num,p->score); p=p->next; }} struct student *del(struct student *head,int num) // 删除 {struct student *p1,*p2=NULL; if(head=NULL) printf("空链表,无法操作"); else {p1=head; while((num!=p1->num)&&(p1->next!=NULL)) {p2=p1; p1=p1->next; } if(num==p1->num) {if(p1==head) head=p1->next; else p2->next=p1->next; free(p1); printf("此链表已删除"); } else printf("无此数据,错误"); } return head; } main() {struct student *head,*p; int num; head=creat(); printf("输入要查找的数据并删除:\n"); scanf("%d",&num); p=del(head,num); printf("删除后数据为:"); print(p); }

C语言:单链表输出显示问题

各位大佬麻烦帮忙看一下,从txt文件中获取数据为链表后,想要输出显示,运行结果是-842150451 1 3 5 7 9(1 3 5 7 9为正确链表数据) 代码如下: ``` // 实验2.cpp : 定义控制台应用程序的入口点。 // #include "stdafx.h" #include <stdio.h> #include <malloc.h> #include <stdlib.h> typedef struct LinkList { int data; struct LinkList *next; }LinkList; LinkList *createlink() { LinkList *head=(LinkList*)malloc(sizeof(LinkList)); int t; LinkList *p; LinkList *q; p=q=head; FILE *r=fopen("list1.txt","r"); if(r==NULL) { printf("could not open file"); return NULL; } while(fscanf(r,"%d",&t)!=EOF) { q=(LinkList*)malloc(sizeof(LinkList)); q->data=t; p->next=q; p=q; } p->next=NULL; return head; } int _tmain(int argc, _TCHAR* argv[]) { LinkList *p; p=createlink(); while(p) { printf("%d ",p->data); p=p->next; } //system("pause"); return 0; } ```

c语言数据结构问题,书上伪代码看上去很正确但是为什么放在自己代码里就输出错误呢

顺序表插入函数, 自己用c实现的书上伪代码 struct sqlist* insert(struct sqlist* L,int i,int num1) //第i个元素之前插入一个数值为num1的元素,并且输出 { int j; for(j=L->length-1; j>=i-1; j--) { L->num[j+1]=L->num[j]; L->num[i-1]=num1; ++ L->length; } return L; } 这个是自己代码: struct sqlist* insert(struct sqlist* L,int i,int num1) //第i个元素之前插入一个数值为num1的元素,并且输出 { int j; for(j=L->length-1; j>=i-1; j--) { L->num[j+1]=L->num[j]; if(j==i-1) { L->num[j]=num1; } } L->length++; return L; }

C++全局结构体变量赋值,读取时不一致

最近遇到一个问题,在对全局的结构体变量进行赋值之后,再读取其中内容的时候发现在Debug下是正常的,在Release下不正常。 下面这个代码是可以重现这个问题的:一个全局的结构体变量,在主函数中对它进行赋值,然后打印出来结构,发现和赋值不一致,并且在Debug和Release下的结果不一致。 代码: // Struct.cpp : 定义控制台应用程序的入口点。 // #include "stdafx.h" #include <iostream> using namespace std; struct MyStruct { int a; int b; int c; char* ca; char* cb; char* cc; }st; int main(int argc, _TCHAR* argv[]) { //MyStruct st; st.a = 1; st.b = 2; st.c = 3; st.ca = "ca"; st.cb = "cb"; st.cc = "cc"; printf("a: %d; b: %d; c %d: ; ca : %c; cb : %c; cc : %c;", st.a, st.b, st.c, st.ca, st.cb, st.cc); getchar(); return 0; } Debug下结果: ![图片说明](https://img-ask.csdn.net/upload/201611/08/1478614000_578050.png) Release: ![图片说明](https://img-ask.csdn.net/upload/201611/08/1478614024_347392.png)

结构体内指针字符数组的释放

问题:结构体成员char* name和结构体struct student* studentIOS同时释放的话回报错,错误见代码中注释。请问这里要怎么释放呢?还是结构体里面不能这样使用指针字符数组? #include <stdio.h> #include <stdlib.h> struct student{ int id; //长度:4 char* name; //8 int score[2]; //8 float avgScore; //4 }; void input(struct student*); void output(struct student*); void input(struct student* stu){ printf("(1)程序最多接受50名学生的信息,多余的无法录入\n"); printf("(2)不足50人,请输入-1结束输入\n"); for (int i=0; i<50; ++i) { (stu+i)->name = (char*)malloc(15 * sizeof(char)); //给结构体中学生的name分配空间 printf("请在下面输入第%d名学生的信息\n",i+1); printf("序号:"); scanf("%d",&(stu+i)->id); if (-1 == (stu+i)->id) { //输入-1的时候,停止输入;退出输入函数 printf("输入结束\n"); return ; } printf("姓名:"); //gets((stu+i)->name); scanf("%s",(stu+i)->name); printf("C语言成绩:"); scanf("%d",&(stu+i)->score[0]); printf("数序成绩:"); scanf("%d",&(stu+i)->score[1]); (stu + i)->avgScore =( (stu + i)->score[0] + (stu + i)->score[1])/2.0; } return; } void output(struct student* stu){ printf("学生信息如下\n"); printf("学号\t\t姓名\t\tC语言\t数学\t\t平均\n"); for (int i=0; i<50; ++i,++stu) { if (stu->id == -1) { break; } printf("%d\t\t%s\t\t%d\t\t%d\t\t%.2f",stu->id,stu->name,stu->score[0],stu->score[1],stu->avgScore); printf("\n"); } return; } int main(int argc, const char * argv[]) { struct student* studentIOS = (struct student*)malloc(50 * sizeof(struct student)); input(studentIOS); //output(studentIOS); // printf("%p\n%p",studentIOS->name,&studentIOS->name); //输出不同 /* 释放每个学生的name空间,或者释放学生结构体的空间, 测试发现二者只能释放一个 */ //释放每个学生中的name空间 #if 0 //加上此循环,程序出问题,提示studentIOS未malloc for (int i=0; i<50; ++i,++studentIOS) { if (NULL != studentIOS->name) { free(studentIOS->name); studentIOS->name = NULL; } } #endif #if 0 //加上下面的两句不会出问题 free((studentIOS+10)->name); (studentIOS+10)->name = NULL; #endif free(studentIOS); studentIOS = NULL; return 0; }

关于scanf输入到结构体中时不用&的问题

有一个结构体 struct student { long num; char name[20]; }zhao; 输入数据时是这样: scanf("%s",zhao.name); //这里为什么没有&了?

用结构体变量的指针做函数的参数

#include<stdio.h> #include<stdlib.h> #include<math.h> #include<string.h> struct Student { int num; char name[20]; float score[3]; float aver; }; void main() { struct Student *p; struct Student stu[10]; p = stu; void input(struct Student *p,int n); int n; scanf("%d",&n); input(p,n); system("pause"); } void input(struct Student *p,int n) { for(int i = 0;i < n;i++) { 接下来怎么写,我想从input 函数中 用指针输入数据 } }

C语言:在子函数中修改结构变量中元素的值

要写一个处理学生成绩信息的程序,使用单向链表,创建,遍历已经没有问题,但在修改结点的数据时出现问题,输入数据后程序就停止运行。 修改的思路是先根据学号定位到指定结点,然后修改数据,修改函数如下 ``` void Correct(float *a,float *b,float *c,float *d,float *e,float *f) { printf("请依次输入学生正确的的英语 数学 物理 C语言成绩\n"); scanf("%f%f%f%f",a,b,c,d); *e=*a+*b+*c+*d; *f=*e/4; } ``` 程序执行到上面时总是出现问题,不知道是什么原因,也尝试过其他修改的方法:只传结点的地址,同样出现问题;查找与修改函数合并,找到结点直接修改也是有问题,不知道为什么,代码有些长,还希望有人可以指导一下,非常感谢。 完整代码如下: ``` #include<stdio.h> #include<stdlib.h> #include<string.h> struct stu{ char num[15]; char name[20]; float EngSco; float MathSco; float PhySco; float CSco; float TotalSco; float AveSco; int GoOn; struct stu * next; }; void PrtMenu(); void CreatList(struct stu **headp);/*创建链表并输入数据*/ void PrtInf(struct stu *headp);/*输出链表中的某些数据*/ void Correct(float *a,float *b,float *c,float *d,float *e,float *f);/*修改链表中某结点元素的数据*/ void PrtData(struct stu *headp);/*输出链表中的某些数据*/ struct stu* Search(struct stu *headp);/*定位需要修改的结点的地址*/ int main() { int choice; struct stu *head=NULL,*revise=NULL; Order: PrtMenu(); scanf("%d",&choice); if(choice<0||choice>5){ printf("指令错误,请重新输入指令\n"); goto Order; } else switch(choice) { case 0: system("CLS"); break; case 1: CreatList(&head);break; case 2: PrtInf(head);break; case 3: revise=Search(head); Correct(&(revise->EngSco),&(revise->MathSco),&(revise->PhySco),&(revise->CSco),&(revise->TotalSco),&(revise->AveSco));break; case 4: PrtData(head);break; case 5: return 0; } goto Order; return 0; } void PrtMenu() { printf("-----功能选择-----\n"); printf("0.清屏并显示菜单\n"); printf("1.输入学生信息\n"); printf("2.输出学生各项信息\n"); printf("3.修改学生指定数据项的内容\n"); printf("4.输出各位同学的学号、姓名、四门课的总成绩和平均成绩\n"); printf("5.退出系统\n"); printf("------------------\n"); printf("请输入指令前的序号\n"); } void CreatList(struct stu **headp) { struct stu *loc_head=NULL,*tail; loc_head=(struct stu*)malloc(sizeof(struct stu)); printf("请输入学生的学号\n"); scanf("%s",loc_head->num); printf("请输入学生的姓名\n"); scanf("%s",loc_head->name); printf("请依次输入学生的英语 数学 物理 C语言成绩\n"); scanf("%f%f%f%f",&loc_head->EngSco,&loc_head->MathSco,&loc_head->PhySco,&loc_head->CSco); loc_head->TotalSco=loc_head->EngSco+loc_head->MathSco+loc_head->PhySco+loc_head->CSco; loc_head->AveSco=loc_head->TotalSco/4; tail=loc_head; printf("继续输入请按1,输入完成请按0\n"); scanf("%d",&tail->GoOn); if(tail->GoOn==0) goto end; else while(1) { tail->next=(struct stu*)malloc(sizeof(struct stu)); tail=tail->next; printf("请输入学生的学号\n"); scanf("%s",tail->num); printf("请输入学生的姓名\n"); scanf("%s",tail->name); printf("请依次输入学生的英语 数学 物理 C语言成绩\n"); scanf("%f%f%f%f",&tail->EngSco,&tail->MathSco,&tail->PhySco,&tail->CSco); tail->TotalSco=tail->EngSco+tail->MathSco+tail->PhySco+tail->CSco; tail->AveSco=tail->TotalSco/4; printf("继续输入请按1,输入完成请按0\n"); scanf("%d",&tail->GoOn); if(!tail->GoOn) break; } end: tail->next=NULL; *headp=loc_head; } void PrtInf(struct stu *headp) { struct stu *current=headp; printf("学号\t姓名\t英语\t高数\t物理\tC语言\t\n"); while(current) { printf("%s\t%s\t%.2f\t%.2f\t%.2f\t%.2f\t\n",current->num,current->name,current->EngSco,current->MathSco,current->PhySco,current->CSco); current=current->next; } } void Correct(float *a,float *b,float *c,float *d,float *e,float *f) { printf("请依次输入学生正确的的英语 数学 物理 C语言成绩\n"); scanf("%f%f%f%f",a,b,c,d); *e=*a+*b+*c+*d; *f=*e/4; } void PrtData(struct stu *headp) { struct stu *current=headp; printf("学号\t姓名\t总分\t平均分\t\n"); while(current) { printf("%s\t%s\t%.2f\t%.2f\t\n",current->num,current->name,current->TotalSco,current->AveSco); current=current->next; } } struct stu* Search(struct stu *headp) { struct stu *current=headp; char aim[15]; int flag; printf("请输入要修改数据的学生的学号\n"); scanf("%s",aim); while(current) { flag=strcmp(current->num,aim); if(flag=0) break; else current=current->next; } return current; } ```

关于c语言中free以及指针的问题

先上代码 ``` #include <stdio.h> #include <string.h> #include <stdlib.h> struct ListNode { int val; struct ListNode *next; }; int main() { struct ListNode *ptr = (struct ListNode*)malloc(sizeof(struct ListNode)); ptr->val = 2; ptr->next = NULL; struct ListNode *qtr = (struct ListNode*)malloc(sizeof(struct ListNode)); qtr->val = 8; qtr->next = NULL; ptr->next = qtr; free(qtr);//对该句进行修改 while(ptr) { printf(" %d\n",ptr->val); ptr = ptr->next; } } ``` 1、输出错误,这里的原因如下,执行free后qtr并不是NULL;     free(pointer); 释放的是指针指向的内存。注意,释放的是内存,不是指针。指针并没有被释放,指针仍然指向原来的存储空间。指针是一个变量,只有程序结束时才被销毁。释放了内存空间后,原来指向这块空间的指针还是存在,只不过现在指针指向的内容是垃圾,是未定义的。因此,释放内存后把指针指向 NULL,防止指针在后面不小心又被解引用了。 --------------------- 作者:ForeverStrong 来源:CSDN 原文:https://blog.csdn.net/chengyq116/article/details/79079389 版权声明:本文为博主原创文章,转载请附上博文链接! 2、将free(qtr);后面再添加qtr = NULL; 执行错误。 3、将free(qtr)改成qtr = NULL; 执行正确。 我想问的就是造成2、3的区别,在2中,free后,qtr与原来的链表已经没有联系了吗?个人推测,ptr->next在1里面指向依然是qtr,而qtr指向的是一个垃圾空间。在2里面,改变了qtr的值后,ptr->next为什么没有指向NULL? 感激不尽。

C语言编程题,插入求和函数,排序函数。么有错误,但结果不对!

定义一个包括学号、姓名及三门课的成绩和总分的结构体,利用该结构体说明一个包含五个人的结构体数组。从键盘输入五个人的基本信息、计算总分,并根据总分排序输出一个成绩单!

添加记录(结构体) python怎么实现(哪位大佬看一下怎么写啊)

描述 统计 有一学生成绩表,包括学号、姓名、3门课程成绩。已知该成绩表按学号升序已排序。请编程实现,添加一个新的学生信息,且使成绩表仍按学号有序;若待添加的学号与已有学号重复,则输出错误信息,拒绝添加。 输入 输入只有一组数据,包含多行。 首先输入一个整数n(1<=n<=100),表示学生人数; 然后输入n行,每行包含一个学生的信息:学号(12位)、姓名(不含空格且不超过20位),以及3个整数,表示3门课成绩,数据之间用空格隔开。 最后一行输入一个待添加的学生信息,包括学号、姓名和3门课成绩。 输出 若待添加的学号与已有学号重复,则输出只有一行“error!”;否则,输出n+1行,即添加后的成绩单信息。 输入示例 3 541207010188 Zhangling 78 95 55 541207010189 Wangli 87 99 88 541207010191 Fangfang 68 76 75 541207010190 Lilei 68 79 82 输出示例 541207010188 Zhangling 78 95 55 541207010189 Wangli 87 99 88 541207010190 Lilei 68 79 82 541207010191 Fangfang 68 76 75

C语言用sizeof求数组长度,为什么结果不对?

int aaaaa[10]; printf("%d/n",sizeof(aaaaa)); 结果是40?

C语言中两个变量的值互换问题

两个变量的值互换为什么不能直接用 a=b;b=a;来实现。

MySQL 8.0.19安装教程(windows 64位)

话不多说直接开干 目录 1-先去官网下载点击的MySQL的下载​ 2-配置初始化的my.ini文件的文件 3-初始化MySQL 4-安装MySQL服务 + 启动MySQL 服务 5-连接MySQL + 修改密码 先去官网下载点击的MySQL的下载 下载完成后解压 解压完是这个样子 配置初始化的my.ini文件的文件 ...

Python+OpenCV计算机视觉

Python+OpenCV计算机视觉系统全面的介绍。

Vue.js 2.0之全家桶系列视频课程

基于新的Vue.js 2.3版本, 目前新全的Vue.js教学视频,让你少走弯路,直达技术前沿! 1. 包含Vue.js全家桶(vue.js、vue-router、axios、vuex、vue-cli、webpack、ElementUI等) 2. 采用笔记+代码案例的形式讲解,通俗易懂

navicat(内含激活码)

navicat支持mysql的可视化操作,内涵激活码,不用再忍受弹框的痛苦。

HTML期末大作业

这是我自己做的HTML期末大作业,花了很多时间,稍加修改就可以作为自己的作业了,而且也可以作为学习参考

150讲轻松搞定Python网络爬虫

【为什么学爬虫?】 &nbsp; &nbsp; &nbsp; &nbsp;1、爬虫入手容易,但是深入较难,如何写出高效率的爬虫,如何写出灵活性高可扩展的爬虫都是一项技术活。另外在爬虫过程中,经常容易遇到被反爬虫,比如字体反爬、IP识别、验证码等,如何层层攻克难点拿到想要的数据,这门课程,你都能学到! &nbsp; &nbsp; &nbsp; &nbsp;2、如果是作为一个其他行业的开发者,比如app开发,web开发,学习爬虫能让你加强对技术的认知,能够开发出更加安全的软件和网站 【课程设计】 一个完整的爬虫程序,无论大小,总体来说可以分成三个步骤,分别是: 网络请求:模拟浏览器的行为从网上抓取数据。 数据解析:将请求下来的数据进行过滤,提取我们想要的数据。 数据存储:将提取到的数据存储到硬盘或者内存中。比如用mysql数据库或者redis等。 那么本课程也是按照这几个步骤循序渐进的进行讲解,带领学生完整的掌握每个步骤的技术。另外,因为爬虫的多样性,在爬取的过程中可能会发生被反爬、效率低下等。因此我们又增加了两个章节用来提高爬虫程序的灵活性,分别是: 爬虫进阶:包括IP代理,多线程爬虫,图形验证码识别、JS加密解密、动态网页爬虫、字体反爬识别等。 Scrapy和分布式爬虫:Scrapy框架、Scrapy-redis组件、分布式爬虫等。 通过爬虫进阶的知识点我们能应付大量的反爬网站,而Scrapy框架作为一个专业的爬虫框架,使用他可以快速提高我们编写爬虫程序的效率和速度。另外如果一台机器不能满足你的需求,我们可以用分布式爬虫让多台机器帮助你快速爬取数据。 &nbsp; 从基础爬虫到商业化应用爬虫,本套课程满足您的所有需求! 【课程服务】 专属付费社群+每周三讨论会+1v1答疑

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

基于STM32的电子时钟设计

时钟功能 还有闹钟功能,温湿度功能,整点报时功能 你值得拥有

学生成绩管理系统(PHP + MYSQL)

做的是数据库课程设计,使用的php + MySQL,本来是黄金搭配也就没啥说的,推荐使用wamp服务器,里面有详细的使用说明,带有界面的啊!呵呵 不行的话,可以给我留言!

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

程序员的兼职技能课

获取讲师答疑方式: 在付费视频第一节(触摸命令_ALL)片头有二维码及加群流程介绍 限时福利 原价99元,今日仅需39元!购课添加小助手(微信号:itxy41)按提示还可领取价值800元的编程大礼包! 讲师介绍: 苏奕嘉&nbsp;前阿里UC项目工程师 脚本开发平台官方认证满级(六级)开发者。 我将如何教会你通过【定制脚本】赚到你人生的第一桶金? 零基础程序定制脚本开发课程,是完全针对零脚本开发经验的小白而设计,课程内容共分为3大阶段: ①前期将带你掌握Q开发语言和界面交互开发能力; ②中期通过实战来制作有具体需求的定制脚本; ③后期将解锁脚本的更高阶玩法,打通任督二脉; ④应用定制脚本合法赚取额外收入的完整经验分享,带你通过程序定制脚本开发这项副业,赚取到你的第一桶金!

实用主义学Python(小白也容易上手的Python实用案例)

原价169,限时立减100元! 系统掌握Python核心语法16点,轻松应对工作中80%以上的Python使用场景! 69元=72讲+源码+社群答疑+讲师社群分享会&nbsp; 【哪些人适合学习这门课程?】 1)大学生,平时只学习了Python理论,并未接触Python实战问题; 2)对Python实用技能掌握薄弱的人,自动化、爬虫、数据分析能让你快速提高工作效率; 3)想学习新技术,如:人工智能、机器学习、深度学习等,这门课程是你的必修课程; 4)想修炼更好的编程内功,优秀的工程师肯定不能只会一门语言,Python语言功能强大、使用高效、简单易学。 【超实用技能】 从零开始 自动生成工作周报 职场升级 豆瓣电影数据爬取 实用案例 奥运冠军数据分析 自动化办公:通过Python自动化分析Excel数据并自动操作Word文档,最终获得一份基于Excel表格的数据分析报告。 豆瓣电影爬虫:通过Python自动爬取豆瓣电影信息并将电影图片保存到本地。 奥运会数据分析实战 简介:通过Python分析120年间奥运会的数据,从不同角度入手分析,从而得出一些有趣的结论。 【超人气老师】 二两 中国人工智能协会高级会员 生成对抗神经网络研究者 《深入浅出生成对抗网络:原理剖析与TensorFlow实现》一书作者 阿里云大学云学院导师 前大型游戏公司后端工程师 【超丰富实用案例】 0)图片背景去除案例 1)自动生成工作周报案例 2)豆瓣电影数据爬取案例 3)奥运会数据分析案例 4)自动处理邮件案例 5)github信息爬取/更新提醒案例 6)B站百大UP信息爬取与分析案例 7)构建自己的论文网站案例

Java8零基础入门视频教程

这门课程基于主流的java8平台,由浅入深的详细讲解了java SE的开发技术,可以使java方向的入门学员,快速扎实的掌握java开发技术!

Python数据挖掘简易入门

&nbsp; &nbsp; &nbsp; &nbsp; 本课程为Python数据挖掘方向的入门课程,课程主要以真实数据为基础,详细介绍数据挖掘入门的流程和使用Python实现pandas与numpy在数据挖掘方向的运用,并深入学习如何运用scikit-learn调用常用的数据挖掘算法解决数据挖掘问题,为进一步深入学习数据挖掘打下扎实的基础。

零基础学C#编程—C#从小白到大咖

本课程从初学者角度出发,提供了C#从入门到成为程序开发高手所需要掌握的各方面知识和技术。 【课程特点】 1 由浅入深,编排合理; 2 视频讲解,精彩详尽; 3 丰富实例,轻松易学; 4 每章总结配有难点解析文档。 15大章节,228课时,1756分钟与你一同进步!

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

多功能数字钟.zip

利用数字电子计数知识设计并制作的数字电子钟(含multisim仿真),该数字钟具有显示星期、24小时制时间、闹铃、整点报时、时间校准功能

极简JAVA学习营第四期(报名以后加助教微信:eduxy-1)

想学好JAVA必须要报两万的培训班吗? Java大神勿入 如果你: 零基础想学JAVA却不知道从何入手 看了一堆书和视频却还是连JAVA的环境都搭建不起来 囊中羞涩面对两万起的JAVA培训班不忍直视 在职没有每天大块的时间专门学习JAVA 那么恭喜你找到组织了,在这里有: 1. 一群志同道合立志学好JAVA的同学一起学习讨论JAVA 2. 灵活机动的学习时间完成特定学习任务+每日编程实战练习 3. 热心助人的助教和讲师及时帮你解决问题,不按时完成作业小心助教老师的家访哦 上一张图看看前辈的感悟: &nbsp; &nbsp; 大家一定迫不及待想知道什么是极简JAVA学习营了吧,下面就来给大家说道说道: 什么是极简JAVA学习营? 1. 针对Java小白或者初级Java学习者; 2. 利用9天时间,每天1个小时时间; 3.通过 每日作业 / 组队PK / 助教答疑 / 实战编程 / 项目答辩 / 社群讨论 / 趣味知识抢答等方式让学员爱上学习编程 , 最终实现能独立开发一个基于控制台的‘库存管理系统’ 的学习模式 极简JAVA学习营是怎么学习的? &nbsp; 如何报名? 只要购买了极简JAVA一:JAVA入门就算报名成功! &nbsp;本期为第四期极简JAVA学习营,我们来看看往期学员的学习状态: 作业看这里~ &nbsp; 助教的作业报告是不是很专业 不交作业打屁屁 助教答疑是不是很用心 &nbsp; 有奖抢答大家玩的很嗨啊 &nbsp; &nbsp; 项目答辩终于开始啦 &nbsp; 优秀者的获奖感言 &nbsp; 这是答辩项目的效果 &nbsp; &nbsp; 这么细致的服务,这么好的氛围,这样的学习效果,需要多少钱呢? 不要1999,不要199,不要99,只要9.9 是的你没听错,只要9.9以上所有就都属于你了 如果你: 1、&nbsp;想学JAVA没有基础 2、&nbsp;想学JAVA没有整块的时间 3、&nbsp;想学JAVA没有足够的预算 还等什么?赶紧报名吧,抓紧抢位,本期只招300人,错过只有等时间待定的下一期了 &nbsp; 报名请加小助手微信:eduxy-1 &nbsp; &nbsp;

Python可以这样学(第一季:Python内功修炼)

董付国系列教材《Python程序设计基础》、《Python程序设计(第2版)》、《Python可以这样学》配套视频,讲解Python 3.5.x和3.6.x语法、内置对象用法、选择与循环以及函数设计与使用、lambda表达式用法、字符串与正则表达式应用、面向对象编程、文本文件与二进制文件操作、目录操作与系统运维、异常处理结构。

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

机器学习实战系列套餐(必备基础+经典算法+案例实战)

机器学习实战系列套餐以实战为出发点,帮助同学们快速掌握机器学习领域必备经典算法原理并结合Python工具包进行实战应用。建议学习顺序:1.Python必备工具包:掌握实战工具 2.机器学习算法与实战应用:数学原理与应用方法都是必备技能 3.数据挖掘实战:通过真实数据集进行项目实战。按照下列课程顺序学习即可! 课程风格通俗易懂,用最接地气的方式带领大家轻松进军机器学习!提供所有课程代码,PPT与实战数据,有任何问题欢迎随时与我讨论。

Java面试题大全(2020版)

发现网上很多Java面试题都没有答案,所以花了很长时间搜集整理出来了这套Java面试题大全,希望对大家有帮助哈~ 本套Java面试题大全,全的不能再全,哈哈~ 一、Java 基础 1. JDK 和 JRE 有什么区别? JDK:Java Development Kit 的简称,java 开发工具包,提供了 java 的开发环境和运行环境。 JRE:Java Runtime Environ...

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

HoloLens2开发入门教程

本课程为HoloLens2开发入门教程,讲解部署开发环境,安装VS2019,Unity版本,Windows SDK,创建Unity项目,讲解如何使用MRTK,编辑器模拟手势交互,打包VS工程并编译部署应用到HoloLens上等。

几率大的Redis面试题(含答案)

本文的面试题如下: Redis 持久化机制 缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级等问题 热点数据和冷数据是什么 Memcache与Redis的区别都有哪些? 单线程的redis为什么这么快 redis的数据类型,以及每种数据类型的使用场景,Redis 内部结构 redis的过期策略以及内存淘汰机制【~】 Redis 为什么是单线程的,优点 如何解决redis的并发竞争key问题 Red...

MFC一站式终极全套课程包

该套餐共包含从C小白到C++到MFC的全部课程,整套学下来绝对成为一名C++大牛!!!

【数据结构与算法综合实验】欢乐连连看(C++ & MFC)案例

这是武汉理工大学计算机学院数据结构与算法综合实验课程的第三次项目:欢乐连连看(C++ & MFC)迭代开发代码。运行环境:VS2017。已经实现功能:开始游戏、消子、判断胜负、提示、重排、计时、帮助。

YOLOv3目标检测实战:训练自己的数据集

YOLOv3是一种基于深度学习的端到端实时目标检测方法,以速度快见长。本课程将手把手地教大家使用labelImg标注和使用YOLOv3训练自己的数据集。课程分为三个小项目:足球目标检测(单目标检测)、梅西目标检测(单目标检测)、足球和梅西同时目标检测(两目标检测)。 本课程的YOLOv3使用Darknet,在Ubuntu系统上做项目演示。包括:安装Darknet、给自己的数据集打标签、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算和画出PR曲线)和先验框聚类。 Darknet是使用C语言实现的轻型开源深度学习框架,依赖少,可移植性好,值得深入探究。 除本课程《YOLOv3目标检测实战:训练自己的数据集》外,本人推出了有关YOLOv3目标检测的系列课程,请持续关注该系列的其它课程视频,包括: 《YOLOv3目标检测实战:交通标志识别》 《YOLOv3目标检测:原理与源码解析》 《YOLOv3目标检测:网络模型改进方法》 敬请关注并选择学习!

u-boot-2015.07.tar.bz2

uboot-2015-07最新代码,喜欢的朋友请拿去

相关热词 c#跨线程停止timer c#批量写入sql数据库 c# 自动安装浏览器 c#语言基础考试题 c# 偏移量打印是什么 c# 绘制曲线图 c#框体中的退出函数 c# 按钮透明背景 c# idl 混编出错 c#在位置0处没有任何行
立即提问