Исправьте ошибки в program partiii; var n, numparties, i, j, t: integer; count: array[1..10] of integer; s: string[50]; names: array[1..10] of string; begin numparties: =0; readln(n); for i: =1 to numparties do begin max: =count[i]; n: =i; for l: =1 to numparties do begin if count[l]> max then begin max: =count[l]; n: =l; end; end; if names[n]< > '' then begin writeln (names[n]); count[n]: =-1; names[n]: =''; end; end; for i: =2 to numparties do if count[i-1]> n then begin n: =count[i]; t: =i; end; writeln(names[t]) end. вот какое было , доработайте программу так, чтобы она решала следующую : 1) программа должна вывести список всех партий, встречающихся в исходном списке, в порядке убывания количества голосов, отданных за эту партию. при этом название каждой партии должно быть выведено ровно один раз, вне зависимости от того, сколько голосов было отдано за данную партию. пример выходных данных для выше примера входных данных: party three party two party one 2) на вход программы подается список, при этом некоторые голоса являются недействительными, в этом случае вместо названия партии записан один символ «.» (точка). партия проходит в парламент, если за нее отдано не менее 7% от общего числа действительных голосов (то есть от количества строк в списке, которые не равны «.»). программа должна вывести список всех партий, прошедших в парламент, в произвольном порядке. при этом название каждой партии должно быть выведено ровно один раз, вне зависимости от того, сколько голосов было отдано за данную партию.
230
417
Ответы на вопрос:
1) program partiii; var n, numparties, i, j, max: integer; count: array[1..10] of integer; names: array[1..10] of string; begin writeln('количество партий: '); read (numparties); for i: =1 to numparties do begin if names[n]< > '' then begin max: =count[i]; n : = i; for j: =2 to numparties do begin if count[j]> max then begin max : = count[j]; n: =j; end; end; writeln (names[n]); count[n] : = -1; names[n] : = ''; end; end; end; end. 2) алгоритм: вводятся данные в массив inlist. массив просматривается, при совпадении партии увеличивается счетчик. названия партий добавляются в список по мере встречаемости во входном массиве. названия с точкой тоже подсчитываются. дальше считается число действительных голосов, лпределяется процент. если больше 7 - выводится. процент недействительных голосов тоже выводится на общих основаниях. program partiii; const m=2000; var n, numparties, i, j: integer; inlist: array[1..m] of integer; //входной список s: string; n: real; t: boolean; names: array[1..10] of string; //список партий count: array[1..10] of integer; //количество голосов begin numparties : = 1; names[1] : = inlist[1]; count[1] : = 1; for i : = 2 to m do begin s : = inlist[i]; t : = false; for j: =1 to numparties do begin if s=names[j] then begin t : = true; count[j] : = count[j] + 1; end; end; if (t = false) then //партия встретилась первый раз. добавляем в список begin numparties : = numparties +1; count[numparties] : = 1; names[numparties] : = inlist[i]; end; end; for j: =1 to numparties do if names[j] < > '.' then n : = n + count[j]; //общее количество голосов без '.' for j: =1 to numparties do begin if names[j] < > '.' then begin n1 : = count[j]/n; //% по партии if n1 > = 7 then writeln (names[j]); end else begin n1 : = count[j]/n; writeln ('недействительных голосов: ', n1, ' %'); end; end; end; end.
ответ: #include
#include
using namespace std;
int main()
{
int smth;
cin > > smth;
for(int i = 1; i< =smth; i++){
cout < < i < < " ";
}
cout < < endl;
for(int i = smth; i> =1; i--){
cout < < i < < " ";
}
return 0;
}
объяснение: это дополнение к ранее ответа
Популярно: Информатика
-
MiaDakota24.05.2020 21:55
-
kabekesov9907.04.2020 08:33
-
Камилия31125.12.2020 22:58
-
ALINASVETLYRULIT11.08.2022 09:34
-
ксениякейт24.10.2022 06:29
-
alenaFox45705.03.2022 05:10
-
alextrasted07.06.2020 13:29
-
bahriddinJoN208526.01.2023 10:50
-
taniaselikova16.07.2021 06:25
-
1Booooooooooom114.10.2020 08:25