输入一个数字,从其中删除一位使得余下的数字是最大的,并输出。C语言实现

 我来答
sparkaround
2012-04-12 · TA获得超过3508个赞
知道大有可为答主
回答量:1522
采纳率:0%
帮助的人:894万
展开全部
#include <stdio.h>
int main(int argc, char **argv)
{
int m;
int i, j;
int len;
int factor;
char digits[32];

scanf("%d:", &m);

len = 0;
while(m){
if(len >= sizeof(digits)){
fprintf(stderr, "不应该发生的错误,数字过大!\n");
}
digits[len] = m % 10;
m /= 10;
len ++;
}

if(len < 2) {
printf("至少两位数!\n");
return 1;
}

/* 从最高位向最低位调整 */
for(i = len - 1; i > 0; i --){
/* 用大的数字占据高位, 除去digits[i] */
if(digits[i] < digits[i - 1]) break;
}
m = 0;
factor = 1;
for(j = 0; j < len; j++){
if(j == i) continue;
m += digits[j] * factor;
factor *= 10;
}
printf("%d\n", m);
return 0;
}
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
libinhao1111
2012-04-12 · TA获得超过1013个赞
知道小有建树答主
回答量:425
采纳率:0%
帮助的人:553万
展开全部
这是你要的逻辑。肯定没错。
#include <math.h>
#include <stdio.h>
void main()
{
int i,n;
int sum=0, result=0;
scanf("%d", &n);

i=1;
while(n>i)
{
result=n/i/10*pow((double)10,log10((double)i)) + n%i;
if(result > sum)
sum = result;
i*=10;
}

printf("%d",sum);
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
leiyangbdwk
2012-04-12 · TA获得超过3295个赞
知道大有可为答主
回答量:4975
采纳率:12%
帮助的人:4351万
展开全部
#include <stdio.h>
#include <math.h>
int len(int num)
{
return int(log10(num)) + 1 ;
}

int Cut(int num,int i)
{
int a,b,l;
l = len(num);
a = num / (int)pow(10,l - i + 1);
b = (num % (int)pow(10,l - i));

return a * (int)pow(10,l - i ) + b ;
}

int main()
{
int num=523456,i,max=0;

for (i = 1;i <= len(num);i++ )
{
if (max < Cut(num,i) )
max = Cut(num,i);
}
printf("%d\n",max);
return 0;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
沧海雄风2009
2012-04-12 · TA获得超过1.1万个赞
知道大有可为答主
回答量:8525
采纳率:79%
帮助的人:2769万
展开全部
输入一个数字:12345
要删除第几位? 3
剩余数字组成的最大数为:5421
Press any key to continue

#include<stdio.h>
main()
{
int i=0,j=0,k=0,wei,inum[20]={0};
char num[20]="\0",tmp[20]={0};
printf("输入一个数字:");
gets(num);
printf("要删除第几位? ");
scanf("%d",&wei);
while (num[i])
{
if (i+1==wei)
{
i++;
}
tmp[j]=num[i++];
inum[k++]=tmp[j++]-'0';
}
for (i=0;i<k-1;i++)
{
for (j=0;j<k-i-1;j++)
{
if (inum[j]<inum[j+1])
{
wei=inum[j];
inum[j]=inum[j+1];
inum[j+1]=wei;
}
}
}
printf("剩余数字组成的最大数为:");
for (i=0;i<k;i++)
{
printf("%d",inum[i]);
}
printf("\n");
}
更多追问追答
追问
顺序不能变啊
追答
顺序不能变 那么就是 1245 ?  但是这个不是最大啊
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友1fc36d4
2012-04-12 · TA获得超过3128个赞
知道大有可为答主
回答量:1497
采纳率:100%
帮助的人:1807万
展开全部
觉得分析下数学逻辑吧,先看递增,再看递减

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int MaxInteger(char *Str)
{
char Buf[50];
char *s=Str,*p=Buf;
int value;
if(Str==NULL) return 0;
if(strlen(Str)==1) return 0;
if(*(s+1)&&*(s+1)>*s)
{
s++;
value=atoi(s);
}
else
{
*p++=*s++;
while(*(s+1)&&*s>*(s+1)) *p++=*s++;
s++;
while(*s) *p++=*s++;
*p='\0';
value=atoi(Buf);
}
return value;
}

int main()
{
char Str[50];
int Data;
gets(Str);
Data=MaxInteger(Str);
printf("%d\n",Data);
system("pause");
return 0;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式