
Составить наибольшее число из входных символов
By:
darklagger on
Apr 30th, 2012 | syntax:
C# | size: 2.16 KB | hits: 23 | expires: Never
/*
На вход программе подается последовательность символов, среди которых встречаются и цифры. Ввод символов заканчивается точкой (в программе на языке Бейсик символы можно вводить по одному в строке, пока не будет введена точка). Требуется написать как можно более эффективную программу (укажите используемую версию языка программирования, например, Borland Pascal 7.0), которая составит из тех цифр, которые
встречаются во входных данных, максимальное число. При составлении итогового числа каждая цифра может быть использована только один раз. Если во входных данных цифры не встречаются, то следует вывести "-1". Например, пусть на вход подаются следующие символы:
14ф73п439
В данном случае программа должна вывести
97431
*/
using System;
using System.Collections.Generic;
using System.Linq;
namespace ConsoleApplication1
{
class Program
{
static void Main()
{
List<char> list = new List<char>();
Console.WriteLine("Начинайте вводить последовательность");
for (; ; )
{
char c = (char)Console.Read();
if (c == '.') break;
if (char.IsDigit(c)) list.Add(c);
}
if(list.Count()==0)
{
Console.WriteLine("-1");
Console.ReadKey();
return;
}
var answer = list.Distinct().OrderByDescending(l => l);
foreach (var a in answer)
{
Console.Write(a);
}
Console.ReadKey();
}
}
}