输入一个数字,从其中删除一位使得余下的数字是最大的,并输出。C语言实现
5个回答
展开全部
#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;
}
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;
}
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这是你要的逻辑。肯定没错。
#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);
}
#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);
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#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;
}
#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;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
输入一个数字: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");
}
要删除第几位? 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 ? 但是这个不是最大啊
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
觉得分析下数学逻辑吧,先看递增,再看递减
#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;
}
#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;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询