数组和字符串(分数统计_stat,单词的长度,乘积的末3位,计算器,旋转_rotate,进制转换1_base1,进制转换2_base2,手机键盘)

本文主要是介绍数组和字符串(分数统计_stat,单词的长度,乘积的末3位,计算器,旋转_rotate,进制转换1_base1,进制转换2_base2,手机键盘),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

关于C语言字符串
  • 别人家的整理
  • scanf和gets的区别
字符串输入的方法
  • scanf(“%s”,in_buff);
  • gets(in_buff);
  • fgets(in_buff,BUFFER_SIZE + 1,stdin);

1.当使用scanf函数时,如果在数组范围内有空格,那么第一个空格之后的字符将被忽略,这通常不是我们想要的。另外,scanf函数也不提供对写入数组的数据是否越界的检查。
2.当使用gets函数时,由于gets不提供对写入数组的数据进行是否越界的检查,所以也不安全。
3.而使用fgets函数时,只要第二个参数正好等于第一个参数传给它的数组的字节个数,那么fgets函数不会写出数组边界。所以,fgets函数是最好的选择.

1 分数统计_stat

好像这个办法很笨,不知道有没有好主意==
疑问:当分数为非负实数时(保留两位小数)。嗯,乘以100..==
int main() {int a[101]={0};int i=0,u,max;while(scanf("%.2f",&u)!=EOF){a[u]++;}for(i=0;i<100;i++){if(a[i]>max) max=a[i];}
//输出分数出现次数最多的,如果有多个并列,从小到大输出。for(i=0;i<100;i++){if(a[i]==max) printf("%d\n",i);}return 0;
}
输入:
12 34 56 78 89 12 12 12 34 34 34
输出:
12
34

2 单词的长度

输入一些单词,统计单词的平均长度
#include <stdio.h>
#include<string.h>
#include<ctype.h>
int main() {char s[1000],buf[1000];int sum=0,count=0,i;fgets(buf,sizeof(s),stdin);//从后往前,因为你不知道最后一个是什么时候截止for(i=strlen(buf)-1;i>0;i--){if(buf[i]==' ') count++;else sum++;}printf("%lf\n",(double)sum/count);return 0;
}
//i am best one
输入输出:

输入输出

3 乘积的末3位——product(借鉴)

