C语言入门级教程五

2024-06-09 21:18
文章标签 语言 教程 入门级

本文主要是介绍C语言入门级教程五,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 C语言入门级教程                  icesongqiang


2016.11.14

本次试验暴露出来的一些问题:
1. if() 条件判断等于,里面一定是if(a==b) , 而if(a=b) 执行赋值操作,赋值的数就是表达式的值;
2. 字符串拼接,将char b[80] 拼接到 char a[80] 后,一定要添加 '\0' ;
3. 单词统计很多同学的统计结果会与真实的相差一个,或多或少,因为没有考虑字符串是不是以空格结束,空格的数量是多少等等。

4.此外,这次试验还是有很多同学用了一些还没学的函数,有提高要求的同学可以试试,但是基础学习的过程中不倡导,建议大家还是以基础为重

5.关于goto, 基本用goto的都可以用条件语句替换掉,要多考虑程序流程,goto提供简单易操作的同时,也会带来扰乱逻辑的困扰。

单词个数统计

#include<stdio.h>
void main()
{
char a[100],i;
int word=0;
printf("please input a sentence\n");
gets(a);
for(i=1;a[i]!='\0';i++)if(a[i]==' '&&a[i-1]!=' ')word=word+1;
if(a[i-1]!=' ') ++word; // 没有以空格结束,不加1会漏数一个     
printf("%d",word);
}

更严格的,还应该考虑到数字嵌入英文序列中。

// by qiankun
#include <stdlib.h>
#include <string.h>
#define LU(a,l,u) (a>=l && a<=u) 
#define isalpha(a) (LU(a,65,90)||LU(a,97,122))
int ct_words(char str[])
{int i = 0,ct = 0;while (str[i]!='\0'){if (isalpha(str[i])){do {i++;} while (isalpha(str[i]));ct++;}else i++;}return ct;
}
void main()
{char str[1000];printf("输入一段英文,统计单词个数\n");gets_s(str,1000);printf("\nthere are %d words in this passage", ct_words(str));
}

约瑟夫问题

/ 约瑟夫问题
/*
**序号说明:只在输入和输出时调整0-1开始,内部计算均从0开始
**1.确定每个位置上的人的被处决顺序
**2.按处决顺序输出位数索引即可
@author: icesongqiang
@version:v0
@time:Nov-12-2016
*/#include <stdio.h>
#include <stdlib.h>
#include <malloc.h>  // for macoll(), free()// 函数声明
int Jose_people_index(int order, int N, int *Jose);
void printinOrder(int N, int *Jose);
void Josephus(int start, int m, int N);/*
argv: start, m, N
** 从start开始数1,每数到m的人就执行处决;报数N个人一圈,即(N-1)的报数后由(0)位置上的接着报数
** 每次报到m就有一个人被处决,上述过程重复N-1次,就可以退出
*/
void Josephus(int start, int m, int N)
{int *Jose = (int *)malloc(N * sizeof(int));    // 申请堆内存 N 个int// 数组Jose N个元素全部初始化为N-1for (int i = 0; i < N; ++i){Jose[i] = N - 1;}int cnt = 0, count = 0, current_index = start;while (count != N - 1){                       // 直到处决人数为N-1个退出      if (*(Jose + current_index) == N-1){      // 未被处决的人才参与报数if (++cnt == m){                      // 报数到m的人被处决后本次结束,开始下一轮报数cnt = 0;                          // 报数清零*(Jose+current_index) = count++;  // 数组位置上的数修改为处决顺序             }}current_index = (current_index + 1) % N;  // 下一个位置的索引}// 现在每个slot里的数就是被处决的序号,可以排序后输出索引printinOrder(N, Jose);for (int i = 0; i < N; ++i){Jose[i] = 0;}free(Jose);
}/*
**找到第order个被处决的人的位置号
*argv: 
*order 被处决的顺序
*N: 总人数
*Jose: 数组,在slot中存放该位置的人被处决的顺序
*/
int Jose_people_index(int order, int N, int *Jose)
{int index = 0;for (; index < N; ++index){if (*(Jose + index) == order){break;}}return (index == N ? -1 : index);
}/*
** 按处决顺序输出人的序号,最后一个为活着的人,
** 按用户习惯,从1开始标记
*/
void printinOrder(int N, int *Jose)
{printf("处决顺序如下:\n");for (int i = 0; i < N-1; ++i){printf("%d ", 1+Jose_people_index(i, N, Jose));}printf("\n最后活着的人是:\n");printf("%d ", 1+Jose_people_index(N-1, N, Jose));
}/*
*  测试, 只在输入和输出时调整0-1开始,内部计算均从0开始
** 按用户习惯,从1开始标记
*/
int main()
{int start = 4, m = 3;int N = 9;Josephus(start-1, m, N);getchar(); getchar();return 0;
}

实际上, 约瑟夫问题有递推公式,假设(N,m)的最后解为函数 f(n,m) 的值,那么,

