The computer has important parts such as the input/output, memory and CPU. The human has similar attributes making it possible to interact with computers. As an expert in Human Computer Interaction: a. How would you model a Human as a Processor? 6 marks b. Briefly explain 4 limitations of interactive performance. 4 marks c. Use switching of a light bulb to illustrate Norman’s cycle. 9 marks d. Differentiate between error and a slip. 1 mark
In: Computer Science
Write code in Python that does the following : An anagram is
when the order of a word can be changed to create a new word
(evil,
live, and vile for example). Using the dictionary provided, find
all of the anagram groups.
Which words contain the most anagrams? How large is this group?
Here is another example:
Alert, alter, and later have 3 in their group. Use the provided
dict.txt as your word list,
solution must also finish in less than a minute.
* I know there is no dict.txt file to use here..
file = open("dict.txt", "r", encoding="utf8")
*looking for a way to sort through the file and group anograms together
*output the groups from largest to smallest (if there is only a
single word in a group, no need to display)
file.close()
In: Computer Science
What type of the combinational circuit is described by the
following VHDL process? 1. XOR gate 2. XNOR gate 3. 2-to-1 MUX 4. half adder |
In: Computer Science
DO THIS IN C#. Design and implement a program (name it MinMaxAvg) that defines three methods as follows: Method max (int x, int y, int z) returns the maximum value of three integer values. Method min (int X, int y, int z) returns the minimum value of three integer values. Method average (int x, int y, int z) returns the average of three integer values. In the main method, test all three methods with different input value read from the user. Document your code and properly label the input prompts and the outputs as shown below. Sample run 1: You entered: 20, 8, 12 Max value: 20 Min value: 8 Average value: 13 Sample run 2: You entered: 1, 2, 3 Max value: 3 Min value: 1 Average value: 2 Sample run 3: You entered: 10, 5, 25 Max value: 25 Min value: 5 Average value: 13
In: Computer Science
3. The Hofstadter Conway sequence is defined by a(1)=a(2)=1 and (for n>2 by) a(n)=a(a(n-1))+a(n-a(n-1)). Write a function to quickly compute this sequence.
>>> [hc(i) for i in range(1,20)] [1, 1, 2, 2, 3, 4, 4, 4, 5, 6, 7, 7, 8, 8, 8, 8, 9, 10, 11]
In: Computer Science
Write a function COTtupleRange(xstart,xend,xstep) that returns a tuple that has:
- as index 0 item, the value of xstart
- as index 1 item, the value xstart+xstep
- as index 2 item, the value (xstart+xstep)+xstep,
and so on as long as the value does equal or pass the value of xend.
However, the function should return an empty string if for positive xstep, xstart>xend or if for negative xstep, xstart < xend. Here are three examples:
a = (2, 2.5, 3., 3.5)
a = (2, 1.5, 1., 0.5)
a = ()
Your code should also have a function mainProg() for testing the COTtupleRange(xstart,xend,xstep) function and the associated if __name__ == statement. Write the mainProg() code so that it does the three examples shown above.
In: Computer Science
In: Computer Science
Of the primary areas of US concern surrounding cybersecurity, what do you think is the most important issue facing policy makers?
In: Computer Science
The following code must be written using matlab
How to get the elements that are different in two set without using the setdiff function in matlbab?
In: Computer Science
I need the following C code converted to java or C++
#include <stdio.h>
#include <stdlib.h>
typedef struct node {
struct node *left;
struct node *right;
long data;
long leftSize;
} node;
void btreeInsert(node *new, node **rootptr) {
node *parent = NULL, *cursor;
/* Find parent */
cursor = *rootptr;
while (cursor != NULL) {
parent = cursor;
if (new->data < cursor->data) {
cursor->leftSize += 1;
cursor = cursor->left;
} else {
cursor = cursor->right;
}
}
/* Insert node below parent */
if (parent == NULL) {
*rootptr = new;
} else if (new->data < parent->data) {
parent->left = new;
} else {
parent->right = new;
}
}
node *readTree(FILE *dataFile) {
node *root = NULL, *new;
long element;
while (fscanf(dataFile, "%ld\n", &element) == 1) {
new = malloc(sizeof(node));
new->data = element;
new->right = NULL;
new->left = NULL;
new->leftSize = 0;
btreeInsert(new, &root);
}
return root;
}
long kthOrder(int k, node *root) {
node *current;
current = root;
while (k != current->leftSize + 1) {
if (k <= current->leftSize) {
current = current->left;
} else {
k -= current->leftSize + 1;
current = current->right;
}
}
return current->data;
}
void reportKthOrderStats(FILE *positionFile, node *root) {
int position;
while (fscanf(positionFile, "%i\n", &position) == 1) {
printf("%ld\n", kthOrder(position, root));
}
}
int main(int argc, const char * argv[]) {
const char *data, *range;
FILE *dataFile, *rangeFile;
node *root;
data = argv[1];
range = argv[2];
dataFile = fopen(data, "r");
rangeFile = fopen(range, "r");
root = readTree(dataFile);
reportKthOrderStats(rangeFile, root);
return (0);
}
In: Computer Science
In: Computer Science
Write a program in NASM that turns a 32-bit numeric value (e.g., 0xFFFFh) and converts it to a byte array such that it can be printed to the screen using a system call method. A loop is necessary for converting the numeric value to ASCII for output. Again, use a system call (e.g., int 80h) to print the value to the console. Calling external functions (e.g. printf) is not allowed. You may use the starter file attached to this assignment.
In: Computer Science
Program Description
Write and test a MASM program to perform the following tasks:
Program Requirements
In: Computer Science
Write the code in Java:
1. Create a method that displays your name in the console. This method is void and takes no parameters. Make an app that runs the method in response to a button press.
2. Create a version of the method in #1 that takes the text (String) to be displayed as a parameter. Allow the user to enter the text in a dialog box or text field and display that text in the console. Be sure to trim() the text.
In: Computer Science
c++ "Programming For Big Data [
DvcScheduleV2.cpp and
StaticArray.h and/or
DynamicArray.h ]
Assignment 5's runtime was too slow -- a couple of minutes or so.
It's because of the duplicate-checking, with over 4 billion
compares.
Rewrite the duplicate-checking logic from Assignment 5, using a technique from "Techniques For Big Data, Reading" to do fewer compares, and come up with the exact same results as Assignment 5.
You may use your StaticArray.h from Assignment 3 and/or your DynamicArray.h from assignments 4, but you may not use any STL containers. Submit the H file(s) you use in your solution, even if there are no changes since your previous work. Your project will be compiled for grading using the default stack memory size of 1MB.
Progress Bar
Since this version is supposed to be fast, there is no longer a need for a progress bar. Include one if you wish, or you may leave it out -- your choice. But if you do have a progress bar, do remember to "flush"...
You should get the same result as V1 and should run an order of magnitude faster."
For some reason I'm getting different results from my first version of the programs and the program I've written for this assignment.
Code for the prior assignment :
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <fstream>
#include <string>
using namespace std;
#include <cstring>
#include "DynamicArray.h"
struct Class
{
string code;
int count;
};
int main()
{
DynamicArray <Class> sub;
DynamicArray <string> sem;
DynamicArray <string> sec;
int totalSubjects = 0;
int dup = 0;
int total = 0;
int counter = 0;
bool duplicate;
bool stored;
//for parsing inputfile
char* token;
char buf[1000];
const char* const tab = "\t";
//open input file
ifstream fin;
fin.open("dvc-schedule.txt");
if (!fin.good())
cout << "I/O error. File can't be found!\n";
//read the input file
while (fin.good())
{
//progress bar
if(counter % 1000 == 0)
cout << '.'; cout.flush();
duplicate = false;
stored = false;
string line;
getline(fin, line);
total++; //total lines processed
strcpy(buf, line.c_str());
if (buf[0] == 0) continue; // skip blank lines
//parse the line
const string term(token = strtok(buf, tab));
const string section(token = strtok(0, tab));
const string course((token = strtok(0, tab)) ? token : "");
const string instructor((token = strtok(0, tab)) ? token :
"");
const string whenWhere((token = strtok(0, tab)) ? token :
"");
if (course.find('-') == string::npos) continue;
const string code(course.begin(), course.begin() +
course.find('-'));
//check for duplicates
for(int i = 0; i < counter; i++)
{
if(sem[i] == term && sec[i] == section)
{
dup++;
duplicate = true;
break;
}
}
if(duplicate == true)
continue;
sem[counter] = term;
sec[counter] = section;
counter++;
for(int i = 0; i < totalSubjects; i++)
{
if (sub[i].code == code)
{
sub[i].count++;
stored = true;
break;
}
}
if(stored == true)
continue;
Class y;
y.code = code;
y.count = 1;
sub[totalSubjects] = y;
totalSubjects++;
}
fin.close();
cout << endl;
//sort
for (int i = 0; i < totalSubjects; i++)
for (int j = i + 1; j < totalSubjects; j++)
if (sub[j].code < sub[i].code)
swap(sub[j], sub[i]);
//output
for(int i = 0; i < totalSubjects; i++)
{
cout << sub[i].code << ", " << sub[i].count
<< " section" << endl;
}
cout << "Total duplication: " << dup <<
endl;
cout << "Total counts: " << total << endl;
cout << "Total subjects: " << totalSubjects <<
endl;
}
Code for this assignment:
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <fstream>
#include <string>
using namespace std;
#include <cstring>
#include "DynamicArray.h"
struct SectionsForTerm
{
string term;
int numberOfSectionsSeen;
DynamicArray<string> seenSectionNumbers;
};
struct Class
{
string code;
int count;
};
int main()
{
int numberOfTermsSeen = 0;
DynamicArray <SectionsForTerm> alreadySeen;
DynamicArray <Class> sub;
int totalSubjects = 0;
int dup = 0;
int total = 0;
int counter = 0;
bool match;
bool duplicate;
bool stored;
//for parsing inputfile
char* token;
char buf[1000];
const char* const tab = "\t";
//open input file
ifstream fin;
fin.open("dvc-schedule.txt");
if (!fin.good())
cout << "I/O error. File can't be found!\n";
//read the input file
while (fin.good())
{
//check for false
match = false;
duplicate = false;
stored = false;
//read lines
string line;
getline(fin, line);
total++; //total lines processed
strcpy(buf, line.c_str());
if (buf[0] == 0) continue; // skip blank lines
//parse the line
const string term(token = strtok(buf, tab));
const string section(token = strtok(0, tab));
const string course((token = strtok(0, tab)) ? token : "");
const string instructor((token = strtok(0, tab)) ? token :
"");
const string whenWhere((token = strtok(0, tab)) ? token :
"");
if (course.find('-') == string::npos) continue;
const string code(course.begin(), course.begin() +
course.find('-'));
//check for duplicates
int i;
for(int i = 0; i < numberOfTermsSeen; i++)
{
if(alreadySeen[i].term == term)
{
match = true;
break;
}
}
if(match == true)
{
for(int j = 0; j < alreadySeen[i].numberOfSectionsSeen;
j++)
if (alreadySeen[i].seenSectionNumbers[j]== section)
{
duplicate = true;
dup++;
break;
}
if (duplicate == true)
continue;
else
{
alreadySeen[i].seenSectionNumbers[alreadySeen[i].numberOfSectionsSeen]=
section;
alreadySeen[i].numberOfSectionsSeen++;
}
}
else
{
alreadySeen[numberOfTermsSeen].term = term;
alreadySeen[i].numberOfSectionsSeen = 1;
numberOfTermsSeen++;
}
// check for same section
for(i = 0; i < totalSubjects; i++)
{
if(sub[i].code == code)
{
stored = true;
break;
}
}
if(stored == true)
{
sub[i].count++;
}
else
{
sub[totalSubjects].code = code;
sub[totalSubjects].count = 1;
totalSubjects++;
}
counter++;
}
fin.close();
cout << endl;
//sort
for (int i = 0; i < totalSubjects; i++)
for (int j = i + 1; j < totalSubjects; j++)
if (sub[j].code < sub[i].code)
swap(sub[j], sub[i]);
//output
for(int i = 0; i < totalSubjects; i++)
{
cout << sub[i].code << ", " << sub[i].count
<< " section" << endl;
}
cout << "Total duplication: " << dup <<
endl;
cout << "Total counts: " << total << endl;
cout << "Total subjects: " << totalSubjects <<
endl;
}
*When I compare the results of both programs the subjects and total are the same but the total duplication number is significantly off. Also the amount of sections per course is off? I'm not really sure how, why, or how to fix it?
In: Computer Science