输入若干个整数,输出他们的成绩的末三位(取余),其中有干扰的字符串
break是结束整个循环体,continue是结束单次循环
一直没搞懂题目是要怎么输入的,认真看“输入若干个“,肯定不是要输入一个字符串,这样就可以使用while!=EOF来循环输出
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAXN 100
#define MOD 1000
char a[MAXN];
int main()
{int i, n;long d= 0, sum= 1;while(scanf("%s", a)!=EOF){n = strlen(a);for(i = 0; i < n; i++){if(a[i] >= 'A' && a[i] <= 'Z') break;//一定要判断是怎么退出的continue;d=(d*10+a[i]-'0')%MOD;}if(a[i] >= 'A' && a[i] <= 'Z') continue;//如果是大写字母,就不用进行乘法sum=sum*d%MOD;d= 0;//这种计数用的,每次都要清零}printf("%3d\n",sum);system("PAUSE");return 0;}
假设输入:
12
H
12
HU
12
输出:
728

4 计算器

编写程序,读入一行恰好包含一个加号、减号或乘号的表达式,输出它的值。这个运算符保证是二元运算符,且两个数均为不超过100的非负整数。运算数和运算符可以紧挨着,也可以用一个或多个空格、TAB隔开。行首末尾均可以有空格。提示:选择合适的输入方法可以将问题简化。
一直想着一步到位的,最后发现没有用。分成两部分反而更好处理,以运算符号为中心分成两个部分计算。
 #include <stdio.h>
#include<string.h>
char buf[1010];
int main() {int m=0,n=0,i,l;int middle;while(fgets(buf,sizeof(buf),stdin)){l=strlen(buf);for(i=0;i<l-1;i++){if(buf[i]=='+'||buf[i]=='-'||buf[i]=='*')middle=i;}for(i=0;i<middle;i++){if(buf[i]==' ') continue;m=m*10+buf[i]-'0';}for(i=middle+1;i<l-1;i++){if(buf[i]==' ') continue;n=n*10+buf[i]-'0';}//  if(buf[i]==' ') continue;//  d=d*10+buf[i]-'0';//   if(buf[i]=='+') {sign=1;m=d;d=0;}//   else if(buf[i]=='-'){sign=-1;m=d;d=0;}//   else if(buf[i]=='*'){sign=0;m=d;d=0;}switch(buf[middle]){case '+':printf("%d\n", m+n);break;case '-':printf("%d\n", m-n);break;case '*':printf("%d\n", m*n);break;}m = 0;n = 0;}return 0;
}
输入:
1+1
2-     5
0   *1982
输出:
2
-3
0

5 旋转_rotate

#include <stdio.h>
#include<stdlib.h>
#include<string.h>
char a[1010][1010],s[1001][1010];
int main() {int i,j,n;scanf("%d",&n);getchar();char temp;
/*   for(i = 0; i < n; i++)scanf("%s", a[i]);*/for(i=0;i<n;i++){for(j=0;j<n;j++)scanf("%c",&a[i][j]);getchar();}
/*  for(i=0;i<n;i++){for(j=0;j<n;j++)printf("%c ",a[i][j]);printf("\n");}*/for(i=0;i<n;i++){for(j=0;j<n;j++){s[i][j]=a[j][n-i-1];printf("%c",s[i][j]);}printf("\n");}return 0;
}
输入:
3
123
456
789
输出:
3
1 2 3
4 5 6
7 8 9

各种旋转

int main(){int a[5][6]={1,3,4,2,5,2,2,3,6,3,8,3,2,9,7,9,4,8,6,3,8,1,9,3,9,3,5,2,8,5,};int s90[6][5],ni90[6][5],x180[5][6];int i,j;printf("顺时针旋转90度矩阵为:\n");for(i=0;i<6;i++){for(j=0;j<5;j++){s90[i][j]=a[4-j][i];printf("%2d%",s90[i][j]);}printf("\n");}printf("逆时针旋转90度矩阵为:\n");for(i=0;i<6;i++){for(j=0;j<5;j++){ni90[i][j]=a[j][5-i];printf("%2d%",ni90[i][j]);}printf("\n");}printf("旋转180度矩阵为:\n");for(i=0;i<5;i++){for(j=0;j<6;j++){x180[i][j]=a[4-i][5-j];printf("%2d%",x180[i][j]);}printf("\n");}
}

6 进制转换1_base1

#include <stdio.h>
int a[100];
int main() {int i=0,b,n;scanf("%d%d",&b,&n);while(n>0){a[i]=n%b;n=n/b;printf("%d",a[i++]);}return 0;
}
输入:
2 15
输出:
1111

7 进制转换2_base2

#include <stdio.h>
int main() {int n,b,k=1;int s=0;scanf("%d%d",&b,&n);while(n>0){s+=n%10*k;k=k*b;n=n/10;}printf("%d",s);return 0;
}
输入:
2 1111
输出:
15

8 手机键盘——keyboard

需要注意限制范围,当输入‘z’时候特殊处理,当输入‘a’到‘y’时取余,没有限制的话会出现又输出个1。原因可能是最后一个输入换行为一个字符’\0’,取余之后为0。
#include <stdio.h>
#include<string.h>
int main() {char a[100];int i=0,k;while(scanf("%c",&a[i])!=EOF){if(a[i]=='z'){printf("%c",a[i]);printf("4");}else if(a[i]>='a'&&a[i]<'z'){k=(a[i]-'a')%3;switch(k){case 0:{printf("%c",a[i]);printf("1");break;}case 1:{printf("%c",a[i]);printf("2");break;}case 2:{printf("%c",a[i]);printf("3");break;}}
/*          if(k==0){printf("%c",a[i]);printf("1");continue;}if(k==1){printf("%c",a[i]);printf("2");continue;}if(k==2){printf("%c",a[i]);printf("3");continue;}*/}i++;}return 0;
}
输入:
pig
输出:
p1i3g1
九宫格输入法示意图:

九宫格

这篇关于数组和字符串(分数统计_stat,单词的长度,乘积的末3位,计算器,旋转_rotate,进制转换1_base1,进制转换2_base2,手机键盘)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

Python中反转字符串的常见方法小结

《Python中反转字符串的常见方法小结》在Python中,字符串对象没有内置的反转方法,然而,在实际开发中,我们经常会遇到需要反转字符串的场景,比如处理回文字符串、文本加密等,因此,掌握如何在Pyt... 目录python中反转字符串的方法技术背景实现步骤1. 使用切片2. 使用 reversed() 函

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

MySQL 获取字符串长度及注意事项

《MySQL获取字符串长度及注意事项》本文通过实例代码给大家介绍MySQL获取字符串长度及注意事项,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql 获取字符串长度详解 核心长度函数对比⚠️ 六大关键注意事项1. 字符编码决定字节长度2

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决

在Linux终端中统计非二进制文件行数的实现方法

《在Linux终端中统计非二进制文件行数的实现方法》在Linux系统中,有时需要统计非二进制文件(如CSV、TXT文件)的行数,而不希望手动打开文件进行查看,例如,在处理大型日志文件、数据文件时,了解... 目录在linux终端中统计非二进制文件的行数技术背景实现步骤1. 使用wc命令2. 使用grep命令

利用Python脚本实现批量将图片转换为WebP格式

《利用Python脚本实现批量将图片转换为WebP格式》Python语言的简洁语法和库支持使其成为图像处理的理想选择,本文将介绍如何利用Python实现批量将图片转换为WebP格式的脚本,WebP作为... 目录简介1. python在图像处理中的应用2. WebP格式的原理和优势2.1 WebP格式与传统

基于 HTML5 Canvas 实现图片旋转与下载功能(完整代码展示)

《基于HTML5Canvas实现图片旋转与下载功能(完整代码展示)》本文将深入剖析一段基于HTML5Canvas的代码,该代码实现了图片的旋转(90度和180度)以及旋转后图片的下载... 目录一、引言二、html 结构分析三、css 样式分析四、JavaScript 功能实现一、引言在 Web 开发中,

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c