目录
1.删除有序数组中重复的数
2.用除二取余的方法,把任意一个十进制正数的二进制序列输出(不考虑溢出)
2.1如果是把任意一个十进制整数的二进制序列输出呢?
3.输出一个六行六列的整形矩阵,并输出其转置矩阵。矩阵中的元素的十位数是行数,个位数是列数,比如第一行第六列的元素是16
4.编写程序把4位16进制数转换为短整型(short类型)
5.分割字符串
6.二代身份证
7.绝对素数
8.输入一个十进制数N,把他转化成R进制数输出(R是11到16之间的整数),比如R=16,输入90,输出就是5A
9.输入某年某月某日,判断这一天是那年的第几天,并输出本年还剩下多少天。
10.合并文件内容
11.检查字符串str2是否为str1的子串
12.输入10个1~100范围内的整数,删除其中1~50的数,并输出一个新数组。
13.在一个文件A.txt中取出一个矩阵,然后转置后写入到另一个文件B.txt中
14.输入年月日,输出这是今年第几天
15.能否构成三角形
16.把一个二维数组每行的最小值构成一个新的数组输出
1.删除有序数组中重复的数
2.用除二取余的方法,把任意一个十进制正数的二进制序列输出(不考虑溢出)
2.1如果是把任意一个十进制整数的二进制序列输出呢?
3.输出一个六行六列的整形矩阵,并输出其转置矩阵。矩阵中的元素的十位数是行数,个位数是列数,比如第一行第六列的元素是16
4.编写程序把4位16进制数转换为短整型(short类型)
比如FFF8=>-8,过程如下
//FFF8:4位16进制数
//1111 1111 1111 1000:二进制补码
//1000 0000 0000 0111:二进制反码
//1000 0000 0000 1000:二进制原码
法一:考查scanf和printf的占位符写法
法2:库函数法
strtol 是 C 语言标准库中的一个函数,用于将字符串转换成长整型数(long int)。这个函数定义在头文件 中。strtol 的名字是 "string to long" 的缩写,表示其功能是将一个字符串转化为一个长整型数值。
strtol 函数的原型如下:
long int strtol(const char *str, char **endptr, int base);
这个函数接受三个参数:
- const char *str:一个指向要进行转换的以 null 结尾的 C 字符串的指针。
- char **endptr:一个引用指针,用于存储转换后剩余部分字符串的地址。如果不需要这个值,可以传递 NULL。
- int base:转换所采用的数制的基数,它必须在 2 和 36 之间,或者是特殊值 0。对于十进制数,这个值应该是 10;对于十六进制数,应该是 16 等等。如果 base 设置为 0,则会根据字符串格式自动推断基数(例如,以 "0x" 或 "0X" 开头的字符串会被识别为十六进制,以 "0" 开头为八进制,其余为十进制)。
此函数会读取 str,然后根据 base 的值将读取到的内容转换为一个长整型值。转换会忽略任何前导的空白字符(如空格),直到遇到第一个非有效字符或字符串末尾。如果 endptr 不是 NULL,函数还会设置 endptr 指向字符串中未进行转换的第一个字符。
对于类似的任务,比如将字符串转换成 int,可以使用 atoi或者 strtol 函数后再进行类型转换。然而如果字符串表示的数值可能超出 int 类型的范围,最好直接使用 strtol 然后检查返回值是否在 int 的范围之内。
请注意,strtol 能处理的最大数值为 LONG_MAX,最小数值为 LONG_MIN,这些极值定义在头文件 中。若字符串转换的结果超出了 long int 类型能表示的范围,则会发生溢出,并且函数将返回 LONG_MAX 或 LONG_MIN,同时设置 errno 为 ERANGE。
法3:不使用库函数strtol
5.分割字符串
编写toArray函数,其函数原型为int toArray(char* st,char c,int arr[])将字符串str用c所指定的分隔符分割并转换为整型数之后存入整形数组arr,函数返回值是该数组元素个数
运行结果
6.二代身份证
2019
法一:使用库函数
法二:不使用库函数
7.绝对素数
编写代码用来判断一个正整数是否为绝对素数,绝对素数是指这个数本身是素数,他的反置数也是素数,比如37是素数,他的反置数73也是素数,那么这两个数就是绝对素数
如果题目说是让编写一个函数int is_absolute_Prime(int n),我们现在写了好几个函数,显然不复合要求,实际上我们只要在这个is_absolute_Prime()函数中调用我们写的那好几个函数就行。
8.输入一个十进制数N,把他转化成R进制数输出(R是11到16之间的整数),比如R=16,输入90,输出就是5A
法一:转换字符
这种方法应该注意的是当我们拿到一个大于等于10的数时候,我们应该转化成A~F,在上面的代码中我们是要把数字字符转化成字符A~F,因此应该判断当前数字字符是否大于字符10,但是判断条件不能写>='10'而应该写成>'9',这是因为在C语言中'10'会被认为是一个多字符常量,他的ASCII码值并不是‘9’的ASCII码值+1,我们可以通过写一个代码打印他们两个的ASCII码来观察
发现这两个的ASCII码值相差了不是一点半点
因此在判断我们加上'0'之后的ch[i]是否大于'9'的时候就不能写成ch[i]>='10',应该写成ch[i]>'9',同时在转换成A~F的时候也不能直接写成ch[i]-'10'+'A',应该写成ch[i]-'0'-10+'A'。
法二:创建字符数组法
我没每次都是拿到的最低位,余数是几,那么这一位实际上就是几,比如我们拿到了余数5,实际上拿到的这一位就应该是5,打印的时候就要打印字符5,余数是10,就打印字符A。
9.输入某年某月某日,判断这一天是那年的第几天,并输出本年还剩下多少天。
例如输入2020 12 25,则输出是本年的第360天,今年还剩下6天
法一:
代码可以优化一下,让代码看起来更简洁
10.合并文件内容
有3个磁盘文件A.txt,B.txt,C.txt在同一路径下, A.txt,B.txt中各存放一行字母,要求把两个文件的信息合并,且按字母顺序排列好,然后输出到文件C.txt中去
11.检查字符串str2是否为str1的子串
检查字符串str2是否为str1的子串,如果是,返回子串在str1中的位置,如果不是,返回NULL
法一:库函数法
法二:不使用库函数,也即模拟实现strstr
12.输入10个1~100范围内的整数,删除其中1~50的数,并输出一个新数组。
13.在一个文件A.txt中取出一个矩阵,然后转置后写入到另一个文件B.txt中
14.输入年月日,输出这是今年第几天
另一种写法
实际上这道题的关键就在于讨论输入的天是否为闰年的二月之后。
15.能否构成三角形
输入三个整数作为三角形的三条边,看看能否构成三角形,如果能的话输出这个三角形的面积。