一个简单的c++程序
判断一个自然数是否是降序数,并求其各个数位上的数之和:#include"iostream.h"boolf(int&x);voidmain(){intx;cin>>x;if...
判断一个自然数是否是降序数,并求其各个数位上的数之和:
#include"iostream.h"
bool f(int&x);
void main()
{int x;
cin>>x;
if(f(x))
cout<<"yes"<<endl;
else
cout<<"no"<<endl;
}
bool f(int&x)
{int a,b,c,s=0;
a=x;
while(a)
{b=a%10;
a/=10;
s+=b;}
cout<<"各位数之和为="<<s<<endl;
while(x>=10)
{if(x/10%10>=x%10)
{c=1;x/=10;}
else
c=0;}
return c;
}
为什么最后只能输出各位数之和但不能判断是否为降序数%>_<%
大家帮帮忙啊 展开
#include"iostream.h"
bool f(int&x);
void main()
{int x;
cin>>x;
if(f(x))
cout<<"yes"<<endl;
else
cout<<"no"<<endl;
}
bool f(int&x)
{int a,b,c,s=0;
a=x;
while(a)
{b=a%10;
a/=10;
s+=b;}
cout<<"各位数之和为="<<s<<endl;
while(x>=10)
{if(x/10%10>=x%10)
{c=1;x/=10;}
else
c=0;}
return c;
}
为什么最后只能输出各位数之和但不能判断是否为降序数%>_<%
大家帮帮忙啊 展开
展开全部
#include "stdafx.h"
#include"iostream.h"
bool f(int&x);
void main()
{
int x;
cin>>x;
if(f(x))
cout<<"yes"<<endl;
else
cout<<"no"<<endl;
}
bool f(int&x)
{
int a,b,c,s=0;
a=x;
while(a)
{
b=a%10;
a/=10;
s+=b;
}
cout<<"各位数之和为="<<s<<endl;
while(x>=10)
{
if(x/10%10>=x%10)
{
c=1;
x/=10;
}
else
{
c=0;
break;
}
}
return c;
}
#include"iostream.h"
bool f(int&x);
void main()
{
int x;
cin>>x;
if(f(x))
cout<<"yes"<<endl;
else
cout<<"no"<<endl;
}
bool f(int&x)
{
int a,b,c,s=0;
a=x;
while(a)
{
b=a%10;
a/=10;
s+=b;
}
cout<<"各位数之和为="<<s<<endl;
while(x>=10)
{
if(x/10%10>=x%10)
{
c=1;
x/=10;
}
else
{
c=0;
break;
}
}
return c;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include<stdio.h>
#include<stdlib.h>
int main()
{
int m[100], n, i, j;
puts("请输入一个正整数:");
scanf("%d",&n);//为便于分析,假设n=321
for (i=0; n!=0 ; i++)
{
m[i] = n%10; //几次循环下来,赋值结果为:
n=n/10; //i=0 m[0]=1 n=32; i=1 m[1]=2 n=3; i=2 m[2]=3 n=0---->i=3时循环结束
}
for (j=0; (j<i-1 )&& (m[j]<m[j+1]); j++) ; //m[j]<m[j+1]是依次从低位到次低位的比较
if (j==i-1)
puts("是降序数!");
else
puts("不是降序数!");
system("pause");
return 0;
}
#include<stdlib.h>
int main()
{
int m[100], n, i, j;
puts("请输入一个正整数:");
scanf("%d",&n);//为便于分析,假设n=321
for (i=0; n!=0 ; i++)
{
m[i] = n%10; //几次循环下来,赋值结果为:
n=n/10; //i=0 m[0]=1 n=32; i=1 m[1]=2 n=3; i=2 m[2]=3 n=0---->i=3时循环结束
}
for (j=0; (j<i-1 )&& (m[j]<m[j+1]); j++) ; //m[j]<m[j+1]是依次从低位到次低位的比较
if (j==i-1)
puts("是降序数!");
else
puts("不是降序数!");
system("pause");
return 0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询