C语言,键盘输入一个2位以上的任意数,输出这个数的第m位开始,到第n位结束的数。

C语言,键盘输入一个2位以上的任意数,输出这个数的第m位开始,到第n位结束的数。(n>m),例如:12345,m=2,n=4时,输出234... C语言,键盘输入一个2位以上的任意数,输出这个数的第m位开始,到第n位结束的数。(n>m),例如:12345,m=2,n=4时,输出234 展开
 我来答
百度网友e133476
2019-06-07 · TA获得超过1080个赞
知道答主
回答量:70
采纳率:0%
帮助的人:9638
展开全部

该设计有两个思路,即对数据进行处理分离出各个位数,或将数据直接作为字符串读取进来对字符串进行分割。

1、对数据进行处理

程序及运行结果如下:

程序分析:

该程序读取数据后通过除法运算分离出个位、十位…并依次存放在数组中,在通过循环将所需位数读取进来。程序基本满足要求,但计算量需要进行多次除法,且输入数据受数据类型影响较大,容易出现数据溢出。

2、将数据当成字符串处理

程序及运行结果如下:

程序分析:

该程序读取需要处理的数据时将其作为字符串读入,根据字符串长度及其他必要的数据将需要的字符串子串输出。

比较原程序,处理输入数据值长度增加,不再受数据类型影响,而受字符串长度影响,且将需要进行计算部分简化为地址的调整,优化了系统整体性能,但对于读入数据的真实数据调用较麻烦。

扩展资料

C语言对数据类型比较敏感,且数据类型的相关属性还与编译器有关,实际使用时应注意不同类型的大致范围,避免溢出。对于大数可以通过字符串、结构体或链表来表示和进行处理。

常见基本类型占用空间和数值范围对应较为复杂,可以通过以下思路进行对应:

1、通过调用sizeof(数据类型)读取数据类型占用的空间,该函数返回数值单位是字节。

2、通过字节与Bit的对应了解数据空间占据的位数。

3、通过进制转换即可了解该数据类型表达的数据大小,对于有符号数采用首位存储符号,故存储数据的位数比同类型无符号数少1。

以上可用于熟悉C语言常见数据类型的占用空间和数值范围。

xuzhouliuying
高粉答主

2017-12-16 · 繁杂信息太多,你要学会辨别
知道顶级答主
回答量:5.4万
采纳率:86%
帮助的人:2.5亿
展开全部
#include <stdio.h>
void main(){
int i=0,j,k,m,n,t,a[100];
scanf("%d,m=%d,n=%d",&k,&m,&n);
while(k)
{a[i]=k%10;k/=10;i++;}
for(j=0;j<i/2;j++)
{t=a[j];a[j]=a[i-j-1];a[i-j-1]=t;}
if(m<1||m>n||n>i)
printf("Input error!");
else
for(j=m-1;j<n;j++)
printf("%d",a[j]);
}

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
藤原子大雄
2017-12-16 · TA获得超过7197个赞
知道大有可为答主
回答量:6977
采纳率:82%
帮助的人:1748万
展开全部
方法其实很简单,主要是提取确定位数整数的各个位数,主要利用除法运算和取余运算就可以实现!我来说一下整个过程吧,以后见到类似的题目就可以举一反三了!方法的重点是:(1)对某个整数对相应的最高位数为1的整数(如:三位的345对应100的整数)相除可取到最高位的整数(2)再把原数对对应的整数取余,得到出去最高位数之后的数(345%100=45)(3)再重复执行(1),(2)步骤直到取出个位的整数为止,即可求出所有位上的整数!所以,以上题目的代码是:#include<iostream.h>int main(){ int a ; cout<<"请输入一个两位数的整数"<<endl; /*一下循环作用是:检验输入的整数是否为两位数, 如果是则退出,不是则提示并继续输入,直到输入 的数是两位数的整数为止! */ while(cin>>a) { if(a<100 && a>=10) break; cout<<"输入非法!请输入两位数的整数!"<<endl; } cout<<a<<"的十位数是:"<<a/10<<" ,个位数是:"<<a%10<<endl; return 0;}在VC6.0里验证如下:
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式