高级语言讲义2021软专(仅高级语言部分)

2024-03-10 17:52

本文主要是介绍高级语言讲义2021软专(仅高级语言部分),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.一个二维数组,每一行存放一个字符串,比较字符串并排序。

#include <stdio.h>int strcmp(char *str,char *flag) {int i=0;while(str[i]!='\0'&&flag[i]!='\0') {if(str[i]>flag[i])return 1;else if(str[i]<flag[i])return -1;elsei++;}if(str[i]=='\0'&&flag[i]=='\0')return 0;else if(str[i]=='\0')return -1;elsereturn 1;
}void strcpy(char *flag,char *str) {int i=0;while(str[i]!='\0') {flag[i]=str[i];i++;}flag[i]='\0';
}void sort(char st[][10],int n) {char temp[10];for(int i=0; i<n-1; i++)for(int j=0; j<n-i-1; j++)if(strcmp(st[j],st[j+1])>0) {strcpy(temp,st[j]);strcpy(st[j],st[j+1]);strcpy(st[j+1],temp);}
}int main() {char st[][10] = {"hello","world","python","C","java","R"};int n=6;sort(st,n);for(int i=0; i<n; i++)printf("%s ",st[i]);printf("\n");return 0;
}

2.一行n(n大于等于2)个框,三个颜色,每个相邻的框颜色不能相同,用递归写出有多少种方法

#include <stdio.h>
#include <stdbool.h>bool islegal(int *path,int n) {for(int i=0; i<n; i++)if(path[i]==path[i-1]||path[i]==path[i+1])return false;return true;
}void dfs(int *path,int n,int index,int *num) {if(index==n) {if(islegal(path,n))*num++;return;}for(int i=0; i<=2; i++) {path[index]=i;dfs(path,n,index+1,num);}
}int count(int n) {int path[20];int num=0;dfs(path,n,0,&num);return num;
}

3.定义结构体,链表输入学生数据,再输入到文件中。

#include <stdio.h>
#include <stdlib.h>typedef struct stu {int num;char name[20];int sex;struct stu *next;
} stu;struct stu *create(int n) {struct stu *head=(struct stu*)malloc(sizeof(struct stu));head->next=NULL;struct stu *pre=head;for(int i=0; i<n; i++) {struct stu *p=(struct stu*)malloc(sizeof(struct stu));scanf("%d",&p->num);scanf("%s",&p->name);scanf("%d",&p->sex);while(p->next!=NULL&&pre->next->num<p->num)pre=pre->next;p->next=pre->next;pre->next=p;pre=head;}return head->next;
}

4.将该链表按性别拆分为两个链表并排序,再写到两个文件中

#include <stdio.h>
#include <stdlib.h>typedef struct stu {int num;char name[20];int sex;struct stu *next;
} stu;void save(struct stu *head) {FILE *fileA,*fileB;if((fileA=fopen("man.txt","w"))==NULL) {printf("open error");exit(0);}if((fileB=fopen("woman.txt","w"))==NULL) {printf("open error");exit(0);}struct stu *p=head;struct stu *headA=(struct stu *)malloc(sizeof(struct stu));struct stu *headB=(struct stu *)malloc(sizeof(struct stu));struct stu *rearA=headA,*rearB=headB;while(p!=NULL) {struct stu *flag=p->next;if(p->sex==1) {rearA->next=p;rearA=p;fprintf(fileA,"%d %s",p->num,p->name);fprintf(fileA,"man");} else {rearB->next=p;rearB=p;fprintf(fileB,"%d %s",p->num,p->name);fprintf(fileB,"woman");}p=flag;}rearA->next=NULL;rearB->next=NULL;fclose(fileA);fclose(fileB);}

这篇关于高级语言讲义2021软专(仅高级语言部分)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/795027

相关文章

Go语言中泄漏缓冲区的问题解决

《Go语言中泄漏缓冲区的问题解决》缓冲区是一种常见的数据结构,常被用于在不同的并发单元之间传递数据,然而,若缓冲区使用不当,就可能引发泄漏缓冲区问题,本文就来介绍一下问题的解决,感兴趣的可以了解一下... 目录引言泄漏缓冲区的基本概念代码示例:泄漏缓冲区的产生项目场景:Web 服务器中的请求缓冲场景描述代码

Go语言如何判断两张图片的相似度

《Go语言如何判断两张图片的相似度》这篇文章主要为大家详细介绍了Go语言如何中实现判断两张图片的相似度的两种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 在介绍技术细节前,我们先来看看图片对比在哪些场景下可以用得到:图片去重:自动删除重复图片,为存储空间"瘦身"。想象你是一个

Go语言中Recover机制的使用

《Go语言中Recover机制的使用》Go语言的recover机制通过defer函数捕获panic,实现异常恢复与程序稳定性,具有一定的参考价值,感兴趣的可以了解一下... 目录引言Recover 的基本概念基本代码示例简单的 Recover 示例嵌套函数中的 Recover项目场景中的应用Web 服务器中

Apache 高级配置实战之从连接保持到日志分析的完整指南

《Apache高级配置实战之从连接保持到日志分析的完整指南》本文带你从连接保持优化开始,一路走到访问控制和日志管理,最后用AWStats来分析网站数据,对Apache配置日志分析相关知识感兴趣的朋友... 目录Apache 高级配置实战:从连接保持到日志分析的完整指南前言 一、Apache 连接保持 - 性

Go语言中使用JWT进行身份验证的几种方式

《Go语言中使用JWT进行身份验证的几种方式》本文主要介绍了Go语言中使用JWT进行身份验证的几种方式,包括dgrijalva/jwt-go、golang-jwt/jwt、lestrrat-go/jw... 目录简介1. github.com/dgrijalva/jwt-go安装:使用示例:解释:2. gi

Go 语言中的 Struct Tag 的用法详解

《Go语言中的StructTag的用法详解》在Go语言中,结构体字段标签(StructTag)是一种用于给字段添加元信息(metadata)的机制,常用于序列化(如JSON、XML)、ORM映... 目录一、结构体标签的基本语法二、json:"token"的具体含义三、常见的标签格式变体四、使用示例五、使用

mysql中的group by高级用法详解

《mysql中的groupby高级用法详解》MySQL中的GROUPBY是数据聚合分析的核心功能,主要用于将结果集按指定列分组,并结合聚合函数进行统计计算,本文给大家介绍mysql中的groupby... 目录一、基本语法与核心功能二、基础用法示例1. 单列分组统计2. 多列组合分组3. 与WHERE结合使

Go语言使用slices包轻松实现排序功能

《Go语言使用slices包轻松实现排序功能》在Go语言开发中,对数据进行排序是常见的需求,Go1.18版本引入的slices包提供了简洁高效的排序解决方案,支持内置类型和用户自定义类型的排序操作,本... 目录一、内置类型排序:字符串与整数的应用1. 字符串切片排序2. 整数切片排序二、检查切片排序状态:

PyTorch高级特性与性能优化方式

《PyTorch高级特性与性能优化方式》:本文主要介绍PyTorch高级特性与性能优化方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、自动化机制1.自动微分机制2.动态计算图二、性能优化1.内存管理2.GPU加速3.多GPU训练三、分布式训练1.分布式数据

基于Go语言实现Base62编码的三种方式以及对比分析

《基于Go语言实现Base62编码的三种方式以及对比分析》Base62编码是一种在字符编码中使用62个字符的编码方式,在计算机科学中,,Go语言是一种静态类型、编译型语言,它由Google开发并开源,... 目录一、标准库现状与解决方案1. 标准库对比表2. 解决方案完整实现代码(含边界处理)二、关键实现细