f(n,m){0,(f(n1,m)+m)%n,n=1n>1

可以编写代码如下

/*公式法解约瑟夫问题*/
#include <stdio.h>
const int N = 10;
int Jose_people(n,m)
{if(n < 1 || m < 1) return -1;int last = 0;for(int n =2; n<=N; ++n){last = (last + m) % n;}return last;
}

排序算法

排序算法提前终止就是加标志的过程。
// by qiankun
#include <stdio.h>
int sort_quit(int data[], int NUM)
{int changeflag=0;                  // 标志位设定int tmp;for (int i=0;i<NUM-1;i++){changeflag = 0;               // 外层循环每次赋值为0for (int j=0;j<NUM -1 -i;j++){if (data[j]>data[j+1]){tmp = data[j]; data[j] = data[j + 1]; data[j + 1] = data[j];changeflag = 1;       // 有数据交换表示未完全排序好}}if (!changeflag)return 1;     // 如果没有发生过交换,就表示已经排好序,可以提前退出了}return 0;
}// 省略主函数main

数字转字符串(递归)

// by qiankun
#include <string.h>
#include <stdlib.h>
#include <limits.h>void recu_print(unsigned long long num)
{if (num == 0)return;recu_print(num/10);printf("%c ", num % 10 + '0');
}
void main()
{long long num;unsigned long long num2;printf("递归打印一个整数,下界%lld,上界%lld\n", LLONG_MIN, LLONG_MAX);scanf("%lld", &num);printf("number is %lld\nprint as string is :\n", num);num2 = num > 0 ? num : -num;if(num<0)printf("-");recu_print(num2);printf("\n");
}

字符串拼接

/* 两个循环即可
* icesongqiang
*/
#include <stdio.h>
#include <string.h>
int main()
{char a[80];char b[80];gets(a);gets(b);int i = 0, j=0;while(a[i++]!='\0');           // 确定a的长度--i;                           // 减去最后一次多自增的1     while((a[i+j]=b[j++])!='\0');  // 拼接,已经拼接了'\0'puts(a);getchar();return 0;
}

这篇关于C语言入门级教程五的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

Ubuntu固定虚拟机ip地址的方法教程

《Ubuntu固定虚拟机ip地址的方法教程》本文详细介绍了如何在Ubuntu虚拟机中固定IP地址,包括检查和编辑`/etc/apt/sources.list`文件、更新网络配置文件以及使用Networ... 1、由于虚拟机网络是桥接,所以ip地址会不停地变化,接下来我们就讲述ip如何固定 2、如果apt安

PyCharm 接入 DeepSeek最新完整教程

《PyCharm接入DeepSeek最新完整教程》文章介绍了DeepSeek-V3模型的性能提升以及如何在PyCharm中接入和使用DeepSeek进行代码开发,本文通过图文并茂的形式给大家介绍的... 目录DeepSeek-V3效果演示创建API Key在PyCharm中下载Continue插件配置Con

Deepseek R1模型本地化部署+API接口调用详细教程(释放AI生产力)

《DeepseekR1模型本地化部署+API接口调用详细教程(释放AI生产力)》本文介绍了本地部署DeepSeekR1模型和通过API调用将其集成到VSCode中的过程,作者详细步骤展示了如何下载和... 目录前言一、deepseek R1模型与chatGPT o1系列模型对比二、本地部署步骤1.安装oll

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创

Go语言中三种容器类型的数据结构详解

《Go语言中三种容器类型的数据结构详解》在Go语言中,有三种主要的容器类型用于存储和操作集合数据:本文主要介绍三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下... 目录基本概念1. 数组(Array)2. 切片(Slice)3. 映射(Map)对比总结注意事项基本概念在 Go 语言中,有三种主要

Spring Boot整合log4j2日志配置的详细教程

《SpringBoot整合log4j2日志配置的详细教程》:本文主要介绍SpringBoot项目中整合Log4j2日志框架的步骤和配置,包括常用日志框架的比较、配置参数介绍、Log4j2配置详解... 目录前言一、常用日志框架二、配置参数介绍1. 日志级别2. 输出形式3. 日志格式3.1 PatternL

MySQL8.2.0安装教程分享

《MySQL8.2.0安装教程分享》这篇文章详细介绍了如何在Windows系统上安装MySQL数据库软件,包括下载、安装、配置和设置环境变量的步骤... 目录mysql的安装图文1.python访问网址2javascript.点击3.进入Downloads向下滑动4.选择Community Server5.

C语言中自动与强制转换全解析

《C语言中自动与强制转换全解析》在编写C程序时,类型转换是确保数据正确性和一致性的关键环节,无论是隐式转换还是显式转换,都各有特点和应用场景,本文将详细探讨C语言中的类型转换机制,帮助您更好地理解并在... 目录类型转换的重要性自动类型转换(隐式转换)强制类型转换(显式转换)常见错误与注意事项总结与建议类型

CentOS系统Maven安装教程分享

《CentOS系统Maven安装教程分享》本文介绍了如何在CentOS系统中安装Maven,并提供了一个简单的实际应用案例,安装Maven需要先安装Java和设置环境变量,Maven可以自动管理项目的... 目录准备工作下载并安装Maven常见问题及解决方法实际应用案例总结Maven是一个流行的项目管理工具